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

Commit debf34b8 authored by Bill Yi's avatar Bill Yi
Browse files

Merge RQ1A.210205.004 to stage-aosp-master - DO NOT MERGE

Merged-In: If01c89c950ca18036e4826decea118ddccb8a1f6
Change-Id: I60adcadcbef8aca951c6d1e88dbee7223f8f94da
parents ef58af7e d677162f
Loading
Loading
Loading
Loading
+7 −2
Original line number Diff line number Diff line
@@ -317,7 +317,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 {
@@ -328,6 +328,7 @@ public:
        sp<ConsumerListener> listener{new ConsumerListener};
        mConsumer->consumerConnect(listener, false);
        mConsumer->setConsumerName(String8{"MediaCodec.release"});
        mConsumer->setConsumerUsageBits(usage);
    }

    const sp<Surface> &getSurface() {
@@ -3122,7 +3123,11 @@ void MediaCodec::onMessageReceived(const sp<AMessage> &msg) {
            if (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());