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

Commit b53fe9f1 authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Automerger Merge Worker
Browse files

Merge "MediaCodec: propagate usage from original surface to release surface"...

Merge "MediaCodec: propagate usage from original surface to release surface" into rvc-dev am: 68aa6aad

Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/av/+/12792333

Change-Id: I719f70d978a8b030c9e886b8aa5d4c82de625d26
parents 8579aa2b 68aa6aad
Loading
Loading
Loading
Loading
+7 −2
Original line number Diff line number Diff line
@@ -314,7 +314,7 @@ MediaCodec::BufferInfo::BufferInfo() : mOwnedByClient(false) {}

class MediaCodec::ReleaseSurface {
public:
    ReleaseSurface() {
    explicit ReleaseSurface(uint64_t usage) {
        BufferQueue::createBufferQueue(&mProducer, &mConsumer);
        mSurface = new Surface(mProducer, false /* controlledByApp */);
        struct ConsumerListener : public BnConsumerListener {
@@ -325,6 +325,7 @@ public:
        sp<ConsumerListener> listener{new ConsumerListener};
        mConsumer->consumerConnect(listener, false);
        mConsumer->setConsumerName(String8{"MediaCodec.release"});
        mConsumer->setConsumerUsageBits(usage);
    }

    const sp<Surface> &getSurface() {
@@ -3090,7 +3091,11 @@ void MediaCodec::onMessageReceived(const sp<AMessage> &msg) {
            if (msg->findMessage("async", &asyncNotify) && asyncNotify != nullptr) {
                if (mSurface != NULL) {
                    if (!mReleaseSurface) {
                        mReleaseSurface.reset(new ReleaseSurface);
                        uint64_t usage = 0;
                        if (mSurface->getConsumerUsage(&usage) != OK) {
                            usage = 0;
                        }
                        mReleaseSurface.reset(new ReleaseSurface(usage));
                    }
                    if (mSurface != mReleaseSurface->getSurface()) {
                        status_t err = connectToSurface(mReleaseSurface->getSurface());