Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 82e82762 authored by Wonsik Kim's avatar Wonsik Kim Committed by Android (Google) Code Review
Browse files

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

parents 4328b613 063ea0ad
Loading
Loading
Loading
Loading
+12 −2
Original line number Diff line number Diff line
@@ -242,6 +242,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
@@ -1124,7 +1131,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) {
@@ -2797,7 +2807,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
+1 −0
Original line number Diff line number Diff line
@@ -61,6 +61,7 @@ struct JMediaCodec : public AHandler {

    void registerSelf();
    void release();
    void releaseAsync();

    status_t enableOnFrameRenderedListener(jboolean enable);