Merge "RELAND: "media: lazy MediaCodec.release()"" into rvc-dev

This commit is contained in:
Wonsik Kim
2020-04-30 17:12:33 +00:00
committed by Android (Google) Code Review
2 changed files with 13 additions and 2 deletions

View File

@@ -232,6 +232,13 @@ void JMediaCodec::release() {
});
}
void JMediaCodec::releaseAsync() {
if (mCodec != NULL) {
mCodec->releaseAsync();
}
mInitStatus = NO_INIT;
}
JMediaCodec::~JMediaCodec() {
if (mLooper != NULL) {
/* MediaCodec and looper should have been released explicitly already
@@ -1114,7 +1121,10 @@ static sp<JMediaCodec> getMediaCodec(JNIEnv *env, jobject thiz) {
}
static void android_media_MediaCodec_release(JNIEnv *env, jobject thiz) {
setMediaCodec(env, thiz, NULL);
sp<JMediaCodec> codec = getMediaCodec(env, thiz);
if (codec != NULL) {
codec->releaseAsync();
}
}
static void throwCodecException(JNIEnv *env, status_t err, int32_t actionCode, const char *msg) {
@@ -2889,7 +2899,7 @@ static void android_media_MediaCodec_native_setup(
static void android_media_MediaCodec_native_finalize(
JNIEnv *env, jobject thiz) {
android_media_MediaCodec_release(env, thiz);
setMediaCodec(env, thiz, NULL);
}
// MediaCodec.LinearBlock

View File

@@ -61,6 +61,7 @@ struct JMediaCodec : public AHandler {
void registerSelf();
void release();
void releaseAsync();
status_t enableOnFrameRenderedListener(jboolean enable);