diff options
Diffstat (limited to 'libs/gui/SurfaceComposerClient.cpp')
| -rw-r--r-- | libs/gui/SurfaceComposerClient.cpp | 6 | 
1 files changed, 5 insertions, 1 deletions
| diff --git a/libs/gui/SurfaceComposerClient.cpp b/libs/gui/SurfaceComposerClient.cpp index 5bc05ef0d8..db99726739 100644 --- a/libs/gui/SurfaceComposerClient.cpp +++ b/libs/gui/SurfaceComposerClient.cpp @@ -377,7 +377,6 @@ void TransactionCompletedListener::onTransactionCompleted(ListenerStats listener              }              auto& [callbackFunction, callbackSurfaceControls] = callbacksMap[callbackId];              if (!callbackFunction) { -                ALOGE("cannot call null callback function, skipping");                  continue;              }              std::vector<SurfaceControlStats> surfaceControlStats; @@ -394,6 +393,11 @@ void TransactionCompletedListener::onTransactionCompleted(ListenerStats listener              callbackFunction(transactionStats.latchTime, transactionStats.presentFence,                               surfaceControlStats); + +            // More than one transaction may contain the same callback id. Erase the callback from +            // the map to ensure that it is only called once. This can happen if transactions are +            // parcelled out of process and applied in both processes. +            callbacksMap.erase(callbackId);          }          // handle on complete callbacks |