blob: 4b7d4b1a5d1c2ad9a2dafcfe44bff08e136d382d [file] [log] [blame]
The Android Open Source Projectedbf3b62009-03-04 03:31:441/*
2 * Copyright (C) 2007 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#define LOG_TAG "SurfaceComposerClient"
18
19#include <stdint.h>
The Android Open Source Projectedbf3b62009-03-04 03:31:4420#include <sys/types.h>
The Android Open Source Projectedbf3b62009-03-04 03:31:4421
The Android Open Source Projectedbf3b62009-03-04 03:31:4422#include <utils/Errors.h>
The Android Open Source Projectedbf3b62009-03-04 03:31:4423#include <utils/Log.h>
Mathias Agopiana67932f2011-04-20 21:20:5924#include <utils/SortedVector.h>
25#include <utils/String8.h>
26#include <utils/threads.h>
The Android Open Source Projectedbf3b62009-03-04 03:31:4427
Marissa Wall7a9b6ff2018-08-22 00:26:2028#include <binder/IPCThreadState.h>
Mathias Agopiana67932f2011-04-20 21:20:5929#include <binder/IServiceManager.h>
Marissa Wall7a9b6ff2018-08-22 00:26:2030#include <binder/ProcessState.h>
Mathias Agopian9cce3252010-02-10 01:46:3731
Michael Wright28f24d02016-07-12 20:30:5332#include <system/graphics.h>
33
Robert Carr673134e2017-01-10 03:48:3834#include <gui/BufferItemConsumer.h>
Mathias Agopianabe815d2013-03-20 05:22:2135#include <gui/CpuConsumer.h>
Mathias Agopiane3c697f2013-02-15 01:11:0236#include <gui/IGraphicBufferProducer.h>
Mathias Agopian90ac7992012-02-26 02:48:3537#include <gui/ISurfaceComposer.h>
38#include <gui/ISurfaceComposerClient.h>
Robert Carr4cdc58f2017-08-23 21:22:2039#include <gui/LayerState.h>
Robert Carr0d480722017-01-11 00:42:5440#include <gui/Surface.h>
Mathias Agopian90ac7992012-02-26 02:48:3541#include <gui/SurfaceComposerClient.h>
Dominik Laskowski3cb3d4e2019-11-21 19:14:4542#include <ui/DisplayConfig.h>
The Android Open Source Projectedbf3b62009-03-04 03:31:4443
Robert Carr2c358bf2018-08-08 22:58:1544#ifndef NO_INPUT
45#include <input/InputWindow.h>
46#endif
47
Mathias Agopian41f673c2011-11-18 01:48:3548#include <private/gui/ComposerService.h>
The Android Open Source Projectedbf3b62009-03-04 03:31:4449
Marissa Wall73411622019-01-25 18:45:4150// This server size should always be smaller than the server cache size
51#define BUFFER_CACHE_MAX_SIZE 64
52
The Android Open Source Projectedbf3b62009-03-04 03:31:4453namespace android {
Peiyong Lin9f034472018-03-28 22:29:0054
55using ui::ColorMode;
The Android Open Source Projectedbf3b62009-03-04 03:31:4456// ---------------------------------------------------------------------------
57
Mathias Agopian7e27f052010-05-28 21:22:2358ANDROID_SINGLETON_STATIC_INSTANCE(ComposerService);
59
Mathias Agopianb7e930d2010-06-01 22:12:5860ComposerService::ComposerService()
61: Singleton<ComposerService>() {
Andy McFadden6652b3e2012-09-07 01:45:5662 Mutex::Autolock _l(mLock);
63 connectLocked();
64}
65
66void ComposerService::connectLocked() {
Mathias Agopianb7e930d2010-06-01 22:12:5867 const String16 name("SurfaceFlinger");
68 while (getService(name, &mComposerService) != NO_ERROR) {
69 usleep(250000);
70 }
Yi Konga03e0442018-07-17 18:16:5771 assert(mComposerService != nullptr);
Andy McFadden6652b3e2012-09-07 01:45:5672
73 // Create the death listener.
74 class DeathObserver : public IBinder::DeathRecipient {
75 ComposerService& mComposerService;
76 virtual void binderDied(const wp<IBinder>& who) {
77 ALOGW("ComposerService remote (surfaceflinger) died [%p]",
78 who.unsafe_get());
79 mComposerService.composerServiceDied();
80 }
81 public:
Chih-Hung Hsiehe2347b72016-04-25 22:41:0582 explicit DeathObserver(ComposerService& mgr) : mComposerService(mgr) { }
Andy McFadden6652b3e2012-09-07 01:45:5683 };
84
85 mDeathObserver = new DeathObserver(*const_cast<ComposerService*>(this));
Marco Nelissen2ea926b2014-11-14 16:01:0186 IInterface::asBinder(mComposerService)->linkToDeath(mDeathObserver);
Mathias Agopianb7e930d2010-06-01 22:12:5887}
88
Andy McFadden6652b3e2012-09-07 01:45:5689/*static*/ sp<ISurfaceComposer> ComposerService::getComposerService() {
90 ComposerService& instance = ComposerService::getInstance();
91 Mutex::Autolock _l(instance.mLock);
Yi Kong48a619f2018-06-05 23:34:5992 if (instance.mComposerService == nullptr) {
Andy McFadden6652b3e2012-09-07 01:45:5693 ComposerService::getInstance().connectLocked();
Yi Konga03e0442018-07-17 18:16:5794 assert(instance.mComposerService != nullptr);
Andy McFadden6652b3e2012-09-07 01:45:5695 ALOGD("ComposerService reconnected");
96 }
97 return instance.mComposerService;
98}
99
100void ComposerService::composerServiceDied()
101{
102 Mutex::Autolock _l(mLock);
Yi Kong48a619f2018-06-05 23:34:59103 mComposerService = nullptr;
104 mDeathObserver = nullptr;
Mathias Agopianb7e930d2010-06-01 22:12:58105}
106
Robert Carrfb4d58b2019-01-15 17:21:27107class DefaultComposerClient: public Singleton<DefaultComposerClient> {
108 Mutex mLock;
109 sp<SurfaceComposerClient> mClient;
110 friend class Singleton<ComposerService>;
111public:
112 static sp<SurfaceComposerClient> getComposerClient() {
113 DefaultComposerClient& dc = DefaultComposerClient::getInstance();
114 Mutex::Autolock _l(dc.mLock);
115 if (dc.mClient == nullptr) {
116 dc.mClient = new SurfaceComposerClient;
117 }
118 return dc.mClient;
119 }
120};
121ANDROID_SINGLETON_STATIC_INSTANCE(DefaultComposerClient);
122
123
124sp<SurfaceComposerClient> SurfaceComposerClient::getDefault() {
125 return DefaultComposerClient::getComposerClient();
126}
127
Mathias Agopian7e27f052010-05-28 21:22:23128// ---------------------------------------------------------------------------
129
Marissa Wall7a9b6ff2018-08-22 00:26:20130// TransactionCompletedListener does not use ANDROID_SINGLETON_STATIC_INSTANCE because it needs
131// to be able to return a sp<> to its instance to pass to SurfaceFlinger.
132// ANDROID_SINGLETON_STATIC_INSTANCE only allows a reference to an instance.
133
Marissa Wallc837b5e2018-10-12 17:04:44134// 0 is an invalid callback id
135TransactionCompletedListener::TransactionCompletedListener() : mCallbackIdCounter(1) {}
136
137CallbackId TransactionCompletedListener::getNextIdLocked() {
138 return mCallbackIdCounter++;
139}
140
Marissa Wall7a9b6ff2018-08-22 00:26:20141sp<TransactionCompletedListener> TransactionCompletedListener::getInstance() {
142 static sp<TransactionCompletedListener> sInstance = new TransactionCompletedListener;
143 return sInstance;
144}
145
Marissa Wallc837b5e2018-10-12 17:04:44146sp<ITransactionCompletedListener> TransactionCompletedListener::getIInstance() {
147 return static_cast<sp<ITransactionCompletedListener>>(getInstance());
148}
149
150void TransactionCompletedListener::startListeningLocked() {
Marissa Wall7a9b6ff2018-08-22 00:26:20151 if (mListening) {
152 return;
153 }
154 ProcessState::self()->startThreadPool();
155 mListening = true;
156}
157
Marissa Wall80d94ad2019-01-19 00:04:36158CallbackId TransactionCompletedListener::addCallbackFunction(
159 const TransactionCompletedCallback& callbackFunction,
160 const std::unordered_set<sp<SurfaceControl>, SurfaceComposerClient::SCHash>&
161 surfaceControls) {
Marissa Wallc837b5e2018-10-12 17:04:44162 std::lock_guard<std::mutex> lock(mMutex);
163 startListeningLocked();
164
165 CallbackId callbackId = getNextIdLocked();
Marissa Wall80d94ad2019-01-19 00:04:36166 mCallbacks[callbackId].callbackFunction = callbackFunction;
167
168 auto& callbackSurfaceControls = mCallbacks[callbackId].surfaceControls;
169
170 for (const auto& surfaceControl : surfaceControls) {
171 callbackSurfaceControls[surfaceControl->getHandle()] = surfaceControl;
172 }
173
Marissa Wallc837b5e2018-10-12 17:04:44174 return callbackId;
175}
176
Marissa Wall80d94ad2019-01-19 00:04:36177void TransactionCompletedListener::addSurfaceControlToCallbacks(
178 const sp<SurfaceControl>& surfaceControl,
179 const std::unordered_set<CallbackId>& callbackIds) {
180 std::lock_guard<std::mutex> lock(mMutex);
181
182 for (auto callbackId : callbackIds) {
183 mCallbacks[callbackId].surfaceControls.emplace(std::piecewise_construct,
184 std::forward_as_tuple(
185 surfaceControl->getHandle()),
186 std::forward_as_tuple(surfaceControl));
187 }
188}
189
Marissa Walle2ffb422018-10-12 18:33:52190void TransactionCompletedListener::onTransactionCompleted(ListenerStats listenerStats) {
Valerie Haud3b90d22019-11-06 17:37:31191 std::unordered_map<CallbackId, CallbackTranslation> callbacksMap;
192 {
193 std::lock_guard<std::mutex> lock(mMutex);
Marissa Walle2ffb422018-10-12 18:33:52194
Valerie Haud3b90d22019-11-06 17:37:31195 /* This listener knows all the sp<IBinder> to sp<SurfaceControl> for all its registered
196 * callbackIds, except for when Transactions are merged together. This probably cannot be
197 * solved before this point because the Transactions could be merged together and applied in
198 * a different process.
199 *
200 * Fortunately, we get all the callbacks for this listener for the same frame together at
201 * the same time. This means if any Transactions were merged together, we will get their
202 * callbacks at the same time. We can combine all the sp<IBinder> to sp<SurfaceControl> maps
203 * for all the callbackIds to generate one super map that contains all the sp<IBinder> to
204 * sp<SurfaceControl> that could possibly exist for the callbacks.
205 */
206 callbacksMap = mCallbacks;
207 for (const auto& transactionStats : listenerStats.transactionStats) {
208 for (auto& callbackId : transactionStats.callbackIds) {
209 mCallbacks.erase(callbackId);
210 }
Marissa Wall80d94ad2019-01-19 00:04:36211 }
212 }
Marissa Walld600d572019-03-26 22:38:50213 for (const auto& transactionStats : listenerStats.transactionStats) {
214 for (auto callbackId : transactionStats.callbackIds) {
Valerie Haud3b90d22019-11-06 17:37:31215 auto& [callbackFunction, callbackSurfaceControls] = callbacksMap[callbackId];
Marissa Wall80d94ad2019-01-19 00:04:36216 if (!callbackFunction) {
Marissa Walle2ffb422018-10-12 18:33:52217 ALOGE("cannot call null callback function, skipping");
218 continue;
219 }
Marissa Wall80d94ad2019-01-19 00:04:36220 std::vector<SurfaceControlStats> surfaceControlStats;
221 for (const auto& surfaceStats : transactionStats.surfaceStats) {
Valerie Haud3b90d22019-11-06 17:37:31222 surfaceControlStats
223 .emplace_back(callbacksMap[callbackId]
224 .surfaceControls[surfaceStats.surfaceControl],
Valerie Hau871d6352020-01-29 16:44:02225 transactionStats.latchTime, surfaceStats.acquireTime,
226 transactionStats.presentFence,
227 surfaceStats.previousReleaseFence, surfaceStats.transformHint,
228 surfaceStats.eventStats);
Valerie Hau84d87ff2020-01-09 01:23:21229 if (callbacksMap[callbackId].surfaceControls[surfaceStats.surfaceControl]) {
230 callbacksMap[callbackId]
231 .surfaceControls[surfaceStats.surfaceControl]
232 ->setTransformHint(surfaceStats.transformHint);
233 }
Marissa Wall80d94ad2019-01-19 00:04:36234 }
235
236 callbackFunction(transactionStats.latchTime, transactionStats.presentFence,
237 surfaceControlStats);
Marissa Walle2ffb422018-10-12 18:33:52238 }
239 }
Marissa Wall7a9b6ff2018-08-22 00:26:20240}
241
242// ---------------------------------------------------------------------------
243
Robert Carre06ad2b2020-04-10 22:09:33244void removeDeadBufferCallback(void* /*context*/, uint64_t graphicBufferId);
Marissa Wall78b72202019-03-15 21:58:34245
Robert Carre06ad2b2020-04-10 22:09:33246/**
247 * We use the BufferCache to reduce the overhead of exchanging GraphicBuffers with
248 * the server. If we were to simply parcel the GraphicBuffer we would pay two overheads
249 * 1. Cost of sending the FD
250 * 2. Cost of importing the GraphicBuffer with the mapper in the receiving process.
251 * To ease this cost we implement the following scheme of caching buffers to integers,
252 * or said-otherwise, naming them with integers. This is the scheme known as slots in
253 * the legacy BufferQueue system.
254 * 1. When sending Buffers to SurfaceFlinger we look up the Buffer in the cache.
255 * 2. If there is a cache-hit we remove the Buffer from the Transaction and instead
256 * send the cached integer.
257 * 3. If there is a cache miss, we cache the new buffer and send the integer
258 * along with the Buffer, SurfaceFlinger on it's side creates a new cache
259 * entry, and we use the integer for further communication.
260 * A few details about lifetime:
261 * 1. The cache evicts by LRU. The server side cache is keyed by BufferCache::getToken
262 * which is per process Unique. The server side cache is larger than the client side
263 * cache so that the server will never evict entries before the client.
264 * 2. When the client evicts an entry it notifies the server via an uncacheBuffer
265 * transaction.
266 * 3. The client only references the Buffers by ID, and uses buffer->addDeathCallback
267 * to auto-evict destroyed buffers.
268 */
Marissa Wall73411622019-01-25 18:45:41269class BufferCache : public Singleton<BufferCache> {
270public:
271 BufferCache() : token(new BBinder()) {}
272
273 sp<IBinder> getToken() {
274 return IInterface::asBinder(TransactionCompletedListener::getIInstance());
275 }
276
Marissa Wall78b72202019-03-15 21:58:34277 status_t getCacheId(const sp<GraphicBuffer>& buffer, uint64_t* cacheId) {
Yi Kongd2639aa2019-02-28 19:58:32278 std::lock_guard<std::mutex> lock(mMutex);
Marissa Wall73411622019-01-25 18:45:41279
Marissa Wall78b72202019-03-15 21:58:34280 auto itr = mBuffers.find(buffer->getId());
Marissa Wall73411622019-01-25 18:45:41281 if (itr == mBuffers.end()) {
Marissa Wall78b72202019-03-15 21:58:34282 return BAD_VALUE;
Marissa Wall73411622019-01-25 18:45:41283 }
Marissa Wall78b72202019-03-15 21:58:34284 itr->second = getCounter();
285 *cacheId = buffer->getId();
286 return NO_ERROR;
Marissa Wall73411622019-01-25 18:45:41287 }
288
Marissa Wall78b72202019-03-15 21:58:34289 uint64_t cache(const sp<GraphicBuffer>& buffer) {
Yi Kongd2639aa2019-02-28 19:58:32290 std::lock_guard<std::mutex> lock(mMutex);
Marissa Wall73411622019-01-25 18:45:41291
Marissa Wall78b72202019-03-15 21:58:34292 if (mBuffers.size() >= BUFFER_CACHE_MAX_SIZE) {
293 evictLeastRecentlyUsedBuffer();
294 }
Marissa Wall73411622019-01-25 18:45:41295
Robert Carre06ad2b2020-04-10 22:09:33296 buffer->addDeathCallback(removeDeadBufferCallback, nullptr);
Marissa Wall78b72202019-03-15 21:58:34297
298 mBuffers[buffer->getId()] = getCounter();
299 return buffer->getId();
300 }
301
302 void uncache(uint64_t cacheId) {
303 std::lock_guard<std::mutex> lock(mMutex);
304 uncacheLocked(cacheId);
305 }
306
307 void uncacheLocked(uint64_t cacheId) REQUIRES(mMutex) {
308 mBuffers.erase(cacheId);
309 SurfaceComposerClient::doUncacheBufferTransaction(cacheId);
Marissa Wall73411622019-01-25 18:45:41310 }
311
312private:
Marissa Wall78b72202019-03-15 21:58:34313 void evictLeastRecentlyUsedBuffer() REQUIRES(mMutex) {
Marissa Wall73411622019-01-25 18:45:41314 auto itr = mBuffers.begin();
Marissa Wall78b72202019-03-15 21:58:34315 uint64_t minCounter = itr->second;
Marissa Wall73411622019-01-25 18:45:41316 auto minBuffer = itr;
317 itr++;
318
319 while (itr != mBuffers.end()) {
Marissa Wall78b72202019-03-15 21:58:34320 uint64_t counter = itr->second;
Marissa Wall73411622019-01-25 18:45:41321 if (counter < minCounter) {
322 minCounter = counter;
323 minBuffer = itr;
324 }
325 itr++;
326 }
Marissa Wall78b72202019-03-15 21:58:34327 uncacheLocked(minBuffer->first);
Marissa Wall73411622019-01-25 18:45:41328 }
329
330 uint64_t getCounter() REQUIRES(mMutex) {
331 static uint64_t counter = 0;
332 return counter++;
333 }
334
Marissa Wall73411622019-01-25 18:45:41335 std::mutex mMutex;
Marissa Wall78b72202019-03-15 21:58:34336 std::map<uint64_t /*Cache id*/, uint64_t /*counter*/> mBuffers GUARDED_BY(mMutex);
Marissa Wall73411622019-01-25 18:45:41337
338 // Used by ISurfaceComposer to identify which process is sending the cached buffer.
339 sp<IBinder> token;
340};
341
342ANDROID_SINGLETON_STATIC_INSTANCE(BufferCache);
343
Robert Carre06ad2b2020-04-10 22:09:33344void removeDeadBufferCallback(void* /*context*/, uint64_t graphicBufferId) {
Marissa Wall78b72202019-03-15 21:58:34345 // GraphicBuffer id's are used as the cache ids.
346 BufferCache::getInstance().uncache(graphicBufferId);
347}
348
Marissa Wall73411622019-01-25 18:45:41349// ---------------------------------------------------------------------------
350
Pablo Gamito7eb7ee72020-08-05 10:57:05351// Initialize transaction id counter used to generate transaction ids
352// Transactions will start counting at 1, 0 is used for invalid transactions
353std::atomic<uint32_t> SurfaceComposerClient::Transaction::idCounter = 1;
354
355SurfaceComposerClient::Transaction::Transaction() {
356 mId = generateId();
357}
358
Marissa Wall17b4e452018-12-27 00:32:34359SurfaceComposerClient::Transaction::Transaction(const Transaction& other)
Pablo Gamito7eb7ee72020-08-05 10:57:05360 : mId(other.mId),
361 mForceSynchronous(other.mForceSynchronous),
Marissa Wall17b4e452018-12-27 00:32:34362 mTransactionNestCount(other.mTransactionNestCount),
363 mAnimation(other.mAnimation),
364 mEarlyWakeup(other.mEarlyWakeup),
Ady Abrahambf1349c2020-06-12 21:26:18365 mExplicitEarlyWakeupStart(other.mExplicitEarlyWakeupStart),
366 mExplicitEarlyWakeupEnd(other.mExplicitEarlyWakeupEnd),
Vishnu Nair621102e2019-06-12 21:16:57367 mContainsBuffer(other.mContainsBuffer),
Ady Abraham22c7b5c2020-09-23 02:33:40368 mDesiredPresentTime(other.mDesiredPresentTime),
369 mFrameTimelineVsyncId(other.mFrameTimelineVsyncId) {
Robert Carr4cdc58f2017-08-23 21:22:20370 mDisplayStates = other.mDisplayStates;
371 mComposerStates = other.mComposerStates;
chaviw273171b2018-12-26 19:46:30372 mInputWindowCommands = other.mInputWindowCommands;
Vishnu Nair621102e2019-06-12 21:16:57373 mListenerCallbacks = other.mListenerCallbacks;
374}
375
376std::unique_ptr<SurfaceComposerClient::Transaction>
377SurfaceComposerClient::Transaction::createFromParcel(const Parcel* parcel) {
378 auto transaction = std::make_unique<Transaction>();
379 if (transaction->readFromParcel(parcel) == NO_ERROR) {
380 return transaction;
381 }
382 return nullptr;
383}
384
Pablo Gamito7eb7ee72020-08-05 10:57:05385int64_t SurfaceComposerClient::Transaction::generateId() {
386 return (((int64_t)getpid()) << 32) | idCounter++;
387}
388
Vishnu Nair621102e2019-06-12 21:16:57389status_t SurfaceComposerClient::Transaction::readFromParcel(const Parcel* parcel) {
390 const uint32_t forceSynchronous = parcel->readUint32();
391 const uint32_t transactionNestCount = parcel->readUint32();
392 const bool animation = parcel->readBool();
393 const bool earlyWakeup = parcel->readBool();
Ady Abrahambf1349c2020-06-12 21:26:18394 const bool explicitEarlyWakeupStart = parcel->readBool();
395 const bool explicitEarlyWakeupEnd = parcel->readBool();
Vishnu Nair621102e2019-06-12 21:16:57396 const bool containsBuffer = parcel->readBool();
397 const int64_t desiredPresentTime = parcel->readInt64();
Ady Abraham22c7b5c2020-09-23 02:33:40398 const int64_t frameTimelineVsyncId = parcel->readInt64();
Vishnu Nair621102e2019-06-12 21:16:57399
400 size_t count = static_cast<size_t>(parcel->readUint32());
401 if (count > parcel->dataSize()) {
402 return BAD_VALUE;
403 }
404 SortedVector<DisplayState> displayStates;
405 displayStates.setCapacity(count);
406 for (size_t i = 0; i < count; i++) {
407 DisplayState displayState;
408 if (displayState.read(*parcel) == BAD_VALUE) {
409 return BAD_VALUE;
410 }
411 displayStates.add(displayState);
412 }
413
414 count = static_cast<size_t>(parcel->readUint32());
415 if (count > parcel->dataSize()) {
416 return BAD_VALUE;
417 }
Valerie Hau9dab9732019-08-20 16:29:25418 std::unordered_map<sp<ITransactionCompletedListener>, CallbackInfo, TCLHash> listenerCallbacks;
419 listenerCallbacks.reserve(count);
420 for (size_t i = 0; i < count; i++) {
421 sp<ITransactionCompletedListener> listener =
422 interface_cast<ITransactionCompletedListener>(parcel->readStrongBinder());
423 size_t numCallbackIds = parcel->readUint32();
424 if (numCallbackIds > parcel->dataSize()) {
425 return BAD_VALUE;
426 }
427 for (size_t j = 0; j < numCallbackIds; j++) {
428 listenerCallbacks[listener].callbackIds.insert(parcel->readInt64());
429 }
430 size_t numSurfaces = parcel->readUint32();
431 if (numSurfaces > parcel->dataSize()) {
432 return BAD_VALUE;
433 }
434 for (size_t j = 0; j < numSurfaces; j++) {
435 sp<SurfaceControl> surface;
Pablo Gamito421dfd52020-09-22 18:11:45436 SAFE_PARCEL(SurfaceControl::readFromParcel, *parcel, &surface);
Valerie Hau9dab9732019-08-20 16:29:25437 listenerCallbacks[listener].surfaceControls.insert(surface);
438 }
439 }
440
441 count = static_cast<size_t>(parcel->readUint32());
442 if (count > parcel->dataSize()) {
443 return BAD_VALUE;
444 }
Vishnu Nairf03652d2019-07-17 00:56:56445 std::unordered_map<sp<IBinder>, ComposerState, IBinderHash> composerStates;
Vishnu Nair621102e2019-06-12 21:16:57446 composerStates.reserve(count);
447 for (size_t i = 0; i < count; i++) {
Pablo Gamitodbc31672020-09-01 18:28:58448 sp<IBinder> surfaceControlHandle;
449 SAFE_PARCEL(parcel->readStrongBinder, &surfaceControlHandle);
Vishnu Nair621102e2019-06-12 21:16:57450
451 ComposerState composerState;
452 if (composerState.read(*parcel) == BAD_VALUE) {
453 return BAD_VALUE;
454 }
Pablo Gamitodbc31672020-09-01 18:28:58455
Vishnu Nairf03652d2019-07-17 00:56:56456 composerStates[surfaceControlHandle] = composerState;
Vishnu Nair621102e2019-06-12 21:16:57457 }
458
459 InputWindowCommands inputWindowCommands;
460 inputWindowCommands.read(*parcel);
461
462 // Parsing was successful. Update the object.
463 mForceSynchronous = forceSynchronous;
464 mTransactionNestCount = transactionNestCount;
465 mAnimation = animation;
466 mEarlyWakeup = earlyWakeup;
Ady Abrahambf1349c2020-06-12 21:26:18467 mExplicitEarlyWakeupStart = explicitEarlyWakeupStart;
468 mExplicitEarlyWakeupEnd = explicitEarlyWakeupEnd;
Vishnu Nair621102e2019-06-12 21:16:57469 mContainsBuffer = containsBuffer;
470 mDesiredPresentTime = desiredPresentTime;
Ady Abraham22c7b5c2020-09-23 02:33:40471 mFrameTimelineVsyncId = frameTimelineVsyncId;
Vishnu Nair621102e2019-06-12 21:16:57472 mDisplayStates = displayStates;
Valerie Hau9dab9732019-08-20 16:29:25473 mListenerCallbacks = listenerCallbacks;
Vishnu Nair621102e2019-06-12 21:16:57474 mComposerStates = composerStates;
475 mInputWindowCommands = inputWindowCommands;
Vishnu Nair621102e2019-06-12 21:16:57476 return NO_ERROR;
477}
478
479status_t SurfaceComposerClient::Transaction::writeToParcel(Parcel* parcel) const {
Robert Carr158531d2020-04-08 17:53:30480 // If we write the Transaction to a parcel, we want to ensure the Buffers are cached
481 // before crossing the IPC boundary. Otherwise the receiving party will cache the buffers
482 // but is unlikely to use them again as they are owned by the other process.
483 // You may be asking yourself, is this const cast safe? Const cast is safe up
484 // until the point where you try and write to an object that was originally const at which
485 // point we enter undefined behavior. In this case we are safe though, because there are
486 // two possibilities:
487 // 1. The SurfaceComposerClient::Transaction was originally non-const. Safe.
488 // 2. It was originall const! In this case not only was it useless, but it by definition
489 // contains no composer states and so cacheBuffers will not perform any writes.
490
491 const_cast<SurfaceComposerClient::Transaction*>(this)->cacheBuffers();
492
Vishnu Nair621102e2019-06-12 21:16:57493 parcel->writeUint32(mForceSynchronous);
494 parcel->writeUint32(mTransactionNestCount);
495 parcel->writeBool(mAnimation);
496 parcel->writeBool(mEarlyWakeup);
Ady Abrahambf1349c2020-06-12 21:26:18497 parcel->writeBool(mExplicitEarlyWakeupStart);
498 parcel->writeBool(mExplicitEarlyWakeupEnd);
Vishnu Nair621102e2019-06-12 21:16:57499 parcel->writeBool(mContainsBuffer);
500 parcel->writeInt64(mDesiredPresentTime);
Ady Abraham22c7b5c2020-09-23 02:33:40501 parcel->writeInt64(mFrameTimelineVsyncId);
Vishnu Nair621102e2019-06-12 21:16:57502 parcel->writeUint32(static_cast<uint32_t>(mDisplayStates.size()));
503 for (auto const& displayState : mDisplayStates) {
504 displayState.write(*parcel);
505 }
506
Valerie Hau9dab9732019-08-20 16:29:25507 parcel->writeUint32(static_cast<uint32_t>(mListenerCallbacks.size()));
508 for (auto const& [listener, callbackInfo] : mListenerCallbacks) {
509 parcel->writeStrongBinder(ITransactionCompletedListener::asBinder(listener));
510 parcel->writeUint32(static_cast<uint32_t>(callbackInfo.callbackIds.size()));
511 for (auto callbackId : callbackInfo.callbackIds) {
512 parcel->writeInt64(callbackId);
513 }
514 parcel->writeUint32(static_cast<uint32_t>(callbackInfo.surfaceControls.size()));
515 for (auto surfaceControl : callbackInfo.surfaceControls) {
Pablo Gamito421dfd52020-09-22 18:11:45516 SAFE_PARCEL(surfaceControl->writeToParcel, *parcel);
Valerie Hau9dab9732019-08-20 16:29:25517 }
518 }
519
Vishnu Nair621102e2019-06-12 21:16:57520 parcel->writeUint32(static_cast<uint32_t>(mComposerStates.size()));
Pablo Gamitodbc31672020-09-01 18:28:58521 for (auto const& [handle, composerState] : mComposerStates) {
522 SAFE_PARCEL(parcel->writeStrongBinder, handle);
Vishnu Nair621102e2019-06-12 21:16:57523 composerState.write(*parcel);
524 }
525
526 mInputWindowCommands.write(*parcel);
527 return NO_ERROR;
Mathias Agopian698c0872011-06-29 02:09:31528}
529
Robert Carr2c5f6d22017-09-26 19:30:35530SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::merge(Transaction&& other) {
Pablo Gamitodbc31672020-09-01 18:28:58531 for (auto const& [handle, composerState] : other.mComposerStates) {
532 if (mComposerStates.count(handle) == 0) {
533 mComposerStates[handle] = composerState;
Robert Carr2c5f6d22017-09-26 19:30:35534 } else {
Pablo Gamitodbc31672020-09-01 18:28:58535 mComposerStates[handle].state.merge(composerState.state);
Robert Carr2c5f6d22017-09-26 19:30:35536 }
537 }
Robert Carr2c5f6d22017-09-26 19:30:35538
539 for (auto const& state : other.mDisplayStates) {
540 ssize_t index = mDisplayStates.indexOf(state);
541 if (index < 0) {
542 mDisplayStates.add(state);
543 } else {
544 mDisplayStates.editItemAt(static_cast<size_t>(index)).merge(state);
545 }
546 }
Robert Carr2c5f6d22017-09-26 19:30:35547
Marissa Wallc837b5e2018-10-12 17:04:44548 for (const auto& [listener, callbackInfo] : other.mListenerCallbacks) {
549 auto& [callbackIds, surfaceControls] = callbackInfo;
550 mListenerCallbacks[listener].callbackIds.insert(std::make_move_iterator(
551 callbackIds.begin()),
552 std::make_move_iterator(callbackIds.end()));
Valerie Hau9dab9732019-08-20 16:29:25553
Valerie Hau236eba32020-01-04 00:53:39554 mListenerCallbacks[listener].surfaceControls.insert(surfaceControls.begin(),
555 surfaceControls.end());
556
557 auto& currentProcessCallbackInfo =
558 mListenerCallbacks[TransactionCompletedListener::getIInstance()];
559 currentProcessCallbackInfo.surfaceControls
560 .insert(std::make_move_iterator(surfaceControls.begin()),
561 std::make_move_iterator(surfaceControls.end()));
562
563 // register all surface controls for all callbackIds for this listener that is merging
564 for (const auto& surfaceControl : currentProcessCallbackInfo.surfaceControls) {
565 TransactionCompletedListener::getInstance()
566 ->addSurfaceControlToCallbacks(surfaceControl,
567 currentProcessCallbackInfo.callbackIds);
568 }
Marissa Wallc837b5e2018-10-12 17:04:44569 }
Marissa Wallc837b5e2018-10-12 17:04:44570
chaviw273171b2018-12-26 19:46:30571 mInputWindowCommands.merge(other.mInputWindowCommands);
572
Robert Carrbbc85622020-04-08 17:45:12573 mContainsBuffer |= other.mContainsBuffer;
Jorim Jaggie3b57002019-07-22 15:18:52574 mEarlyWakeup = mEarlyWakeup || other.mEarlyWakeup;
Ady Abrahambf1349c2020-06-12 21:26:18575 mExplicitEarlyWakeupStart = mExplicitEarlyWakeupStart || other.mExplicitEarlyWakeupStart;
576 mExplicitEarlyWakeupEnd = mExplicitEarlyWakeupEnd || other.mExplicitEarlyWakeupEnd;
Ady Abraham22c7b5c2020-09-23 02:33:40577
578 // When merging vsync Ids we take the oldest one
579 if (mFrameTimelineVsyncId != ISurfaceComposer::INVALID_VSYNC_ID &&
580 other.mFrameTimelineVsyncId != ISurfaceComposer::INVALID_VSYNC_ID) {
581 mFrameTimelineVsyncId = std::max(mFrameTimelineVsyncId, other.mFrameTimelineVsyncId);
582 } else if (mFrameTimelineVsyncId == ISurfaceComposer::INVALID_VSYNC_ID) {
583 mFrameTimelineVsyncId = other.mFrameTimelineVsyncId;
584 }
585
Vishnu Nairfef244e2019-06-18 01:07:51586 other.clear();
Robert Carr2c5f6d22017-09-26 19:30:35587 return *this;
588}
589
Vishnu Nairfef244e2019-06-18 01:07:51590void SurfaceComposerClient::Transaction::clear() {
591 mComposerStates.clear();
592 mDisplayStates.clear();
593 mListenerCallbacks.clear();
594 mInputWindowCommands.clear();
595 mContainsBuffer = false;
596 mForceSynchronous = 0;
597 mTransactionNestCount = 0;
598 mAnimation = false;
599 mEarlyWakeup = false;
Ady Abrahambf1349c2020-06-12 21:26:18600 mExplicitEarlyWakeupStart = false;
601 mExplicitEarlyWakeupEnd = false;
Vishnu Nairfef244e2019-06-18 01:07:51602 mDesiredPresentTime = -1;
Ady Abraham22c7b5c2020-09-23 02:33:40603 mFrameTimelineVsyncId = ISurfaceComposer::INVALID_VSYNC_ID;
Vishnu Nairfef244e2019-06-18 01:07:51604}
605
Marissa Wall78b72202019-03-15 21:58:34606void SurfaceComposerClient::doUncacheBufferTransaction(uint64_t cacheId) {
607 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
608
Marissa Wall947d34e2019-03-29 21:03:53609 client_cache_t uncacheBuffer;
Marissa Wall78b72202019-03-15 21:58:34610 uncacheBuffer.token = BufferCache::getInstance().getToken();
Marissa Wall947d34e2019-03-29 21:03:53611 uncacheBuffer.id = cacheId;
Marissa Wall78b72202019-03-15 21:58:34612
Valerie Haufa889122019-04-15 20:56:05613 sp<IBinder> applyToken = IInterface::asBinder(TransactionCompletedListener::getIInstance());
Ady Abraham22c7b5c2020-09-23 02:33:40614 sf->setTransactionState(ISurfaceComposer::INVALID_VSYNC_ID, {}, {}, 0, applyToken, {}, -1,
615 uncacheBuffer, false, {}, 0 /* Undefined transactionId */);
Marissa Wall78b72202019-03-15 21:58:34616}
617
618void SurfaceComposerClient::Transaction::cacheBuffers() {
619 if (!mContainsBuffer) {
620 return;
621 }
622
623 size_t count = 0;
Vishnu Nairf03652d2019-07-17 00:56:56624 for (auto& [handle, cs] : mComposerStates) {
Pablo Gamitodbc31672020-09-01 18:28:58625 layer_state_t* s = &(mComposerStates[handle].state);
Marissa Wall78b72202019-03-15 21:58:34626 if (!(s->what & layer_state_t::eBufferChanged)) {
627 continue;
Robert Carr28037922020-04-08 17:57:07628 } else if (s->what & layer_state_t::eCachedBufferChanged) {
629 // If eBufferChanged and eCachedBufferChanged are both trued then that means
630 // we already cached the buffer in a previous call to cacheBuffers, perhaps
631 // from writeToParcel on a Transaction that was merged in to this one.
632 continue;
Marissa Wall78b72202019-03-15 21:58:34633 }
634
Marissa Wall00597242019-03-27 17:35:19635 // Don't try to cache a null buffer. Sending null buffers is cheap so we shouldn't waste
636 // time trying to cache them.
637 if (!s->buffer) {
638 continue;
639 }
640
Marissa Wall78b72202019-03-15 21:58:34641 uint64_t cacheId = 0;
642 status_t ret = BufferCache::getInstance().getCacheId(s->buffer, &cacheId);
643 if (ret == NO_ERROR) {
Robert Carre06ad2b2020-04-10 22:09:33644 // Cache-hit. Strip the buffer and send only the id.
Marissa Walla141abe2019-03-27 23:28:07645 s->what &= ~static_cast<uint64_t>(layer_state_t::eBufferChanged);
Marissa Wall78b72202019-03-15 21:58:34646 s->buffer = nullptr;
647 } else {
Robert Carre06ad2b2020-04-10 22:09:33648 // Cache-miss. Include the buffer and send the new cacheId.
Marissa Wall78b72202019-03-15 21:58:34649 cacheId = BufferCache::getInstance().cache(s->buffer);
650 }
651 s->what |= layer_state_t::eCachedBufferChanged;
652 s->cachedBuffer.token = BufferCache::getInstance().getToken();
Marissa Wall947d34e2019-03-29 21:03:53653 s->cachedBuffer.id = cacheId;
Marissa Wall78b72202019-03-15 21:58:34654
655 // If we have more buffers than the size of the cache, we should stop caching so we don't
656 // evict other buffers in this transaction
657 count++;
658 if (count >= BUFFER_CACHE_MAX_SIZE) {
659 break;
660 }
661 }
Robert Carr6fb1a7e2018-12-11 20:07:25662}
663
Robert Carr4cdc58f2017-08-23 21:22:20664status_t SurfaceComposerClient::Transaction::apply(bool synchronous) {
665 if (mStatus != NO_ERROR) {
666 return mStatus;
667 }
668
669 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
670
Valerie Hau9dab9732019-08-20 16:29:25671 bool hasListenerCallbacks = !mListenerCallbacks.empty();
Marissa Wall3dad52d2019-03-22 21:03:19672 std::vector<ListenerCallbacks> listenerCallbacks;
Marissa Wallc837b5e2018-10-12 17:04:44673 // For every listener with registered callbacks
674 for (const auto& [listener, callbackInfo] : mListenerCallbacks) {
675 auto& [callbackIds, surfaceControls] = callbackInfo;
676 if (callbackIds.empty()) {
677 continue;
678 }
679
Valerie Hau9dab9732019-08-20 16:29:25680 if (surfaceControls.empty()) {
681 listenerCallbacks.emplace_back(IInterface::asBinder(listener), std::move(callbackIds));
682 } else {
683 // If the listener has any SurfaceControls set on this Transaction update the surface
684 // state
685 for (const auto& surfaceControl : surfaceControls) {
686 layer_state_t* s = getLayerState(surfaceControl);
687 if (!s) {
688 ALOGE("failed to get layer state");
689 continue;
690 }
691 std::vector<CallbackId> callbacks(callbackIds.begin(), callbackIds.end());
692 s->what |= layer_state_t::eHasListenerCallbacksChanged;
693 s->listeners.emplace_back(IInterface::asBinder(listener), callbacks);
Marissa Wallc837b5e2018-10-12 17:04:44694 }
Marissa Wallc837b5e2018-10-12 17:04:44695 }
696 }
Valerie Hau9dab9732019-08-20 16:29:25697
Marissa Wall78b72202019-03-15 21:58:34698 cacheBuffers();
699
Robert Carr4cdc58f2017-08-23 21:22:20700 Vector<ComposerState> composerStates;
701 Vector<DisplayState> displayStates;
702 uint32_t flags = 0;
703
704 mForceSynchronous |= synchronous;
705
chaviw8e3fe5d2018-02-22 18:55:42706 for (auto const& kv : mComposerStates){
707 composerStates.add(kv.second);
708 }
709
Adithya Srinivasand3efcb32020-10-21 01:08:22710 displayStates = std::move(mDisplayStates);
Robert Carr4cdc58f2017-08-23 21:22:20711
712 if (mForceSynchronous) {
713 flags |= ISurfaceComposer::eSynchronous;
714 }
715 if (mAnimation) {
716 flags |= ISurfaceComposer::eAnimation;
717 }
Dan Stoza84d619e2018-03-29 00:07:36718 if (mEarlyWakeup) {
719 flags |= ISurfaceComposer::eEarlyWakeup;
720 }
Robert Carr4cdc58f2017-08-23 21:22:20721
Ady Abrahambf1349c2020-06-12 21:26:18722 // If both mExplicitEarlyWakeupStart and mExplicitEarlyWakeupEnd are set
723 // it is equivalent for none
724 if (mExplicitEarlyWakeupStart && !mExplicitEarlyWakeupEnd) {
725 flags |= ISurfaceComposer::eExplicitEarlyWakeupStart;
726 }
727 if (mExplicitEarlyWakeupEnd && !mExplicitEarlyWakeupStart) {
728 flags |= ISurfaceComposer::eExplicitEarlyWakeupEnd;
729 }
730
Marissa Wall713b63f2018-10-17 22:42:43731 sp<IBinder> applyToken = IInterface::asBinder(TransactionCompletedListener::getIInstance());
Ady Abraham22c7b5c2020-09-23 02:33:40732 sf->setTransactionState(mFrameTimelineVsyncId, composerStates, displayStates, flags, applyToken,
733 mInputWindowCommands, mDesiredPresentTime,
Marissa Wall3dad52d2019-03-22 21:03:19734 {} /*uncacheBuffer - only set in doUncacheBufferTransaction*/,
Adithya Srinivasand3efcb32020-10-21 01:08:22735 hasListenerCallbacks, listenerCallbacks, mId);
736 mId = generateId();
737
738 // Clear the current states and flags
739 clear();
740
Robert Carr4cdc58f2017-08-23 21:22:20741 mStatus = NO_ERROR;
742 return NO_ERROR;
Mathias Agopiane57f2922012-08-09 23:29:12743}
744
The Android Open Source Projectedbf3b62009-03-04 03:31:44745// ---------------------------------------------------------------------------
746
Robert Carr4cdc58f2017-08-23 21:22:20747sp<IBinder> SurfaceComposerClient::createDisplay(const String8& displayName, bool secure) {
Jamie Gennisdd3cb842012-10-20 01:19:11748 return ComposerService::getComposerService()->createDisplay(displayName,
749 secure);
Mathias Agopiane57f2922012-08-09 23:29:12750}
751
Robert Carr4cdc58f2017-08-23 21:22:20752void SurfaceComposerClient::destroyDisplay(const sp<IBinder>& display) {
Jesse Hall6c913be2013-08-08 19:15:49753 return ComposerService::getComposerService()->destroyDisplay(display);
754}
755
Dominik Laskowskidcb38bb2019-01-25 10:35:50756std::vector<PhysicalDisplayId> SurfaceComposerClient::getPhysicalDisplayIds() {
757 return ComposerService::getComposerService()->getPhysicalDisplayIds();
758}
759
760std::optional<PhysicalDisplayId> SurfaceComposerClient::getInternalDisplayId() {
761 return ComposerService::getComposerService()->getInternalDisplayId();
762}
763
764sp<IBinder> SurfaceComposerClient::getPhysicalDisplayToken(PhysicalDisplayId displayId) {
765 return ComposerService::getComposerService()->getPhysicalDisplayToken(displayId);
766}
767
768sp<IBinder> SurfaceComposerClient::getInternalDisplayToken() {
769 return ComposerService::getComposerService()->getInternalDisplayToken();
Jeff Brown9d4e3d22012-08-25 03:00:51770}
771
Robert Carr4cdc58f2017-08-23 21:22:20772void SurfaceComposerClient::Transaction::setAnimationTransaction() {
Jamie Gennis2d5e2302012-10-16 01:24:43773 mAnimation = true;
774}
775
Dan Stoza84d619e2018-03-29 00:07:36776void SurfaceComposerClient::Transaction::setEarlyWakeup() {
777 mEarlyWakeup = true;
778}
779
Ady Abrahambf1349c2020-06-12 21:26:18780void SurfaceComposerClient::Transaction::setExplicitEarlyWakeupStart() {
781 mExplicitEarlyWakeupStart = true;
782}
783
784void SurfaceComposerClient::Transaction::setExplicitEarlyWakeupEnd() {
785 mExplicitEarlyWakeupEnd = true;
786}
787
Pablo Gamitodbc31672020-09-01 18:28:58788layer_state_t* SurfaceComposerClient::Transaction::getLayerState(const sp<SurfaceControl>& sc) {
789 auto handle = sc->getHandle();
790
Vishnu Nairf03652d2019-07-17 00:56:56791 if (mComposerStates.count(handle) == 0) {
Mathias Agopian698c0872011-06-29 02:09:31792 // we don't have it, add an initialized layer_state to our list
chaviw8e3fe5d2018-02-22 18:55:42793 ComposerState s;
Pablo Gamitodbc31672020-09-01 18:28:58794
Vishnu Nairf03652d2019-07-17 00:56:56795 s.state.surface = handle;
Pablo Gamitodbc31672020-09-01 18:28:58796 s.state.layerId = sc->getLayerId();
797
Vishnu Nairf03652d2019-07-17 00:56:56798 mComposerStates[handle] = s;
Mathias Agopian698c0872011-06-29 02:09:31799 }
800
Vishnu Nairf03652d2019-07-17 00:56:56801 return &(mComposerStates[handle].state);
Mathias Agopian698c0872011-06-29 02:09:31802}
803
Marissa Wallc837b5e2018-10-12 17:04:44804void SurfaceComposerClient::Transaction::registerSurfaceControlForCallback(
805 const sp<SurfaceControl>& sc) {
Marissa Wall80d94ad2019-01-19 00:04:36806 auto& callbackInfo = mListenerCallbacks[TransactionCompletedListener::getIInstance()];
807 callbackInfo.surfaceControls.insert(sc);
808
809 TransactionCompletedListener::getInstance()
810 ->addSurfaceControlToCallbacks(sc, callbackInfo.callbackIds);
Marissa Wallc837b5e2018-10-12 17:04:44811}
812
Robert Carr4cdc58f2017-08-23 21:22:20813SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setPosition(
814 const sp<SurfaceControl>& sc, float x, float y) {
chaviw763ef572018-02-23 00:04:57815 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20816 if (!s) {
817 mStatus = BAD_INDEX;
818 return *this;
819 }
Mathias Agopian3165cc22012-08-09 02:42:09820 s->what |= layer_state_t::ePositionChanged;
Mathias Agopian698c0872011-06-29 02:09:31821 s->x = x;
822 s->y = y;
Marissa Wallc837b5e2018-10-12 17:04:44823
824 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20825 return *this;
Mathias Agopian698c0872011-06-29 02:09:31826}
827
Robert Carr4cdc58f2017-08-23 21:22:20828SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::show(
829 const sp<SurfaceControl>& sc) {
830 return setFlags(sc, 0, layer_state_t::eLayerHidden);
831}
832
833SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::hide(
834 const sp<SurfaceControl>& sc) {
835 return setFlags(sc, layer_state_t::eLayerHidden, layer_state_t::eLayerHidden);
836}
837
838SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setSize(
839 const sp<SurfaceControl>& sc, uint32_t w, uint32_t h) {
chaviw763ef572018-02-23 00:04:57840 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20841 if (!s) {
842 mStatus = BAD_INDEX;
843 return *this;
844 }
Mathias Agopian3165cc22012-08-09 02:42:09845 s->what |= layer_state_t::eSizeChanged;
Mathias Agopian698c0872011-06-29 02:09:31846 s->w = w;
847 s->h = h;
Jamie Gennis28378392011-10-13 00:39:00848
Marissa Wallc837b5e2018-10-12 17:04:44849 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20850 return *this;
Mathias Agopian698c0872011-06-29 02:09:31851}
852
Robert Carr4cdc58f2017-08-23 21:22:20853SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setLayer(
854 const sp<SurfaceControl>& sc, int32_t z) {
chaviw763ef572018-02-23 00:04:57855 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20856 if (!s) {
857 mStatus = BAD_INDEX;
858 return *this;
859 }
Mathias Agopian3165cc22012-08-09 02:42:09860 s->what |= layer_state_t::eLayerChanged;
chaviw32377582019-05-13 18:15:19861 s->what &= ~layer_state_t::eRelativeLayerChanged;
Mathias Agopian698c0872011-06-29 02:09:31862 s->z = z;
Marissa Wallc837b5e2018-10-12 17:04:44863
864 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20865 return *this;
Mathias Agopian698c0872011-06-29 02:09:31866}
867
Pablo Gamito11dcc222020-09-12 15:49:39868SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setRelativeLayer(
869 const sp<SurfaceControl>& sc, const sp<SurfaceControl>& relativeTo, int32_t z) {
chaviw763ef572018-02-23 00:04:57870 layer_state_t* s = getLayerState(sc);
Robert Carrdb66e622017-04-10 23:55:57871 if (!s) {
Robert Carr4cdc58f2017-08-23 21:22:20872 mStatus = BAD_INDEX;
Robert Carr30c8d902019-04-04 20:12:49873 return *this;
Robert Carrdb66e622017-04-10 23:55:57874 }
875 s->what |= layer_state_t::eRelativeLayerChanged;
chaviw32377582019-05-13 18:15:19876 s->what &= ~layer_state_t::eLayerChanged;
Pablo Gamito11dcc222020-09-12 15:49:39877 s->relativeLayerSurfaceControl = relativeTo;
Robert Carrdb66e622017-04-10 23:55:57878 s->z = z;
Marissa Wallc837b5e2018-10-12 17:04:44879
880 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20881 return *this;
Robert Carrdb66e622017-04-10 23:55:57882}
883
Robert Carr4cdc58f2017-08-23 21:22:20884SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFlags(
885 const sp<SurfaceControl>& sc, uint32_t flags,
Mathias Agopian698c0872011-06-29 02:09:31886 uint32_t mask) {
chaviw763ef572018-02-23 00:04:57887 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20888 if (!s) {
889 mStatus = BAD_INDEX;
890 return *this;
891 }
chaviwc5676c62020-09-18 22:01:04892 if ((mask & layer_state_t::eLayerOpaque) || (mask & layer_state_t::eLayerHidden) ||
893 (mask & layer_state_t::eLayerSecure) || (mask & layer_state_t::eLayerSkipScreenshot)) {
Dan Stoza23116082015-06-18 21:58:39894 s->what |= layer_state_t::eFlagsChanged;
Andy McFadden4125a4f2014-01-30 01:17:11895 }
Mathias Agopian698c0872011-06-29 02:09:31896 s->flags &= ~mask;
897 s->flags |= (flags & mask);
898 s->mask |= mask;
Marissa Wallc837b5e2018-10-12 17:04:44899
900 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20901 return *this;
Mathias Agopian698c0872011-06-29 02:09:31902}
903
Robert Carr4cdc58f2017-08-23 21:22:20904SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setTransparentRegionHint(
905 const sp<SurfaceControl>& sc,
Mathias Agopian698c0872011-06-29 02:09:31906 const Region& transparentRegion) {
chaviw763ef572018-02-23 00:04:57907 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20908 if (!s) {
909 mStatus = BAD_INDEX;
910 return *this;
911 }
Mathias Agopian3165cc22012-08-09 02:42:09912 s->what |= layer_state_t::eTransparentRegionChanged;
Mathias Agopian698c0872011-06-29 02:09:31913 s->transparentRegion = transparentRegion;
Marissa Wallc837b5e2018-10-12 17:04:44914
915 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20916 return *this;
Mathias Agopian698c0872011-06-29 02:09:31917}
918
Robert Carr4cdc58f2017-08-23 21:22:20919SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setAlpha(
920 const sp<SurfaceControl>& sc, float alpha) {
chaviw763ef572018-02-23 00:04:57921 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20922 if (!s) {
923 mStatus = BAD_INDEX;
924 return *this;
925 }
Mathias Agopian3165cc22012-08-09 02:42:09926 s->what |= layer_state_t::eAlphaChanged;
Mathias Agopian698c0872011-06-29 02:09:31927 s->alpha = alpha;
Marissa Wallc837b5e2018-10-12 17:04:44928
929 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20930 return *this;
Mathias Agopian698c0872011-06-29 02:09:31931}
932
Robert Carr4cdc58f2017-08-23 21:22:20933SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setLayerStack(
934 const sp<SurfaceControl>& sc, uint32_t layerStack) {
chaviw763ef572018-02-23 00:04:57935 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20936 if (!s) {
937 mStatus = BAD_INDEX;
938 return *this;
939 }
Mathias Agopian3165cc22012-08-09 02:42:09940 s->what |= layer_state_t::eLayerStackChanged;
Mathias Agopian87855782012-07-25 04:41:09941 s->layerStack = layerStack;
Marissa Wallc837b5e2018-10-12 17:04:44942
943 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20944 return *this;
Mathias Agopian87855782012-07-25 04:41:09945}
946
Evan Rosky1f6d6d52018-12-06 18:47:26947SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setMetadata(
Garfield Tan01a56132019-08-05 23:44:21948 const sp<SurfaceControl>& sc, uint32_t key, const Parcel& p) {
Evan Rosky1f6d6d52018-12-06 18:47:26949 layer_state_t* s = getLayerState(sc);
950 if (!s) {
951 mStatus = BAD_INDEX;
952 return *this;
953 }
954 s->what |= layer_state_t::eMetadataChanged;
Garfield Tan01a56132019-08-05 23:44:21955
956 s->metadata.mMap[key] = {p.data(), p.data() + p.dataSize()};
Evan Rosky1f6d6d52018-12-06 18:47:26957
958 registerSurfaceControlForCallback(sc);
959 return *this;
960}
961
Robert Carr4cdc58f2017-08-23 21:22:20962SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setMatrix(
963 const sp<SurfaceControl>& sc, float dsdx, float dtdx,
Robert Carrcb6e1e32017-02-22 03:48:26964 float dtdy, float dsdy) {
chaviw763ef572018-02-23 00:04:57965 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20966 if (!s) {
967 mStatus = BAD_INDEX;
968 return *this;
969 }
Mathias Agopian3165cc22012-08-09 02:42:09970 s->what |= layer_state_t::eMatrixChanged;
Mathias Agopian698c0872011-06-29 02:09:31971 layer_state_t::matrix22_t matrix;
972 matrix.dsdx = dsdx;
973 matrix.dtdx = dtdx;
974 matrix.dsdy = dsdy;
975 matrix.dtdy = dtdy;
976 s->matrix = matrix;
Marissa Wallc837b5e2018-10-12 17:04:44977
978 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20979 return *this;
Mathias Agopian698c0872011-06-29 02:09:31980}
981
Marissa Wallf58c14b2018-07-24 17:50:43982SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setCrop_legacy(
Robert Carr4cdc58f2017-08-23 21:22:20983 const sp<SurfaceControl>& sc, const Rect& crop) {
chaviw763ef572018-02-23 00:04:57984 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:20985 if (!s) {
986 mStatus = BAD_INDEX;
987 return *this;
988 }
Marissa Wallf58c14b2018-07-24 17:50:43989 s->what |= layer_state_t::eCropChanged_legacy;
990 s->crop_legacy = crop;
Marissa Wallc837b5e2018-10-12 17:04:44991
992 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:20993 return *this;
Jamie Gennisf15a83f2012-05-11 03:43:55994}
995
Lucas Dupin1b6531c2018-07-06 00:18:21996SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setCornerRadius(
997 const sp<SurfaceControl>& sc, float cornerRadius) {
998 layer_state_t* s = getLayerState(sc);
999 if (!s) {
1000 mStatus = BAD_INDEX;
1001 return *this;
1002 }
1003 s->what |= layer_state_t::eCornerRadiusChanged;
1004 s->cornerRadius = cornerRadius;
1005 return *this;
1006}
1007
Lucas Dupin19c8f0e2019-11-26 01:55:441008SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setBackgroundBlurRadius(
1009 const sp<SurfaceControl>& sc, int backgroundBlurRadius) {
1010 layer_state_t* s = getLayerState(sc);
1011 if (!s) {
1012 mStatus = BAD_INDEX;
1013 return *this;
1014 }
1015 s->what |= layer_state_t::eBackgroundBlurRadiusChanged;
1016 s->backgroundBlurRadius = backgroundBlurRadius;
1017 return *this;
1018}
1019
Marissa Wallf58c14b2018-07-24 17:50:431020SurfaceComposerClient::Transaction&
Pablo Gamito11dcc222020-09-12 15:49:391021SurfaceComposerClient::Transaction::deferTransactionUntil_legacy(
1022 const sp<SurfaceControl>& sc, const sp<SurfaceControl>& barrierSurfaceControl,
1023 uint64_t frameNumber) {
chaviw763ef572018-02-23 00:04:571024 layer_state_t* s = getLayerState(sc);
Dan Stoza7dde5992015-05-22 16:51:441025 if (!s) {
Robert Carr4cdc58f2017-08-23 21:22:201026 mStatus = BAD_INDEX;
1027 return *this;
Dan Stoza7dde5992015-05-22 16:51:441028 }
Marissa Wallf58c14b2018-07-24 17:50:431029 s->what |= layer_state_t::eDeferTransaction_legacy;
Pablo Gamito11dcc222020-09-12 15:49:391030 s->barrierSurfaceControl_legacy = barrierSurfaceControl;
Vishnu Nair6b7c5c92020-09-30 00:27:051031 s->barrierFrameNumber = frameNumber;
Marissa Wallc837b5e2018-10-12 17:04:441032
1033 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:201034 return *this;
Robert Carr0d480722017-01-11 00:42:541035}
1036
Robert Carr4cdc58f2017-08-23 21:22:201037SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::reparentChildren(
Pablo Gamito11dcc222020-09-12 15:49:391038 const sp<SurfaceControl>& sc, const sp<SurfaceControl>& newParent) {
chaviw763ef572018-02-23 00:04:571039 layer_state_t* s = getLayerState(sc);
Robert Carr1db73f62016-12-21 20:58:511040 if (!s) {
Robert Carr4cdc58f2017-08-23 21:22:201041 mStatus = BAD_INDEX;
1042 return *this;
Robert Carr1db73f62016-12-21 20:58:511043 }
1044 s->what |= layer_state_t::eReparentChildren;
Pablo Gamito11dcc222020-09-12 15:49:391045 s->reparentSurfaceControl = newParent;
Marissa Wallc837b5e2018-10-12 17:04:441046
1047 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:201048 return *this;
Robert Carr1db73f62016-12-21 20:58:511049}
1050
Robert Carr4cdc58f2017-08-23 21:22:201051SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::reparent(
Pablo Gamito11dcc222020-09-12 15:49:391052 const sp<SurfaceControl>& sc, const sp<SurfaceControl>& newParent) {
chaviw763ef572018-02-23 00:04:571053 layer_state_t* s = getLayerState(sc);
chaviw06178942017-07-27 17:25:591054 if (!s) {
Robert Carr4cdc58f2017-08-23 21:22:201055 mStatus = BAD_INDEX;
1056 return *this;
chaviw06178942017-07-27 17:25:591057 }
chaviwf1961f72017-09-18 23:41:071058 s->what |= layer_state_t::eReparent;
Pablo Gamito11dcc222020-09-12 15:49:391059 s->parentSurfaceControlForChild = newParent;
Marissa Wallc837b5e2018-10-12 17:04:441060
1061 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:201062 return *this;
chaviw06178942017-07-27 17:25:591063}
1064
Robert Carr4cdc58f2017-08-23 21:22:201065SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setColor(
1066 const sp<SurfaceControl>& sc,
1067 const half3& color) {
chaviw763ef572018-02-23 00:04:571068 layer_state_t* s = getLayerState(sc);
Robert Carr9524cb32017-02-13 19:32:321069 if (!s) {
Robert Carr4cdc58f2017-08-23 21:22:201070 mStatus = BAD_INDEX;
1071 return *this;
1072 }
1073 s->what |= layer_state_t::eColorChanged;
1074 s->color = color;
Marissa Wallc837b5e2018-10-12 17:04:441075
1076 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:201077 return *this;
1078}
1079
Valerie Haudd0b7572019-01-29 22:59:271080SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setBackgroundColor(
1081 const sp<SurfaceControl>& sc, const half3& color, float alpha, ui::Dataspace dataspace) {
Valerie Haued54efa2019-01-12 04:03:141082 layer_state_t* s = getLayerState(sc);
1083 if (!s) {
1084 mStatus = BAD_INDEX;
1085 return *this;
1086 }
1087
Valerie Haudd0b7572019-01-29 22:59:271088 s->what |= layer_state_t::eBackgroundColorChanged;
1089 s->color = color;
1090 s->bgColorAlpha = alpha;
1091 s->bgColorDataspace = dataspace;
Valerie Haued54efa2019-01-12 04:03:141092
1093 registerSurfaceControlForCallback(sc);
1094 return *this;
1095}
1096
Marissa Wall61c58622018-07-18 17:12:201097SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setTransform(
1098 const sp<SurfaceControl>& sc, uint32_t transform) {
1099 layer_state_t* s = getLayerState(sc);
1100 if (!s) {
1101 mStatus = BAD_INDEX;
1102 return *this;
1103 }
1104 s->what |= layer_state_t::eTransformChanged;
1105 s->transform = transform;
Marissa Wallc837b5e2018-10-12 17:04:441106
1107 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 17:12:201108 return *this;
1109}
1110
1111SurfaceComposerClient::Transaction&
1112SurfaceComposerClient::Transaction::setTransformToDisplayInverse(const sp<SurfaceControl>& sc,
1113 bool transformToDisplayInverse) {
1114 layer_state_t* s = getLayerState(sc);
1115 if (!s) {
1116 mStatus = BAD_INDEX;
1117 return *this;
1118 }
1119 s->what |= layer_state_t::eTransformToDisplayInverseChanged;
1120 s->transformToDisplayInverse = transformToDisplayInverse;
Marissa Wallc837b5e2018-10-12 17:04:441121
1122 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 17:12:201123 return *this;
1124}
1125
1126SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setCrop(
1127 const sp<SurfaceControl>& sc, const Rect& crop) {
1128 layer_state_t* s = getLayerState(sc);
1129 if (!s) {
1130 mStatus = BAD_INDEX;
1131 return *this;
1132 }
1133 s->what |= layer_state_t::eCropChanged;
1134 s->crop = crop;
Marissa Wallc837b5e2018-10-12 17:04:441135
1136 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 17:12:201137 return *this;
1138}
1139
Marissa Wall861616d2018-10-22 19:52:231140SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrame(
1141 const sp<SurfaceControl>& sc, const Rect& frame) {
1142 layer_state_t* s = getLayerState(sc);
1143 if (!s) {
1144 mStatus = BAD_INDEX;
1145 return *this;
1146 }
1147 s->what |= layer_state_t::eFrameChanged;
Marin Shalamanov6ad317c2020-07-29 21:34:071148 s->orientedDisplaySpaceRect = frame;
Marissa Wall861616d2018-10-22 19:52:231149
1150 registerSurfaceControlForCallback(sc);
1151 return *this;
1152}
1153
Marissa Wall61c58622018-07-18 17:12:201154SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setBuffer(
1155 const sp<SurfaceControl>& sc, const sp<GraphicBuffer>& buffer) {
1156 layer_state_t* s = getLayerState(sc);
1157 if (!s) {
1158 mStatus = BAD_INDEX;
1159 return *this;
1160 }
Marissa Wall78b72202019-03-15 21:58:341161 s->what |= layer_state_t::eBufferChanged;
1162 s->buffer = buffer;
Marissa Wallebc2c052019-01-17 03:16:551163
1164 registerSurfaceControlForCallback(sc);
Marissa Wall78b72202019-03-15 21:58:341165
1166 mContainsBuffer = true;
Marissa Wallebc2c052019-01-17 03:16:551167 return *this;
1168}
1169
Marissa Wall61c58622018-07-18 17:12:201170SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setAcquireFence(
1171 const sp<SurfaceControl>& sc, const sp<Fence>& fence) {
1172 layer_state_t* s = getLayerState(sc);
1173 if (!s) {
1174 mStatus = BAD_INDEX;
1175 return *this;
1176 }
1177 s->what |= layer_state_t::eAcquireFenceChanged;
1178 s->acquireFence = fence;
Marissa Wallc837b5e2018-10-12 17:04:441179
1180 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 17:12:201181 return *this;
1182}
1183
1184SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setDataspace(
1185 const sp<SurfaceControl>& sc, ui::Dataspace dataspace) {
1186 layer_state_t* s = getLayerState(sc);
1187 if (!s) {
1188 mStatus = BAD_INDEX;
1189 return *this;
1190 }
1191 s->what |= layer_state_t::eDataspaceChanged;
1192 s->dataspace = dataspace;
Marissa Wallc837b5e2018-10-12 17:04:441193
1194 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 17:12:201195 return *this;
1196}
1197
1198SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setHdrMetadata(
1199 const sp<SurfaceControl>& sc, const HdrMetadata& hdrMetadata) {
1200 layer_state_t* s = getLayerState(sc);
1201 if (!s) {
1202 mStatus = BAD_INDEX;
1203 return *this;
1204 }
1205 s->what |= layer_state_t::eHdrMetadataChanged;
1206 s->hdrMetadata = hdrMetadata;
Marissa Wallc837b5e2018-10-12 17:04:441207
1208 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 17:12:201209 return *this;
1210}
1211
1212SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setSurfaceDamageRegion(
1213 const sp<SurfaceControl>& sc, const Region& surfaceDamageRegion) {
1214 layer_state_t* s = getLayerState(sc);
1215 if (!s) {
1216 mStatus = BAD_INDEX;
1217 return *this;
1218 }
1219 s->what |= layer_state_t::eSurfaceDamageRegionChanged;
1220 s->surfaceDamageRegion = surfaceDamageRegion;
Marissa Wallc837b5e2018-10-12 17:04:441221
1222 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 17:12:201223 return *this;
1224}
1225
1226SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setApi(
1227 const sp<SurfaceControl>& sc, int32_t api) {
1228 layer_state_t* s = getLayerState(sc);
1229 if (!s) {
1230 mStatus = BAD_INDEX;
1231 return *this;
1232 }
1233 s->what |= layer_state_t::eApiChanged;
1234 s->api = api;
Marissa Wallc837b5e2018-10-12 17:04:441235
1236 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 17:12:201237 return *this;
1238}
1239
1240SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setSidebandStream(
1241 const sp<SurfaceControl>& sc, const sp<NativeHandle>& sidebandStream) {
1242 layer_state_t* s = getLayerState(sc);
1243 if (!s) {
1244 mStatus = BAD_INDEX;
1245 return *this;
1246 }
1247 s->what |= layer_state_t::eSidebandStreamChanged;
1248 s->sidebandStream = sidebandStream;
Marissa Wallc837b5e2018-10-12 17:04:441249
1250 registerSurfaceControlForCallback(sc);
1251 return *this;
1252}
1253
Marissa Wall17b4e452018-12-27 00:32:341254SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setDesiredPresentTime(
1255 nsecs_t desiredPresentTime) {
1256 mDesiredPresentTime = desiredPresentTime;
1257 return *this;
1258}
1259
Peiyong Linc502cb72019-03-01 23:00:231260SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setColorSpaceAgnostic(
1261 const sp<SurfaceControl>& sc, const bool agnostic) {
1262 layer_state_t* s = getLayerState(sc);
1263 if (!s) {
1264 mStatus = BAD_INDEX;
1265 return *this;
1266 }
1267 s->what |= layer_state_t::eColorSpaceAgnosticChanged;
1268 s->colorSpaceAgnostic = agnostic;
1269
1270 registerSurfaceControlForCallback(sc);
1271 return *this;
1272}
1273
Marissa Wallc837b5e2018-10-12 17:04:441274SurfaceComposerClient::Transaction&
Ana Krulecc84d09b2019-11-02 22:10:291275SurfaceComposerClient::Transaction::setFrameRateSelectionPriority(const sp<SurfaceControl>& sc,
1276 int32_t priority) {
1277 layer_state_t* s = getLayerState(sc);
1278 if (!s) {
1279 mStatus = BAD_INDEX;
1280 return *this;
1281 }
1282
1283 s->what |= layer_state_t::eFrameRateSelectionPriority;
1284 s->frameRateSelectionPriority = priority;
1285
1286 registerSurfaceControlForCallback(sc);
1287 return *this;
1288}
1289
1290SurfaceComposerClient::Transaction&
Marissa Wallc837b5e2018-10-12 17:04:441291SurfaceComposerClient::Transaction::addTransactionCompletedCallback(
Marissa Walle2ffb422018-10-12 18:33:521292 TransactionCompletedCallbackTakesContext callback, void* callbackContext) {
Marissa Wallc837b5e2018-10-12 17:04:441293 auto listener = TransactionCompletedListener::getInstance();
1294
Marissa Wall80d94ad2019-01-19 00:04:361295 auto callbackWithContext = std::bind(callback, callbackContext, std::placeholders::_1,
1296 std::placeholders::_2, std::placeholders::_3);
1297 const auto& surfaceControls =
1298 mListenerCallbacks[TransactionCompletedListener::getIInstance()].surfaceControls;
Marissa Wallc837b5e2018-10-12 17:04:441299
Marissa Wall80d94ad2019-01-19 00:04:361300 CallbackId callbackId = listener->addCallbackFunction(callbackWithContext, surfaceControls);
Marissa Wallc837b5e2018-10-12 17:04:441301
1302 mListenerCallbacks[TransactionCompletedListener::getIInstance()].callbackIds.emplace(
1303 callbackId);
Marissa Wall61c58622018-07-18 17:12:201304 return *this;
1305}
1306
Valerie Hau871d6352020-01-29 16:44:021307SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::notifyProducerDisconnect(
1308 const sp<SurfaceControl>& sc) {
1309 layer_state_t* s = getLayerState(sc);
1310 if (!s) {
1311 mStatus = BAD_INDEX;
1312 return *this;
1313 }
1314
1315 s->what |= layer_state_t::eProducerDisconnect;
1316 return *this;
1317}
1318
Vishnu Nair6b7c5c92020-09-30 00:27:051319SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrameNumber(
1320 const sp<SurfaceControl>& sc, uint64_t frameNumber) {
1321 layer_state_t* s = getLayerState(sc);
1322 if (!s) {
1323 mStatus = BAD_INDEX;
1324 return *this;
1325 }
1326
1327 s->what |= layer_state_t::eFrameNumberChanged;
1328 s->frameNumber = frameNumber;
1329
1330 return *this;
1331}
1332
Robert Carr4cdc58f2017-08-23 21:22:201333SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::detachChildren(
1334 const sp<SurfaceControl>& sc) {
chaviw763ef572018-02-23 00:04:571335 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 21:22:201336 if (!s) {
1337 mStatus = BAD_INDEX;
Greg Kaiserd45fdc32019-04-30 13:14:191338 return *this;
Robert Carr9524cb32017-02-13 19:32:321339 }
1340 s->what |= layer_state_t::eDetachChildren;
Marissa Wallc837b5e2018-10-12 17:04:441341
1342 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 21:22:201343 return *this;
Robert Carr9524cb32017-02-13 19:32:321344}
1345
Robert Carr2c358bf2018-08-08 22:58:151346#ifndef NO_INPUT
1347SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setInputWindowInfo(
1348 const sp<SurfaceControl>& sc,
1349 const InputWindowInfo& info) {
1350 layer_state_t* s = getLayerState(sc);
1351 if (!s) {
1352 mStatus = BAD_INDEX;
1353 return *this;
1354 }
Chris Ye0783e992020-06-03 04:34:491355 s->inputHandle = new InputWindowHandle(info);
Robert Carr2c358bf2018-08-08 22:58:151356 s->what |= layer_state_t::eInputInfoChanged;
1357 return *this;
1358}
chaviw273171b2018-12-26 19:46:301359
Vishnu Naire798b472020-07-23 20:52:211360SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFocusedWindow(
Vishnu Nair958da932020-08-22 00:12:371361 const sp<IBinder>& token, const sp<IBinder>& focusedToken, nsecs_t timestampNanos,
1362 int32_t displayId) {
Vishnu Naire798b472020-07-23 20:52:211363 FocusRequest request;
1364 request.token = token;
1365 request.focusedToken = focusedToken;
1366 request.timestamp = timestampNanos;
Vishnu Nair958da932020-08-22 00:12:371367 request.displayId = displayId;
Vishnu Naire798b472020-07-23 20:52:211368 return setFocusedWindow(request);
1369}
1370
1371SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFocusedWindow(
1372 const FocusRequest& request) {
1373 mInputWindowCommands.focusRequests.push_back(request);
1374 return *this;
1375}
1376
chaviwa911b102019-02-14 18:18:331377SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::syncInputWindows() {
1378 mInputWindowCommands.syncInputWindows = true;
1379 return *this;
1380}
1381
Robert Carr2c358bf2018-08-08 22:58:151382#endif
1383
Peiyong Lind3788632018-09-18 23:01:311384SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setColorTransform(
1385 const sp<SurfaceControl>& sc, const mat3& matrix, const vec3& translation) {
1386 layer_state_t* s = getLayerState(sc);
1387 if (!s) {
1388 mStatus = BAD_INDEX;
1389 return *this;
1390 }
1391 s->what |= layer_state_t::eColorTransformChanged;
1392 s->colorTransform = mat4(matrix, translation);
Marissa Wallc837b5e2018-10-12 17:04:441393
1394 registerSurfaceControlForCallback(sc);
Peiyong Lind3788632018-09-18 23:01:311395 return *this;
1396}
1397
Robert Carrfb4d58b2019-01-15 17:21:271398SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setGeometry(
1399 const sp<SurfaceControl>& sc, const Rect& source, const Rect& dst, int transform) {
1400 setCrop_legacy(sc, source);
1401
1402 int x = dst.left;
1403 int y = dst.top;
Robert Carr66365e42019-04-08 23:58:041404
1405 float sourceWidth = source.getWidth();
1406 float sourceHeight = source.getHeight();
1407
1408 float xScale = sourceWidth < 0 ? 1.0f : dst.getWidth() / sourceWidth;
1409 float yScale = sourceHeight < 0 ? 1.0f : dst.getHeight() / sourceHeight;
Robert Carrfb4d58b2019-01-15 17:21:271410 float matrix[4] = {1, 0, 0, 1};
1411
1412 switch (transform) {
1413 case NATIVE_WINDOW_TRANSFORM_FLIP_H:
1414 matrix[0] = -xScale; matrix[1] = 0;
1415 matrix[2] = 0; matrix[3] = yScale;
1416 x += source.getWidth();
1417 break;
1418 case NATIVE_WINDOW_TRANSFORM_FLIP_V:
1419 matrix[0] = xScale; matrix[1] = 0;
1420 matrix[2] = 0; matrix[3] = -yScale;
1421 y += source.getHeight();
1422 break;
1423 case NATIVE_WINDOW_TRANSFORM_ROT_90:
1424 matrix[0] = 0; matrix[1] = -yScale;
1425 matrix[2] = xScale; matrix[3] = 0;
1426 x += source.getHeight();
1427 break;
1428 case NATIVE_WINDOW_TRANSFORM_ROT_180:
1429 matrix[0] = -xScale; matrix[1] = 0;
1430 matrix[2] = 0; matrix[3] = -yScale;
1431 x += source.getWidth();
1432 y += source.getHeight();
1433 break;
1434 case NATIVE_WINDOW_TRANSFORM_ROT_270:
1435 matrix[0] = 0; matrix[1] = yScale;
1436 matrix[2] = -xScale; matrix[3] = 0;
1437 y += source.getWidth();
1438 break;
1439 default:
1440 matrix[0] = xScale; matrix[1] = 0;
1441 matrix[2] = 0; matrix[3] = yScale;
1442 break;
1443 }
1444 setMatrix(sc, matrix[0], matrix[1], matrix[2], matrix[3]);
chaviw76f5f2f2019-09-23 17:15:511445 float offsetX = xScale * source.left;
1446 float offsetY = yScale * source.top;
1447 setPosition(sc, x - offsetX, y - offsetY);
Robert Carrfb4d58b2019-01-15 17:21:271448
1449 return *this;
1450}
1451
Vishnu Nairc97b8db2019-10-30 01:19:351452SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setShadowRadius(
1453 const sp<SurfaceControl>& sc, float shadowRadius) {
1454 layer_state_t* s = getLayerState(sc);
1455 if (!s) {
1456 mStatus = BAD_INDEX;
1457 return *this;
1458 }
1459 s->what |= layer_state_t::eShadowRadiusChanged;
1460 s->shadowRadius = shadowRadius;
1461 return *this;
1462}
1463
Steven Thomas3172e202020-01-07 03:25:301464SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrameRate(
Steven Thomas62a4cf82020-01-31 20:04:031465 const sp<SurfaceControl>& sc, float frameRate, int8_t compatibility) {
Steven Thomas3172e202020-01-07 03:25:301466 layer_state_t* s = getLayerState(sc);
1467 if (!s) {
1468 mStatus = BAD_INDEX;
1469 return *this;
1470 }
Steven Thomas62a4cf82020-01-31 20:04:031471 if (!ValidateFrameRate(frameRate, compatibility, "Transaction::setFrameRate")) {
1472 mStatus = BAD_VALUE;
1473 return *this;
1474 }
Steven Thomas3172e202020-01-07 03:25:301475 s->what |= layer_state_t::eFrameRateChanged;
1476 s->frameRate = frameRate;
Steven Thomas62a4cf82020-01-31 20:04:031477 s->frameRateCompatibility = compatibility;
Steven Thomas3172e202020-01-07 03:25:301478 return *this;
1479}
1480
Vishnu Nair6213bd92020-05-09 00:42:251481SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFixedTransformHint(
1482 const sp<SurfaceControl>& sc, int32_t fixedTransformHint) {
1483 layer_state_t* s = getLayerState(sc);
1484 if (!s) {
1485 mStatus = BAD_INDEX;
1486 return *this;
1487 }
1488
1489 const ui::Transform::RotationFlags transform = fixedTransformHint == -1
1490 ? ui::Transform::ROT_INVALID
1491 : ui::Transform::toRotationFlags(static_cast<ui::Rotation>(fixedTransformHint));
1492 s->what |= layer_state_t::eFixedTransformHintChanged;
1493 s->fixedTransformHint = transform;
1494 return *this;
1495}
1496
Ady Abraham22c7b5c2020-09-23 02:33:401497SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrameTimelineVsync(
1498 int64_t frameTimelineVsyncId) {
1499 mFrameTimelineVsyncId = frameTimelineVsyncId;
1500 return *this;
1501}
1502
Robert Carr9b611b72020-10-19 19:00:231503SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrameTimelineVsync(
1504 const sp<SurfaceControl>& sc, int64_t frameTimelineVsyncId) {
1505 layer_state_t* s = getLayerState(sc);
1506 if (!s) {
1507 mStatus = BAD_INDEX;
1508 return *this;
1509 }
1510
1511 s->what |= layer_state_t::eFrameTimelineVsyncChanged;
1512 s->frameTimelineVsyncId = frameTimelineVsyncId;
1513 return *this;
1514}
1515
Mathias Agopian698c0872011-06-29 02:09:311516// ---------------------------------------------------------------------------
1517
chaviw763ef572018-02-23 00:04:571518DisplayState& SurfaceComposerClient::Transaction::getDisplayState(const sp<IBinder>& token) {
Mathias Agopiane57f2922012-08-09 23:29:121519 DisplayState s;
1520 s.token = token;
1521 ssize_t index = mDisplayStates.indexOf(s);
1522 if (index < 0) {
1523 // we don't have it, add an initialized layer_state to our list
1524 s.what = 0;
1525 index = mDisplayStates.add(s);
1526 }
Dan Stozad723bd72014-11-18 18:24:031527 return mDisplayStates.editItemAt(static_cast<size_t>(index));
Mathias Agopiane57f2922012-08-09 23:29:121528}
1529
Robert Carr4cdc58f2017-08-23 21:22:201530status_t SurfaceComposerClient::Transaction::setDisplaySurface(const sp<IBinder>& token,
1531 const sp<IGraphicBufferProducer>& bufferProducer) {
Pablo Ceballoseddbef82016-09-01 18:21:211532 if (bufferProducer.get() != nullptr) {
1533 // Make sure that composition can never be stalled by a virtual display
1534 // consumer that isn't processing buffers fast enough.
1535 status_t err = bufferProducer->setAsyncMode(true);
1536 if (err != NO_ERROR) {
1537 ALOGE("Composer::setDisplaySurface Failed to enable async mode on the "
1538 "BufferQueue. This BufferQueue cannot be used for virtual "
1539 "display. (%d)", err);
1540 return err;
1541 }
Pablo Ceballos1aad24c2016-08-04 17:24:221542 }
chaviw763ef572018-02-23 00:04:571543 DisplayState& s(getDisplayState(token));
Andy McFadden2adaf042012-12-18 17:49:451544 s.surface = bufferProducer;
Mathias Agopiane57f2922012-08-09 23:29:121545 s.what |= DisplayState::eSurfaceChanged;
Pablo Ceballos1aad24c2016-08-04 17:24:221546 return NO_ERROR;
Mathias Agopiane57f2922012-08-09 23:29:121547}
1548
Robert Carr4cdc58f2017-08-23 21:22:201549void SurfaceComposerClient::Transaction::setDisplayLayerStack(const sp<IBinder>& token,
Mathias Agopiane57f2922012-08-09 23:29:121550 uint32_t layerStack) {
chaviw763ef572018-02-23 00:04:571551 DisplayState& s(getDisplayState(token));
Mathias Agopiane57f2922012-08-09 23:29:121552 s.layerStack = layerStack;
1553 s.what |= DisplayState::eLayerStackChanged;
1554}
1555
Robert Carr4cdc58f2017-08-23 21:22:201556void SurfaceComposerClient::Transaction::setDisplayProjection(const sp<IBinder>& token,
Dominik Laskowski718f9602019-11-10 04:01:351557 ui::Rotation orientation,
1558 const Rect& layerStackRect,
1559 const Rect& displayRect) {
chaviw763ef572018-02-23 00:04:571560 DisplayState& s(getDisplayState(token));
Mathias Agopiane57f2922012-08-09 23:29:121561 s.orientation = orientation;
Marin Shalamanov6ad317c2020-07-29 21:34:071562 s.layerStackSpaceRect = layerStackRect;
1563 s.orientedDisplaySpaceRect = displayRect;
Mathias Agopian00e8c7a2012-09-05 02:30:461564 s.what |= DisplayState::eDisplayProjectionChanged;
Jorim Jaggi092123c2016-04-13 01:40:351565 mForceSynchronous = true; // TODO: do we actually still need this?
Mathias Agopiane57f2922012-08-09 23:29:121566}
1567
Robert Carr4cdc58f2017-08-23 21:22:201568void SurfaceComposerClient::Transaction::setDisplaySize(const sp<IBinder>& token, uint32_t width, uint32_t height) {
chaviw763ef572018-02-23 00:04:571569 DisplayState& s(getDisplayState(token));
Michael Wright1f6078a2014-06-26 23:01:021570 s.width = width;
1571 s.height = height;
1572 s.what |= DisplayState::eDisplaySizeChanged;
1573}
1574
Mathias Agopiane57f2922012-08-09 23:29:121575// ---------------------------------------------------------------------------
1576
The Android Open Source Projectedbf3b62009-03-04 03:31:441577SurfaceComposerClient::SurfaceComposerClient()
Robert Carr4cdc58f2017-08-23 21:22:201578 : mStatus(NO_INIT)
The Android Open Source Projectedbf3b62009-03-04 03:31:441579{
The Android Open Source Projectedbf3b62009-03-04 03:31:441580}
1581
Jorim Jaggif3cf4bc2017-11-30 13:19:231582SurfaceComposerClient::SurfaceComposerClient(const sp<ISurfaceComposerClient>& client)
1583 : mStatus(NO_ERROR), mClient(client)
1584{
1585}
1586
Mathias Agopian698c0872011-06-29 02:09:311587void SurfaceComposerClient::onFirstRef() {
Robert Carr4cdc58f2017-08-23 21:22:201588 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
Yi Kong48a619f2018-06-05 23:34:591589 if (sf != nullptr && mStatus == NO_INIT) {
Robert Carr1db73f62016-12-21 20:58:511590 sp<ISurfaceComposerClient> conn;
Robert Carrb89ea9d2018-12-10 21:01:141591 conn = sf->createConnection();
Yi Kong48a619f2018-06-05 23:34:591592 if (conn != nullptr) {
Mathias Agopiand4784a32010-05-28 02:41:151593 mClient = conn;
Mathias Agopiand4784a32010-05-28 02:41:151594 mStatus = NO_ERROR;
1595 }
1596 }
The Android Open Source Projectedbf3b62009-03-04 03:31:441597}
1598
Mathias Agopian698c0872011-06-29 02:09:311599SurfaceComposerClient::~SurfaceComposerClient() {
Mathias Agopian631f3582010-05-26 00:51:341600 dispose();
1601}
Mathias Agopiandd3423c2009-09-23 22:44:051602
Mathias Agopian698c0872011-06-29 02:09:311603status_t SurfaceComposerClient::initCheck() const {
The Android Open Source Projectedbf3b62009-03-04 03:31:441604 return mStatus;
1605}
1606
Mathias Agopian698c0872011-06-29 02:09:311607sp<IBinder> SurfaceComposerClient::connection() const {
Marco Nelissen2ea926b2014-11-14 16:01:011608 return IInterface::asBinder(mClient);
The Android Open Source Projectedbf3b62009-03-04 03:31:441609}
1610
Mathias Agopiand4784a32010-05-28 02:41:151611status_t SurfaceComposerClient::linkToComposerDeath(
1612 const sp<IBinder::DeathRecipient>& recipient,
Mathias Agopian698c0872011-06-29 02:09:311613 void* cookie, uint32_t flags) {
Robert Carr4cdc58f2017-08-23 21:22:201614 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
1615 return IInterface::asBinder(sf)->linkToDeath(recipient, cookie, flags);
The Android Open Source Projectedbf3b62009-03-04 03:31:441616}
1617
Mathias Agopian698c0872011-06-29 02:09:311618void SurfaceComposerClient::dispose() {
The Android Open Source Projectedbf3b62009-03-04 03:31:441619 // this can be called more than once.
Mathias Agopian7e27f052010-05-28 21:22:231620 sp<ISurfaceComposerClient> client;
Mathias Agopiand4784a32010-05-28 02:41:151621 Mutex::Autolock _lm(mLock);
Yi Kong48a619f2018-06-05 23:34:591622 if (mClient != nullptr) {
Mathias Agopiand4784a32010-05-28 02:41:151623 client = mClient; // hold ref while lock is held
1624 mClient.clear();
The Android Open Source Projectedbf3b62009-03-04 03:31:441625 }
Mathias Agopiand4784a32010-05-28 02:41:151626 mStatus = NO_INIT;
The Android Open Source Projectedbf3b62009-03-04 03:31:441627}
1628
Evan Rosky1f6d6d52018-12-06 18:47:261629sp<SurfaceControl> SurfaceComposerClient::createSurface(const String8& name, uint32_t w, uint32_t h,
1630 PixelFormat format, uint32_t flags,
Vishnu Nair992496b2020-10-23 00:27:211631 const sp<IBinder>& parentHandle,
Valerie Hau1acd6962019-10-28 23:35:481632 LayerMetadata metadata,
1633 uint32_t* outTransformHint) {
Robert Carr3b382ed2018-03-14 20:49:411634 sp<SurfaceControl> s;
Vishnu Nair992496b2020-10-23 00:27:211635 createSurfaceChecked(name, w, h, format, &s, flags, parentHandle, std::move(metadata),
Valerie Hau1acd6962019-10-28 23:35:481636 outTransformHint);
Robert Carr3b382ed2018-03-14 20:49:411637 return s;
1638}
1639
Marissa Wall35187b32019-01-08 18:08:521640sp<SurfaceControl> SurfaceComposerClient::createWithSurfaceParent(const String8& name, uint32_t w,
1641 uint32_t h, PixelFormat format,
1642 uint32_t flags, Surface* parent,
Valerie Hau1acd6962019-10-28 23:35:481643 LayerMetadata metadata,
1644 uint32_t* outTransformHint) {
Marissa Wall35187b32019-01-08 18:08:521645 sp<SurfaceControl> sur;
1646 status_t err = mStatus;
1647
1648 if (mStatus == NO_ERROR) {
1649 sp<IBinder> handle;
1650 sp<IGraphicBufferProducer> parentGbp = parent->getIGraphicBufferProducer();
1651 sp<IGraphicBufferProducer> gbp;
1652
Valerie Hau1acd6962019-10-28 23:35:481653 uint32_t transformHint = 0;
Pablo Gamito2ec1f7b2020-09-01 14:18:491654 int32_t id = -1;
Evan Rosky1f6d6d52018-12-06 18:47:261655 err = mClient->createWithSurfaceParent(name, w, h, format, flags, parentGbp,
Pablo Gamito2ec1f7b2020-09-01 14:18:491656 std::move(metadata), &handle, &gbp, &id,
1657 &transformHint);
Valerie Hau1acd6962019-10-28 23:35:481658 if (outTransformHint) {
1659 *outTransformHint = transformHint;
1660 }
Marissa Wall35187b32019-01-08 18:08:521661 ALOGE_IF(err, "SurfaceComposerClient::createWithSurfaceParent error %s", strerror(-err));
1662 if (err == NO_ERROR) {
Pablo Gamitodbc31672020-09-01 18:28:581663 return new SurfaceControl(this, handle, gbp, id, transformHint);
Marissa Wall35187b32019-01-08 18:08:521664 }
1665 }
1666 return nullptr;
1667}
1668
Evan Rosky1f6d6d52018-12-06 18:47:261669status_t SurfaceComposerClient::createSurfaceChecked(const String8& name, uint32_t w, uint32_t h,
1670 PixelFormat format,
1671 sp<SurfaceControl>* outSurface, uint32_t flags,
Vishnu Nair992496b2020-10-23 00:27:211672 const sp<IBinder>& parentHandle,
1673 LayerMetadata metadata,
Valerie Hau1acd6962019-10-28 23:35:481674 uint32_t* outTransformHint) {
Mathias Agopian4d9b8222013-03-13 00:11:481675 sp<SurfaceControl> sur;
Robert Carr740eaf02018-03-27 19:59:181676 status_t err = mStatus;
Robert Carr3b382ed2018-03-14 20:49:411677
Mathias Agopian698c0872011-06-29 02:09:311678 if (mStatus == NO_ERROR) {
Mathias Agopian4d9b8222013-03-13 00:11:481679 sp<IBinder> handle;
1680 sp<IGraphicBufferProducer> gbp;
Robert Carr1f0a16a2016-10-24 23:27:391681
Valerie Hau1acd6962019-10-28 23:35:481682 uint32_t transformHint = 0;
Pablo Gamito2ec1f7b2020-09-01 14:18:491683 int32_t id = -1;
Evan Rosky1f6d6d52018-12-06 18:47:261684 err = mClient->createSurface(name, w, h, format, flags, parentHandle, std::move(metadata),
Pablo Gamito2ec1f7b2020-09-01 14:18:491685 &handle, &gbp, &id, &transformHint);
1686
Valerie Hau1acd6962019-10-28 23:35:481687 if (outTransformHint) {
1688 *outTransformHint = transformHint;
1689 }
Mathias Agopian4d9b8222013-03-13 00:11:481690 ALOGE_IF(err, "SurfaceComposerClient::createSurface error %s", strerror(-err));
1691 if (err == NO_ERROR) {
Pablo Gamitodbc31672020-09-01 18:28:581692 *outSurface = new SurfaceControl(this, handle, gbp, id, transformHint);
Mathias Agopian698c0872011-06-29 02:09:311693 }
1694 }
Robert Carr3b382ed2018-03-14 20:49:411695 return err;
Mathias Agopian698c0872011-06-29 02:09:311696}
1697
chaviwfe94a222019-08-21 20:52:591698sp<SurfaceControl> SurfaceComposerClient::mirrorSurface(SurfaceControl* mirrorFromSurface) {
1699 if (mirrorFromSurface == nullptr) {
1700 return nullptr;
1701 }
1702
1703 sp<IBinder> handle;
1704 sp<IBinder> mirrorFromHandle = mirrorFromSurface->getHandle();
Pablo Gamito2ec1f7b2020-09-01 14:18:491705 int32_t layer_id = -1;
1706 status_t err = mClient->mirrorSurface(mirrorFromHandle, &handle, &layer_id);
chaviwfe94a222019-08-21 20:52:591707 if (err == NO_ERROR) {
Pablo Gamitodbc31672020-09-01 18:28:581708 return new SurfaceControl(this, handle, nullptr, layer_id, true /* owned */);
chaviwfe94a222019-08-21 20:52:591709 }
1710 return nullptr;
1711}
1712
Svetoslavd85084b2014-03-20 17:28:311713status_t SurfaceComposerClient::clearLayerFrameStats(const sp<IBinder>& token) const {
1714 if (mStatus != NO_ERROR) {
1715 return mStatus;
1716 }
1717 return mClient->clearLayerFrameStats(token);
1718}
1719
1720status_t SurfaceComposerClient::getLayerFrameStats(const sp<IBinder>& token,
1721 FrameStats* outStats) const {
1722 if (mStatus != NO_ERROR) {
1723 return mStatus;
1724 }
1725 return mClient->getLayerFrameStats(token, outStats);
1726}
1727
Mathias Agopian698c0872011-06-29 02:09:311728// ----------------------------------------------------------------------------
1729
Sahil Dhanjuc1ba5c42016-06-08 03:09:201730status_t SurfaceComposerClient::enableVSyncInjections(bool enable) {
Robert Carr4cdc58f2017-08-23 21:22:201731 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
1732 return sf->enableVSyncInjections(enable);
Sahil Dhanjuc1ba5c42016-06-08 03:09:201733}
1734
1735status_t SurfaceComposerClient::injectVSync(nsecs_t when) {
Robert Carr4cdc58f2017-08-23 21:22:201736 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
1737 return sf->injectVSync(when);
Sahil Dhanjuc1ba5c42016-06-08 03:09:201738}
1739
Dominik Laskowski3cb3d4e2019-11-21 19:14:451740status_t SurfaceComposerClient::getDisplayState(const sp<IBinder>& display,
1741 ui::DisplayState* state) {
1742 return ComposerService::getComposerService()->getDisplayState(display, state);
1743}
1744
1745status_t SurfaceComposerClient::getDisplayInfo(const sp<IBinder>& display, DisplayInfo* info) {
1746 return ComposerService::getComposerService()->getDisplayInfo(display, info);
1747}
1748
1749status_t SurfaceComposerClient::getDisplayConfigs(const sp<IBinder>& display,
1750 Vector<DisplayConfig>* configs) {
Dan Stoza7f7da322014-05-02 22:26:251751 return ComposerService::getComposerService()->getDisplayConfigs(display, configs);
1752}
1753
Dominik Laskowski3cb3d4e2019-11-21 19:14:451754status_t SurfaceComposerClient::getActiveDisplayConfig(const sp<IBinder>& display,
1755 DisplayConfig* config) {
1756 Vector<DisplayConfig> configs;
Dan Stoza7f7da322014-05-02 22:26:251757 status_t result = getDisplayConfigs(display, &configs);
1758 if (result != NO_ERROR) {
1759 return result;
1760 }
1761
1762 int activeId = getActiveConfig(display);
1763 if (activeId < 0) {
1764 ALOGE("No active configuration found");
1765 return NAME_NOT_FOUND;
1766 }
1767
Dominik Laskowski3cb3d4e2019-11-21 19:14:451768 *config = configs[static_cast<size_t>(activeId)];
Dan Stoza7f7da322014-05-02 22:26:251769 return NO_ERROR;
1770}
1771
1772int SurfaceComposerClient::getActiveConfig(const sp<IBinder>& display) {
1773 return ComposerService::getComposerService()->getActiveConfig(display);
1774}
1775
Ana Krulec0782b882019-10-16 00:34:541776status_t SurfaceComposerClient::setDesiredDisplayConfigSpecs(const sp<IBinder>& displayToken,
Ana Kruleced3a8cc2019-11-13 23:55:071777 int32_t defaultConfig,
Steven Thomasf734df42020-04-14 04:09:281778 float primaryRefreshRateMin,
1779 float primaryRefreshRateMax,
1780 float appRequestRefreshRateMin,
1781 float appRequestRefreshRateMax) {
1782 return ComposerService::getComposerService()
1783 ->setDesiredDisplayConfigSpecs(displayToken, defaultConfig, primaryRefreshRateMin,
1784 primaryRefreshRateMax, appRequestRefreshRateMin,
1785 appRequestRefreshRateMax);
Ana Krulec0782b882019-10-16 00:34:541786}
1787
Ana Krulec234bb162019-11-10 21:55:551788status_t SurfaceComposerClient::getDesiredDisplayConfigSpecs(const sp<IBinder>& displayToken,
Ana Kruleced3a8cc2019-11-13 23:55:071789 int32_t* outDefaultConfig,
Steven Thomasf734df42020-04-14 04:09:281790 float* outPrimaryRefreshRateMin,
1791 float* outPrimaryRefreshRateMax,
1792 float* outAppRequestRefreshRateMin,
1793 float* outAppRequestRefreshRateMax) {
1794 return ComposerService::getComposerService()
1795 ->getDesiredDisplayConfigSpecs(displayToken, outDefaultConfig, outPrimaryRefreshRateMin,
1796 outPrimaryRefreshRateMax, outAppRequestRefreshRateMin,
1797 outAppRequestRefreshRateMax);
Ana Krulec234bb162019-11-10 21:55:551798}
1799
Michael Wright28f24d02016-07-12 20:30:531800status_t SurfaceComposerClient::getDisplayColorModes(const sp<IBinder>& display,
Peiyong Lina52f0292018-03-15 00:26:311801 Vector<ColorMode>* outColorModes) {
Michael Wright28f24d02016-07-12 20:30:531802 return ComposerService::getComposerService()->getDisplayColorModes(display, outColorModes);
1803}
1804
Daniel Solomon42d04562019-01-21 05:03:191805status_t SurfaceComposerClient::getDisplayNativePrimaries(const sp<IBinder>& display,
1806 ui::DisplayPrimaries& outPrimaries) {
1807 return ComposerService::getComposerService()->getDisplayNativePrimaries(display, outPrimaries);
1808}
1809
Peiyong Lina52f0292018-03-15 00:26:311810ColorMode SurfaceComposerClient::getActiveColorMode(const sp<IBinder>& display) {
Michael Wright28f24d02016-07-12 20:30:531811 return ComposerService::getComposerService()->getActiveColorMode(display);
1812}
1813
1814status_t SurfaceComposerClient::setActiveColorMode(const sp<IBinder>& display,
Peiyong Lina52f0292018-03-15 00:26:311815 ColorMode colorMode) {
Michael Wright28f24d02016-07-12 20:30:531816 return ComposerService::getComposerService()->setActiveColorMode(display, colorMode);
1817}
1818
Galia Peycheva5492cb52019-10-30 13:13:161819bool SurfaceComposerClient::getAutoLowLatencyModeSupport(const sp<IBinder>& display) {
1820 bool supported = false;
1821 ComposerService::getComposerService()->getAutoLowLatencyModeSupport(display, &supported);
1822 return supported;
1823}
1824
1825void SurfaceComposerClient::setAutoLowLatencyMode(const sp<IBinder>& display, bool on) {
1826 ComposerService::getComposerService()->setAutoLowLatencyMode(display, on);
1827}
1828
1829bool SurfaceComposerClient::getGameContentTypeSupport(const sp<IBinder>& display) {
1830 bool supported = false;
1831 ComposerService::getComposerService()->getGameContentTypeSupport(display, &supported);
1832 return supported;
1833}
1834
1835void SurfaceComposerClient::setGameContentType(const sp<IBinder>& display, bool on) {
1836 ComposerService::getComposerService()->setGameContentType(display, on);
1837}
1838
Prashant Malani2c9b11f2014-05-25 08:36:311839void SurfaceComposerClient::setDisplayPowerMode(const sp<IBinder>& token,
1840 int mode) {
1841 ComposerService::getComposerService()->setPowerMode(token, mode);
Jeff Brown2a09bb32012-10-09 02:13:571842}
1843
Peiyong Linc6780972018-10-28 22:24:081844status_t SurfaceComposerClient::getCompositionPreference(
1845 ui::Dataspace* defaultDataspace, ui::PixelFormat* defaultPixelFormat,
1846 ui::Dataspace* wideColorGamutDataspace, ui::PixelFormat* wideColorGamutPixelFormat) {
1847 return ComposerService::getComposerService()
1848 ->getCompositionPreference(defaultDataspace, defaultPixelFormat,
1849 wideColorGamutDataspace, wideColorGamutPixelFormat);
Peiyong Lin0256f722018-08-31 22:45:101850}
1851
Peiyong Lin08d10512019-01-16 21:27:351852bool SurfaceComposerClient::getProtectedContentSupport() {
1853 bool supported = false;
1854 ComposerService::getComposerService()->getProtectedContentSupport(&supported);
1855 return supported;
1856}
1857
Svetoslavd85084b2014-03-20 17:28:311858status_t SurfaceComposerClient::clearAnimationFrameStats() {
1859 return ComposerService::getComposerService()->clearAnimationFrameStats();
1860}
1861
1862status_t SurfaceComposerClient::getAnimationFrameStats(FrameStats* outStats) {
1863 return ComposerService::getComposerService()->getAnimationFrameStats(outStats);
1864}
1865
Dan Stozac4f471e2016-03-24 16:31:081866status_t SurfaceComposerClient::getHdrCapabilities(const sp<IBinder>& display,
1867 HdrCapabilities* outCapabilities) {
1868 return ComposerService::getComposerService()->getHdrCapabilities(display,
1869 outCapabilities);
1870}
1871
Kevin DuBois9c0a1762018-10-16 20:32:311872status_t SurfaceComposerClient::getDisplayedContentSamplingAttributes(const sp<IBinder>& display,
1873 ui::PixelFormat* outFormat,
1874 ui::Dataspace* outDataspace,
1875 uint8_t* outComponentMask) {
1876 return ComposerService::getComposerService()
1877 ->getDisplayedContentSamplingAttributes(display, outFormat, outDataspace,
1878 outComponentMask);
1879}
1880
Kevin DuBois74e53772018-11-19 18:52:381881status_t SurfaceComposerClient::setDisplayContentSamplingEnabled(const sp<IBinder>& display,
1882 bool enable, uint8_t componentMask,
1883 uint64_t maxFrames) {
1884 return ComposerService::getComposerService()->setDisplayContentSamplingEnabled(display, enable,
1885 componentMask,
1886 maxFrames);
1887}
1888
Kevin DuBois1d4249a2018-08-29 17:45:141889status_t SurfaceComposerClient::getDisplayedContentSample(const sp<IBinder>& display,
1890 uint64_t maxFrames, uint64_t timestamp,
1891 DisplayedFrameStats* outStats) {
1892 return ComposerService::getComposerService()->getDisplayedContentSample(display, maxFrames,
1893 timestamp, outStats);
1894}
Marissa Wall35187b32019-01-08 18:08:521895
Peiyong Lin4f3fddf2019-01-25 01:21:241896status_t SurfaceComposerClient::isWideColorDisplay(const sp<IBinder>& display,
1897 bool* outIsWideColorDisplay) {
1898 return ComposerService::getComposerService()->isWideColorDisplay(display,
1899 outIsWideColorDisplay);
1900}
1901
Kevin DuBois00c66832019-02-19 00:21:311902status_t SurfaceComposerClient::addRegionSamplingListener(
1903 const Rect& samplingArea, const sp<IBinder>& stopLayerHandle,
1904 const sp<IRegionSamplingListener>& listener) {
1905 return ComposerService::getComposerService()->addRegionSamplingListener(samplingArea,
1906 stopLayerHandle,
1907 listener);
1908}
1909
1910status_t SurfaceComposerClient::removeRegionSamplingListener(
1911 const sp<IRegionSamplingListener>& listener) {
1912 return ComposerService::getComposerService()->removeRegionSamplingListener(listener);
1913}
1914
Dan Gittik57e63c52019-01-18 16:37:541915bool SurfaceComposerClient::getDisplayBrightnessSupport(const sp<IBinder>& displayToken) {
1916 bool support = false;
1917 ComposerService::getComposerService()->getDisplayBrightnessSupport(displayToken, &support);
1918 return support;
1919}
1920
1921status_t SurfaceComposerClient::setDisplayBrightness(const sp<IBinder>& displayToken,
1922 float brightness) {
1923 return ComposerService::getComposerService()->setDisplayBrightness(displayToken, brightness);
1924}
1925
Lais Andrade3a6e47d2020-04-02 10:20:161926status_t SurfaceComposerClient::notifyPowerBoost(int32_t boostId) {
1927 return ComposerService::getComposerService()->notifyPowerBoost(boostId);
Ady Abraham8532d012019-05-08 21:50:561928}
1929
Vishnu Nairb13bb952019-11-15 18:24:081930status_t SurfaceComposerClient::setGlobalShadowSettings(const half4& ambientColor,
1931 const half4& spotColor, float lightPosY,
1932 float lightPosZ, float lightRadius) {
1933 return ComposerService::getComposerService()->setGlobalShadowSettings(ambientColor, spotColor,
1934 lightPosY, lightPosZ,
1935 lightRadius);
1936}
1937
Mathias Agopian698c0872011-06-29 02:09:311938// ----------------------------------------------------------------------------
The Android Open Source Projectedbf3b62009-03-04 03:31:441939
chaviw690db382020-07-27 23:46:461940status_t ScreenshotClient::captureDisplay(const DisplayCaptureArgs& captureArgs,
chaviwe7b9f272020-08-18 23:08:591941 const sp<IScreenCaptureListener>& captureListener) {
Mathias Agopian2a9fc492013-03-01 21:42:571942 sp<ISurfaceComposer> s(ComposerService::getComposerService());
Yi Kong48a619f2018-06-05 23:34:591943 if (s == nullptr) return NO_INIT;
chaviw8ffc7b82020-08-18 18:25:371944
chaviwe7b9f272020-08-18 23:08:591945 return s->captureDisplay(captureArgs, captureListener);
Robert Carr673134e2017-01-10 03:48:381946}
1947
chaviw690db382020-07-27 23:46:461948status_t ScreenshotClient::captureDisplay(uint64_t displayOrLayerStack,
chaviwe7b9f272020-08-18 23:08:591949 const sp<IScreenCaptureListener>& captureListener) {
chaviw93df2ea2019-04-30 23:45:121950 sp<ISurfaceComposer> s(ComposerService::getComposerService());
1951 if (s == nullptr) return NO_INIT;
chaviw8ffc7b82020-08-18 18:25:371952
chaviwe7b9f272020-08-18 23:08:591953 return s->captureDisplay(displayOrLayerStack, captureListener);
chaviw93df2ea2019-04-30 23:45:121954}
1955
chaviw26c52482020-07-28 23:25:521956status_t ScreenshotClient::captureLayers(const LayerCaptureArgs& captureArgs,
chaviwe7b9f272020-08-18 23:08:591957 const sp<IScreenCaptureListener>& captureListener) {
chaviwa76b2712017-09-20 19:02:261958 sp<ISurfaceComposer> s(ComposerService::getComposerService());
Yi Kong48a619f2018-06-05 23:34:591959 if (s == nullptr) return NO_INIT;
chaviw8ffc7b82020-08-18 18:25:371960
chaviwe7b9f272020-08-18 23:08:591961 return s->captureLayers(captureArgs, captureListener);
chaviwa76b2712017-09-20 19:02:261962}
Dominik Laskowski718f9602019-11-10 04:01:351963
1964} // namespace android