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

Commit dc71bebc authored by Rob Carr's avatar Rob Carr Committed by Android (Google) Code Review
Browse files

Merge "Add Surface::waitForNextFrame" into nyc-dev

parents ef1081f9 9f31e299
Loading
Loading
Loading
Loading
+9 −0
Original line number Diff line number Diff line
@@ -122,6 +122,13 @@ public:
    // See IGraphicBufferProducer::setDequeueTimeout
    status_t setDequeueTimeout(nsecs_t timeout);

    /*
     * Wait for frame number to increase past lastFrame for at most
     * timeoutNs. Useful for one thread to wait for another unknown
     * thread to queue a buffer.
     */
    bool waitForNextFrame(uint64_t lastFrame, nsecs_t timeout);

protected:
    virtual ~Surface();

@@ -348,6 +355,8 @@ private:
    // This is true if the shared buffer has already been queued/canceled. It's
    // used to prevent a mismatch between the number of queue/dequeue calls.
    bool mSharedBufferHasBeenQueued;

    Condition mQueueBufferCondition;
};

namespace view {
+11 −0
Original line number Diff line number Diff line
@@ -480,6 +480,8 @@ int Surface::queueBuffer(android_native_buffer_t* buffer, int fenceFd) {
        mSharedBufferHasBeenQueued = true;
    }

    mQueueBufferCondition.broadcast();

    return err;
}

@@ -1259,6 +1261,15 @@ status_t Surface::unlockAndPost()
    return err;
}

bool Surface::waitForNextFrame(uint64_t lastFrame, nsecs_t timeout) {
    Mutex::Autolock lock(mMutex);
    uint64_t currentFrame = mGraphicBufferProducer->getNextFrameNumber();
    if (currentFrame > lastFrame) {
      return true;
    }
    return mQueueBufferCondition.waitRelative(mMutex, timeout) == OK;
}

namespace view {

status_t Surface::writeToParcel(Parcel* parcel) const {