SurfaceFlinger: Support out of order transactions
With BLAST, buffers are submitted via transactions and they are subjected to the same transaction queueing logic - transactions from a client must be applied in the order they came in. This poses a problem when clients use multiple blast adapters. Transactions from one window can get queued up if the buffer is not ready to be presented, preventing transactions from another window to be applied in a timely manner. We fix this by using a different apply token for every bast adapter so their transactions are handled independently. Bug: b/176411039, b/168917217 Test: atest BlastBufferQueueTest Test: YouTube minimize video and scroll, notice scrolling is at 60/90fps Change-Id: I0005dfa3c221a2b33545e39af16ae4b1ef08d269
Loading
Please register or sign in to comment