blob: 9ed7d1cc199daf7cb102b8cc5c94bd2e8a760e6a [file] [log] [blame]
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001/*
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-03 19:31:44 -080020#include <sys/types.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080021
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080022#include <utils/Errors.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080023#include <utils/Log.h>
Mathias Agopiana67932f2011-04-20 14:20:59 -070024#include <utils/SortedVector.h>
25#include <utils/String8.h>
26#include <utils/threads.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080027
Marissa Wall7a9b6ff2018-08-21 17:26:20 -070028#include <binder/IPCThreadState.h>
Mathias Agopiana67932f2011-04-20 14:20:59 -070029#include <binder/IServiceManager.h>
Marissa Wall7a9b6ff2018-08-21 17:26:20 -070030#include <binder/ProcessState.h>
Mathias Agopian9cce3252010-02-09 17:46:37 -080031
Michael Wright28f24d02016-07-12 13:30:53 -070032#include <system/graphics.h>
33
Robert Carr673134e2017-01-09 19:48:38 -080034#include <gui/BufferItemConsumer.h>
Mathias Agopianabe815d2013-03-19 22:22:21 -070035#include <gui/CpuConsumer.h>
Mathias Agopiane3c697f2013-02-14 17:11:02 -080036#include <gui/IGraphicBufferProducer.h>
Mathias Agopian90ac7992012-02-25 18:48:35 -080037#include <gui/ISurfaceComposer.h>
38#include <gui/ISurfaceComposerClient.h>
Robert Carr4cdc58f2017-08-23 14:22:20 -070039#include <gui/LayerState.h>
Robert Carr0d480722017-01-10 16:42:54 -080040#include <gui/Surface.h>
Mathias Agopian90ac7992012-02-25 18:48:35 -080041#include <gui/SurfaceComposerClient.h>
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -080042#include <ui/DisplayConfig.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080043
Robert Carr2c358bf2018-08-08 15:58:15 -070044#ifndef NO_INPUT
45#include <input/InputWindow.h>
46#endif
47
Mathias Agopian41f673c2011-11-17 17:48:35 -080048#include <private/gui/ComposerService.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080049
Marissa Wall73411622019-01-25 10:45:41 -080050// 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-03 19:31:44 -080053namespace android {
Peiyong Lin9f034472018-03-28 15:29:00 -070054
55using ui::ColorMode;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080056// ---------------------------------------------------------------------------
57
Mathias Agopian7e27f052010-05-28 14:22:23 -070058ANDROID_SINGLETON_STATIC_INSTANCE(ComposerService);
59
Mathias Agopianb7e930d2010-06-01 15:12:58 -070060ComposerService::ComposerService()
61: Singleton<ComposerService>() {
Andy McFadden6652b3e2012-09-06 18:45:56 -070062 Mutex::Autolock _l(mLock);
63 connectLocked();
64}
65
66void ComposerService::connectLocked() {
Mathias Agopianb7e930d2010-06-01 15:12:58 -070067 const String16 name("SurfaceFlinger");
68 while (getService(name, &mComposerService) != NO_ERROR) {
69 usleep(250000);
70 }
Yi Konga03e0442018-07-17 11:16:57 -070071 assert(mComposerService != nullptr);
Andy McFadden6652b3e2012-09-06 18:45:56 -070072
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 15:41:05 -070082 explicit DeathObserver(ComposerService& mgr) : mComposerService(mgr) { }
Andy McFadden6652b3e2012-09-06 18:45:56 -070083 };
84
85 mDeathObserver = new DeathObserver(*const_cast<ComposerService*>(this));
Marco Nelissen2ea926b2014-11-14 08:01:01 -080086 IInterface::asBinder(mComposerService)->linkToDeath(mDeathObserver);
Mathias Agopianb7e930d2010-06-01 15:12:58 -070087}
88
Andy McFadden6652b3e2012-09-06 18:45:56 -070089/*static*/ sp<ISurfaceComposer> ComposerService::getComposerService() {
90 ComposerService& instance = ComposerService::getInstance();
91 Mutex::Autolock _l(instance.mLock);
Yi Kong48a619f2018-06-05 16:34:59 -070092 if (instance.mComposerService == nullptr) {
Andy McFadden6652b3e2012-09-06 18:45:56 -070093 ComposerService::getInstance().connectLocked();
Yi Konga03e0442018-07-17 11:16:57 -070094 assert(instance.mComposerService != nullptr);
Andy McFadden6652b3e2012-09-06 18:45:56 -070095 ALOGD("ComposerService reconnected");
96 }
97 return instance.mComposerService;
98}
99
100void ComposerService::composerServiceDied()
101{
102 Mutex::Autolock _l(mLock);
Yi Kong48a619f2018-06-05 16:34:59 -0700103 mComposerService = nullptr;
104 mDeathObserver = nullptr;
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700105}
106
Robert Carrfb4d58b2019-01-15 09:21:27 -0800107class 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
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100128JankDataListener::~JankDataListener() {
129}
130
Mathias Agopian7e27f052010-05-28 14:22:23 -0700131// ---------------------------------------------------------------------------
132
Marissa Wall7a9b6ff2018-08-21 17:26:20 -0700133// TransactionCompletedListener does not use ANDROID_SINGLETON_STATIC_INSTANCE because it needs
134// to be able to return a sp<> to its instance to pass to SurfaceFlinger.
135// ANDROID_SINGLETON_STATIC_INSTANCE only allows a reference to an instance.
136
Marissa Wallc837b5e2018-10-12 10:04:44 -0700137// 0 is an invalid callback id
138TransactionCompletedListener::TransactionCompletedListener() : mCallbackIdCounter(1) {}
139
140CallbackId TransactionCompletedListener::getNextIdLocked() {
141 return mCallbackIdCounter++;
142}
143
Marissa Wall7a9b6ff2018-08-21 17:26:20 -0700144sp<TransactionCompletedListener> TransactionCompletedListener::getInstance() {
145 static sp<TransactionCompletedListener> sInstance = new TransactionCompletedListener;
146 return sInstance;
147}
148
Marissa Wallc837b5e2018-10-12 10:04:44 -0700149sp<ITransactionCompletedListener> TransactionCompletedListener::getIInstance() {
150 return static_cast<sp<ITransactionCompletedListener>>(getInstance());
151}
152
153void TransactionCompletedListener::startListeningLocked() {
Marissa Wall7a9b6ff2018-08-21 17:26:20 -0700154 if (mListening) {
155 return;
156 }
157 ProcessState::self()->startThreadPool();
158 mListening = true;
159}
160
Marissa Wall80d94ad2019-01-18 16:04:36 -0800161CallbackId TransactionCompletedListener::addCallbackFunction(
162 const TransactionCompletedCallback& callbackFunction,
163 const std::unordered_set<sp<SurfaceControl>, SurfaceComposerClient::SCHash>&
164 surfaceControls) {
Marissa Wallc837b5e2018-10-12 10:04:44 -0700165 std::lock_guard<std::mutex> lock(mMutex);
166 startListeningLocked();
167
168 CallbackId callbackId = getNextIdLocked();
Marissa Wall80d94ad2019-01-18 16:04:36 -0800169 mCallbacks[callbackId].callbackFunction = callbackFunction;
170
171 auto& callbackSurfaceControls = mCallbacks[callbackId].surfaceControls;
172
173 for (const auto& surfaceControl : surfaceControls) {
174 callbackSurfaceControls[surfaceControl->getHandle()] = surfaceControl;
175 }
176
Marissa Wallc837b5e2018-10-12 10:04:44 -0700177 return callbackId;
178}
179
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100180void TransactionCompletedListener::addJankListener(const sp<JankDataListener>& listener,
181 sp<SurfaceControl> surfaceControl) {
182 std::lock_guard<std::mutex> lock(mMutex);
183 mJankListeners.insert({surfaceControl->getHandle(), listener});
184}
185
186void TransactionCompletedListener::removeJankListener(const sp<JankDataListener>& listener) {
187 std::lock_guard<std::mutex> lock(mMutex);
188 for (auto it = mJankListeners.begin(); it != mJankListeners.end();) {
189 if (it->second == listener) {
190 it = mJankListeners.erase(it);
191 } else {
192 it++;
193 }
194 }
195}
196
Marissa Wall80d94ad2019-01-18 16:04:36 -0800197void TransactionCompletedListener::addSurfaceControlToCallbacks(
198 const sp<SurfaceControl>& surfaceControl,
199 const std::unordered_set<CallbackId>& callbackIds) {
200 std::lock_guard<std::mutex> lock(mMutex);
201
202 for (auto callbackId : callbackIds) {
203 mCallbacks[callbackId].surfaceControls.emplace(std::piecewise_construct,
204 std::forward_as_tuple(
205 surfaceControl->getHandle()),
206 std::forward_as_tuple(surfaceControl));
207 }
208}
209
Marissa Walle2ffb422018-10-12 11:33:52 -0700210void TransactionCompletedListener::onTransactionCompleted(ListenerStats listenerStats) {
Valerie Haud3b90d22019-11-06 09:37:31 -0800211 std::unordered_map<CallbackId, CallbackTranslation> callbacksMap;
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100212 std::multimap<sp<IBinder>, sp<JankDataListener>> jankListenersMap;
Valerie Haud3b90d22019-11-06 09:37:31 -0800213 {
214 std::lock_guard<std::mutex> lock(mMutex);
Marissa Walle2ffb422018-10-12 11:33:52 -0700215
Valerie Haud3b90d22019-11-06 09:37:31 -0800216 /* This listener knows all the sp<IBinder> to sp<SurfaceControl> for all its registered
217 * callbackIds, except for when Transactions are merged together. This probably cannot be
218 * solved before this point because the Transactions could be merged together and applied in
219 * a different process.
220 *
221 * Fortunately, we get all the callbacks for this listener for the same frame together at
222 * the same time. This means if any Transactions were merged together, we will get their
223 * callbacks at the same time. We can combine all the sp<IBinder> to sp<SurfaceControl> maps
224 * for all the callbackIds to generate one super map that contains all the sp<IBinder> to
225 * sp<SurfaceControl> that could possibly exist for the callbacks.
226 */
227 callbacksMap = mCallbacks;
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100228 jankListenersMap = mJankListeners;
Valerie Haud3b90d22019-11-06 09:37:31 -0800229 for (const auto& transactionStats : listenerStats.transactionStats) {
230 for (auto& callbackId : transactionStats.callbackIds) {
231 mCallbacks.erase(callbackId);
232 }
Marissa Wall80d94ad2019-01-18 16:04:36 -0800233 }
234 }
Marissa Walld600d572019-03-26 15:38:50 -0700235 for (const auto& transactionStats : listenerStats.transactionStats) {
236 for (auto callbackId : transactionStats.callbackIds) {
Valerie Haud3b90d22019-11-06 09:37:31 -0800237 auto& [callbackFunction, callbackSurfaceControls] = callbacksMap[callbackId];
Marissa Wall80d94ad2019-01-18 16:04:36 -0800238 if (!callbackFunction) {
Marissa Walle2ffb422018-10-12 11:33:52 -0700239 ALOGE("cannot call null callback function, skipping");
240 continue;
241 }
Marissa Wall80d94ad2019-01-18 16:04:36 -0800242 std::vector<SurfaceControlStats> surfaceControlStats;
243 for (const auto& surfaceStats : transactionStats.surfaceStats) {
Valerie Haud3b90d22019-11-06 09:37:31 -0800244 surfaceControlStats
245 .emplace_back(callbacksMap[callbackId]
246 .surfaceControls[surfaceStats.surfaceControl],
Valerie Hau871d6352020-01-29 08:44:02 -0800247 transactionStats.latchTime, surfaceStats.acquireTime,
248 transactionStats.presentFence,
249 surfaceStats.previousReleaseFence, surfaceStats.transformHint,
250 surfaceStats.eventStats);
Valerie Hau84d87ff2020-01-08 17:23:21 -0800251 if (callbacksMap[callbackId].surfaceControls[surfaceStats.surfaceControl]) {
252 callbacksMap[callbackId]
253 .surfaceControls[surfaceStats.surfaceControl]
254 ->setTransformHint(surfaceStats.transformHint);
255 }
Marissa Wall80d94ad2019-01-18 16:04:36 -0800256 }
257
258 callbackFunction(transactionStats.latchTime, transactionStats.presentFence,
259 surfaceControlStats);
Marissa Walle2ffb422018-10-12 11:33:52 -0700260 }
Jorim Jaggi9c03b502020-11-24 23:51:31 +0100261 for (const auto& surfaceStats : transactionStats.surfaceStats) {
262 if (surfaceStats.jankData.empty()) continue;
263 for (auto it = jankListenersMap.find(surfaceStats.surfaceControl);
264 it != jankListenersMap.end(); it++) {
265 it->second->onJankDataAvailable(surfaceStats.jankData);
266 }
267 }
Marissa Walle2ffb422018-10-12 11:33:52 -0700268 }
Marissa Wall7a9b6ff2018-08-21 17:26:20 -0700269}
270
271// ---------------------------------------------------------------------------
272
Robert Carre06ad2b2020-04-10 15:09:33 -0700273void removeDeadBufferCallback(void* /*context*/, uint64_t graphicBufferId);
Marissa Wall78b72202019-03-15 14:58:34 -0700274
Robert Carre06ad2b2020-04-10 15:09:33 -0700275/**
276 * We use the BufferCache to reduce the overhead of exchanging GraphicBuffers with
277 * the server. If we were to simply parcel the GraphicBuffer we would pay two overheads
278 * 1. Cost of sending the FD
279 * 2. Cost of importing the GraphicBuffer with the mapper in the receiving process.
280 * To ease this cost we implement the following scheme of caching buffers to integers,
281 * or said-otherwise, naming them with integers. This is the scheme known as slots in
282 * the legacy BufferQueue system.
283 * 1. When sending Buffers to SurfaceFlinger we look up the Buffer in the cache.
284 * 2. If there is a cache-hit we remove the Buffer from the Transaction and instead
285 * send the cached integer.
286 * 3. If there is a cache miss, we cache the new buffer and send the integer
287 * along with the Buffer, SurfaceFlinger on it's side creates a new cache
288 * entry, and we use the integer for further communication.
289 * A few details about lifetime:
290 * 1. The cache evicts by LRU. The server side cache is keyed by BufferCache::getToken
291 * which is per process Unique. The server side cache is larger than the client side
292 * cache so that the server will never evict entries before the client.
293 * 2. When the client evicts an entry it notifies the server via an uncacheBuffer
294 * transaction.
295 * 3. The client only references the Buffers by ID, and uses buffer->addDeathCallback
296 * to auto-evict destroyed buffers.
297 */
Marissa Wall73411622019-01-25 10:45:41 -0800298class BufferCache : public Singleton<BufferCache> {
299public:
300 BufferCache() : token(new BBinder()) {}
301
302 sp<IBinder> getToken() {
303 return IInterface::asBinder(TransactionCompletedListener::getIInstance());
304 }
305
Marissa Wall78b72202019-03-15 14:58:34 -0700306 status_t getCacheId(const sp<GraphicBuffer>& buffer, uint64_t* cacheId) {
Yi Kongd2639aa2019-02-28 11:58:32 -0800307 std::lock_guard<std::mutex> lock(mMutex);
Marissa Wall73411622019-01-25 10:45:41 -0800308
Marissa Wall78b72202019-03-15 14:58:34 -0700309 auto itr = mBuffers.find(buffer->getId());
Marissa Wall73411622019-01-25 10:45:41 -0800310 if (itr == mBuffers.end()) {
Marissa Wall78b72202019-03-15 14:58:34 -0700311 return BAD_VALUE;
Marissa Wall73411622019-01-25 10:45:41 -0800312 }
Marissa Wall78b72202019-03-15 14:58:34 -0700313 itr->second = getCounter();
314 *cacheId = buffer->getId();
315 return NO_ERROR;
Marissa Wall73411622019-01-25 10:45:41 -0800316 }
317
Marissa Wall78b72202019-03-15 14:58:34 -0700318 uint64_t cache(const sp<GraphicBuffer>& buffer) {
Yi Kongd2639aa2019-02-28 11:58:32 -0800319 std::lock_guard<std::mutex> lock(mMutex);
Marissa Wall73411622019-01-25 10:45:41 -0800320
Marissa Wall78b72202019-03-15 14:58:34 -0700321 if (mBuffers.size() >= BUFFER_CACHE_MAX_SIZE) {
322 evictLeastRecentlyUsedBuffer();
323 }
Marissa Wall73411622019-01-25 10:45:41 -0800324
Robert Carre06ad2b2020-04-10 15:09:33 -0700325 buffer->addDeathCallback(removeDeadBufferCallback, nullptr);
Marissa Wall78b72202019-03-15 14:58:34 -0700326
327 mBuffers[buffer->getId()] = getCounter();
328 return buffer->getId();
329 }
330
331 void uncache(uint64_t cacheId) {
332 std::lock_guard<std::mutex> lock(mMutex);
333 uncacheLocked(cacheId);
334 }
335
336 void uncacheLocked(uint64_t cacheId) REQUIRES(mMutex) {
337 mBuffers.erase(cacheId);
338 SurfaceComposerClient::doUncacheBufferTransaction(cacheId);
Marissa Wall73411622019-01-25 10:45:41 -0800339 }
340
341private:
Marissa Wall78b72202019-03-15 14:58:34 -0700342 void evictLeastRecentlyUsedBuffer() REQUIRES(mMutex) {
Marissa Wall73411622019-01-25 10:45:41 -0800343 auto itr = mBuffers.begin();
Marissa Wall78b72202019-03-15 14:58:34 -0700344 uint64_t minCounter = itr->second;
Marissa Wall73411622019-01-25 10:45:41 -0800345 auto minBuffer = itr;
346 itr++;
347
348 while (itr != mBuffers.end()) {
Marissa Wall78b72202019-03-15 14:58:34 -0700349 uint64_t counter = itr->second;
Marissa Wall73411622019-01-25 10:45:41 -0800350 if (counter < minCounter) {
351 minCounter = counter;
352 minBuffer = itr;
353 }
354 itr++;
355 }
Marissa Wall78b72202019-03-15 14:58:34 -0700356 uncacheLocked(minBuffer->first);
Marissa Wall73411622019-01-25 10:45:41 -0800357 }
358
359 uint64_t getCounter() REQUIRES(mMutex) {
360 static uint64_t counter = 0;
361 return counter++;
362 }
363
Marissa Wall73411622019-01-25 10:45:41 -0800364 std::mutex mMutex;
Marissa Wall78b72202019-03-15 14:58:34 -0700365 std::map<uint64_t /*Cache id*/, uint64_t /*counter*/> mBuffers GUARDED_BY(mMutex);
Marissa Wall73411622019-01-25 10:45:41 -0800366
367 // Used by ISurfaceComposer to identify which process is sending the cached buffer.
368 sp<IBinder> token;
369};
370
371ANDROID_SINGLETON_STATIC_INSTANCE(BufferCache);
372
Robert Carre06ad2b2020-04-10 15:09:33 -0700373void removeDeadBufferCallback(void* /*context*/, uint64_t graphicBufferId) {
Marissa Wall78b72202019-03-15 14:58:34 -0700374 // GraphicBuffer id's are used as the cache ids.
375 BufferCache::getInstance().uncache(graphicBufferId);
376}
377
Marissa Wall73411622019-01-25 10:45:41 -0800378// ---------------------------------------------------------------------------
379
Pablo Gamito7eb7ee72020-08-05 10:57:05 +0000380// Initialize transaction id counter used to generate transaction ids
381// Transactions will start counting at 1, 0 is used for invalid transactions
382std::atomic<uint32_t> SurfaceComposerClient::Transaction::idCounter = 1;
383
384SurfaceComposerClient::Transaction::Transaction() {
385 mId = generateId();
386}
387
Marissa Wall17b4e452018-12-26 16:32:34 -0800388SurfaceComposerClient::Transaction::Transaction(const Transaction& other)
Pablo Gamito7eb7ee72020-08-05 10:57:05 +0000389 : mId(other.mId),
390 mForceSynchronous(other.mForceSynchronous),
Marissa Wall17b4e452018-12-26 16:32:34 -0800391 mTransactionNestCount(other.mTransactionNestCount),
392 mAnimation(other.mAnimation),
393 mEarlyWakeup(other.mEarlyWakeup),
Ady Abrahambf1349c2020-06-12 14:26:18 -0700394 mExplicitEarlyWakeupStart(other.mExplicitEarlyWakeupStart),
395 mExplicitEarlyWakeupEnd(other.mExplicitEarlyWakeupEnd),
Vishnu Nair621102e2019-06-12 14:16:57 -0700396 mContainsBuffer(other.mContainsBuffer),
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700397 mDesiredPresentTime(other.mDesiredPresentTime),
398 mFrameTimelineVsyncId(other.mFrameTimelineVsyncId) {
Robert Carr4cdc58f2017-08-23 14:22:20 -0700399 mDisplayStates = other.mDisplayStates;
400 mComposerStates = other.mComposerStates;
chaviw273171b2018-12-26 11:46:30 -0800401 mInputWindowCommands = other.mInputWindowCommands;
Vishnu Nair621102e2019-06-12 14:16:57 -0700402 mListenerCallbacks = other.mListenerCallbacks;
403}
404
405std::unique_ptr<SurfaceComposerClient::Transaction>
406SurfaceComposerClient::Transaction::createFromParcel(const Parcel* parcel) {
407 auto transaction = std::make_unique<Transaction>();
408 if (transaction->readFromParcel(parcel) == NO_ERROR) {
409 return transaction;
410 }
411 return nullptr;
412}
413
Pablo Gamito7eb7ee72020-08-05 10:57:05 +0000414int64_t SurfaceComposerClient::Transaction::generateId() {
415 return (((int64_t)getpid()) << 32) | idCounter++;
416}
417
Vishnu Nair621102e2019-06-12 14:16:57 -0700418status_t SurfaceComposerClient::Transaction::readFromParcel(const Parcel* parcel) {
419 const uint32_t forceSynchronous = parcel->readUint32();
420 const uint32_t transactionNestCount = parcel->readUint32();
421 const bool animation = parcel->readBool();
422 const bool earlyWakeup = parcel->readBool();
Ady Abrahambf1349c2020-06-12 14:26:18 -0700423 const bool explicitEarlyWakeupStart = parcel->readBool();
424 const bool explicitEarlyWakeupEnd = parcel->readBool();
Vishnu Nair621102e2019-06-12 14:16:57 -0700425 const bool containsBuffer = parcel->readBool();
426 const int64_t desiredPresentTime = parcel->readInt64();
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700427 const int64_t frameTimelineVsyncId = parcel->readInt64();
Vishnu Nair621102e2019-06-12 14:16:57 -0700428
429 size_t count = static_cast<size_t>(parcel->readUint32());
430 if (count > parcel->dataSize()) {
431 return BAD_VALUE;
432 }
433 SortedVector<DisplayState> displayStates;
434 displayStates.setCapacity(count);
435 for (size_t i = 0; i < count; i++) {
436 DisplayState displayState;
437 if (displayState.read(*parcel) == BAD_VALUE) {
438 return BAD_VALUE;
439 }
440 displayStates.add(displayState);
441 }
442
443 count = static_cast<size_t>(parcel->readUint32());
444 if (count > parcel->dataSize()) {
445 return BAD_VALUE;
446 }
Valerie Hau9dab9732019-08-20 09:29:25 -0700447 std::unordered_map<sp<ITransactionCompletedListener>, CallbackInfo, TCLHash> listenerCallbacks;
448 listenerCallbacks.reserve(count);
449 for (size_t i = 0; i < count; i++) {
450 sp<ITransactionCompletedListener> listener =
451 interface_cast<ITransactionCompletedListener>(parcel->readStrongBinder());
452 size_t numCallbackIds = parcel->readUint32();
453 if (numCallbackIds > parcel->dataSize()) {
454 return BAD_VALUE;
455 }
456 for (size_t j = 0; j < numCallbackIds; j++) {
457 listenerCallbacks[listener].callbackIds.insert(parcel->readInt64());
458 }
459 size_t numSurfaces = parcel->readUint32();
460 if (numSurfaces > parcel->dataSize()) {
461 return BAD_VALUE;
462 }
463 for (size_t j = 0; j < numSurfaces; j++) {
464 sp<SurfaceControl> surface;
Pablo Gamito421dfd52020-09-22 18:11:45 +0000465 SAFE_PARCEL(SurfaceControl::readFromParcel, *parcel, &surface);
Valerie Hau9dab9732019-08-20 09:29:25 -0700466 listenerCallbacks[listener].surfaceControls.insert(surface);
467 }
468 }
469
470 count = static_cast<size_t>(parcel->readUint32());
471 if (count > parcel->dataSize()) {
472 return BAD_VALUE;
473 }
Vishnu Nairf03652d2019-07-16 17:56:56 -0700474 std::unordered_map<sp<IBinder>, ComposerState, IBinderHash> composerStates;
Vishnu Nair621102e2019-06-12 14:16:57 -0700475 composerStates.reserve(count);
476 for (size_t i = 0; i < count; i++) {
Pablo Gamitodbc31672020-09-01 18:28:58 +0000477 sp<IBinder> surfaceControlHandle;
478 SAFE_PARCEL(parcel->readStrongBinder, &surfaceControlHandle);
Vishnu Nair621102e2019-06-12 14:16:57 -0700479
480 ComposerState composerState;
481 if (composerState.read(*parcel) == BAD_VALUE) {
482 return BAD_VALUE;
483 }
Pablo Gamitodbc31672020-09-01 18:28:58 +0000484
Vishnu Nairf03652d2019-07-16 17:56:56 -0700485 composerStates[surfaceControlHandle] = composerState;
Vishnu Nair621102e2019-06-12 14:16:57 -0700486 }
487
488 InputWindowCommands inputWindowCommands;
489 inputWindowCommands.read(*parcel);
490
491 // Parsing was successful. Update the object.
492 mForceSynchronous = forceSynchronous;
493 mTransactionNestCount = transactionNestCount;
494 mAnimation = animation;
495 mEarlyWakeup = earlyWakeup;
Ady Abrahambf1349c2020-06-12 14:26:18 -0700496 mExplicitEarlyWakeupStart = explicitEarlyWakeupStart;
497 mExplicitEarlyWakeupEnd = explicitEarlyWakeupEnd;
Vishnu Nair621102e2019-06-12 14:16:57 -0700498 mContainsBuffer = containsBuffer;
499 mDesiredPresentTime = desiredPresentTime;
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700500 mFrameTimelineVsyncId = frameTimelineVsyncId;
Vishnu Nair621102e2019-06-12 14:16:57 -0700501 mDisplayStates = displayStates;
Valerie Hau9dab9732019-08-20 09:29:25 -0700502 mListenerCallbacks = listenerCallbacks;
Vishnu Nair621102e2019-06-12 14:16:57 -0700503 mComposerStates = composerStates;
504 mInputWindowCommands = inputWindowCommands;
Vishnu Nair621102e2019-06-12 14:16:57 -0700505 return NO_ERROR;
506}
507
508status_t SurfaceComposerClient::Transaction::writeToParcel(Parcel* parcel) const {
Robert Carr158531d2020-04-08 10:53:30 -0700509 // If we write the Transaction to a parcel, we want to ensure the Buffers are cached
510 // before crossing the IPC boundary. Otherwise the receiving party will cache the buffers
511 // but is unlikely to use them again as they are owned by the other process.
512 // You may be asking yourself, is this const cast safe? Const cast is safe up
513 // until the point where you try and write to an object that was originally const at which
514 // point we enter undefined behavior. In this case we are safe though, because there are
515 // two possibilities:
516 // 1. The SurfaceComposerClient::Transaction was originally non-const. Safe.
517 // 2. It was originall const! In this case not only was it useless, but it by definition
518 // contains no composer states and so cacheBuffers will not perform any writes.
519
520 const_cast<SurfaceComposerClient::Transaction*>(this)->cacheBuffers();
521
Vishnu Nair621102e2019-06-12 14:16:57 -0700522 parcel->writeUint32(mForceSynchronous);
523 parcel->writeUint32(mTransactionNestCount);
524 parcel->writeBool(mAnimation);
525 parcel->writeBool(mEarlyWakeup);
Ady Abrahambf1349c2020-06-12 14:26:18 -0700526 parcel->writeBool(mExplicitEarlyWakeupStart);
527 parcel->writeBool(mExplicitEarlyWakeupEnd);
Vishnu Nair621102e2019-06-12 14:16:57 -0700528 parcel->writeBool(mContainsBuffer);
529 parcel->writeInt64(mDesiredPresentTime);
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700530 parcel->writeInt64(mFrameTimelineVsyncId);
Vishnu Nair621102e2019-06-12 14:16:57 -0700531 parcel->writeUint32(static_cast<uint32_t>(mDisplayStates.size()));
532 for (auto const& displayState : mDisplayStates) {
533 displayState.write(*parcel);
534 }
535
Valerie Hau9dab9732019-08-20 09:29:25 -0700536 parcel->writeUint32(static_cast<uint32_t>(mListenerCallbacks.size()));
537 for (auto const& [listener, callbackInfo] : mListenerCallbacks) {
538 parcel->writeStrongBinder(ITransactionCompletedListener::asBinder(listener));
539 parcel->writeUint32(static_cast<uint32_t>(callbackInfo.callbackIds.size()));
540 for (auto callbackId : callbackInfo.callbackIds) {
541 parcel->writeInt64(callbackId);
542 }
543 parcel->writeUint32(static_cast<uint32_t>(callbackInfo.surfaceControls.size()));
544 for (auto surfaceControl : callbackInfo.surfaceControls) {
Pablo Gamito421dfd52020-09-22 18:11:45 +0000545 SAFE_PARCEL(surfaceControl->writeToParcel, *parcel);
Valerie Hau9dab9732019-08-20 09:29:25 -0700546 }
547 }
548
Vishnu Nair621102e2019-06-12 14:16:57 -0700549 parcel->writeUint32(static_cast<uint32_t>(mComposerStates.size()));
Pablo Gamitodbc31672020-09-01 18:28:58 +0000550 for (auto const& [handle, composerState] : mComposerStates) {
551 SAFE_PARCEL(parcel->writeStrongBinder, handle);
Vishnu Nair621102e2019-06-12 14:16:57 -0700552 composerState.write(*parcel);
553 }
554
555 mInputWindowCommands.write(*parcel);
556 return NO_ERROR;
Mathias Agopian698c0872011-06-28 19:09:31 -0700557}
558
Robert Carr2c5f6d22017-09-26 12:30:35 -0700559SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::merge(Transaction&& other) {
Pablo Gamitodbc31672020-09-01 18:28:58 +0000560 for (auto const& [handle, composerState] : other.mComposerStates) {
561 if (mComposerStates.count(handle) == 0) {
562 mComposerStates[handle] = composerState;
Robert Carr2c5f6d22017-09-26 12:30:35 -0700563 } else {
Pablo Gamitodbc31672020-09-01 18:28:58 +0000564 mComposerStates[handle].state.merge(composerState.state);
Robert Carr2c5f6d22017-09-26 12:30:35 -0700565 }
566 }
Robert Carr2c5f6d22017-09-26 12:30:35 -0700567
568 for (auto const& state : other.mDisplayStates) {
569 ssize_t index = mDisplayStates.indexOf(state);
570 if (index < 0) {
571 mDisplayStates.add(state);
572 } else {
573 mDisplayStates.editItemAt(static_cast<size_t>(index)).merge(state);
574 }
575 }
Robert Carr2c5f6d22017-09-26 12:30:35 -0700576
Marissa Wallc837b5e2018-10-12 10:04:44 -0700577 for (const auto& [listener, callbackInfo] : other.mListenerCallbacks) {
578 auto& [callbackIds, surfaceControls] = callbackInfo;
579 mListenerCallbacks[listener].callbackIds.insert(std::make_move_iterator(
580 callbackIds.begin()),
581 std::make_move_iterator(callbackIds.end()));
Valerie Hau9dab9732019-08-20 09:29:25 -0700582
Valerie Hau236eba32020-01-03 16:53:39 -0800583 mListenerCallbacks[listener].surfaceControls.insert(surfaceControls.begin(),
584 surfaceControls.end());
585
586 auto& currentProcessCallbackInfo =
587 mListenerCallbacks[TransactionCompletedListener::getIInstance()];
588 currentProcessCallbackInfo.surfaceControls
589 .insert(std::make_move_iterator(surfaceControls.begin()),
590 std::make_move_iterator(surfaceControls.end()));
591
592 // register all surface controls for all callbackIds for this listener that is merging
593 for (const auto& surfaceControl : currentProcessCallbackInfo.surfaceControls) {
594 TransactionCompletedListener::getInstance()
595 ->addSurfaceControlToCallbacks(surfaceControl,
596 currentProcessCallbackInfo.callbackIds);
597 }
Marissa Wallc837b5e2018-10-12 10:04:44 -0700598 }
Marissa Wallc837b5e2018-10-12 10:04:44 -0700599
chaviw273171b2018-12-26 11:46:30 -0800600 mInputWindowCommands.merge(other.mInputWindowCommands);
601
Robert Carrbbc85622020-04-08 10:45:12 -0700602 mContainsBuffer |= other.mContainsBuffer;
Jorim Jaggie3b57002019-07-22 17:18:52 +0200603 mEarlyWakeup = mEarlyWakeup || other.mEarlyWakeup;
Ady Abrahambf1349c2020-06-12 14:26:18 -0700604 mExplicitEarlyWakeupStart = mExplicitEarlyWakeupStart || other.mExplicitEarlyWakeupStart;
605 mExplicitEarlyWakeupEnd = mExplicitEarlyWakeupEnd || other.mExplicitEarlyWakeupEnd;
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700606
607 // When merging vsync Ids we take the oldest one
608 if (mFrameTimelineVsyncId != ISurfaceComposer::INVALID_VSYNC_ID &&
609 other.mFrameTimelineVsyncId != ISurfaceComposer::INVALID_VSYNC_ID) {
610 mFrameTimelineVsyncId = std::max(mFrameTimelineVsyncId, other.mFrameTimelineVsyncId);
611 } else if (mFrameTimelineVsyncId == ISurfaceComposer::INVALID_VSYNC_ID) {
612 mFrameTimelineVsyncId = other.mFrameTimelineVsyncId;
613 }
614
Vishnu Nairfef244e2019-06-17 18:07:51 -0700615 other.clear();
Robert Carr2c5f6d22017-09-26 12:30:35 -0700616 return *this;
617}
618
Vishnu Nairfef244e2019-06-17 18:07:51 -0700619void SurfaceComposerClient::Transaction::clear() {
620 mComposerStates.clear();
621 mDisplayStates.clear();
622 mListenerCallbacks.clear();
623 mInputWindowCommands.clear();
624 mContainsBuffer = false;
625 mForceSynchronous = 0;
626 mTransactionNestCount = 0;
627 mAnimation = false;
628 mEarlyWakeup = false;
Ady Abrahambf1349c2020-06-12 14:26:18 -0700629 mExplicitEarlyWakeupStart = false;
630 mExplicitEarlyWakeupEnd = false;
Vishnu Nairfef244e2019-06-17 18:07:51 -0700631 mDesiredPresentTime = -1;
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700632 mFrameTimelineVsyncId = ISurfaceComposer::INVALID_VSYNC_ID;
Vishnu Nairfef244e2019-06-17 18:07:51 -0700633}
634
Marissa Wall78b72202019-03-15 14:58:34 -0700635void SurfaceComposerClient::doUncacheBufferTransaction(uint64_t cacheId) {
636 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
637
Marissa Wall947d34e2019-03-29 14:03:53 -0700638 client_cache_t uncacheBuffer;
Marissa Wall78b72202019-03-15 14:58:34 -0700639 uncacheBuffer.token = BufferCache::getInstance().getToken();
Marissa Wall947d34e2019-03-29 14:03:53 -0700640 uncacheBuffer.id = cacheId;
Marissa Wall78b72202019-03-15 14:58:34 -0700641
Valerie Haufa889122019-04-15 13:56:05 -0700642 sp<IBinder> applyToken = IInterface::asBinder(TransactionCompletedListener::getIInstance());
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700643 sf->setTransactionState(ISurfaceComposer::INVALID_VSYNC_ID, {}, {}, 0, applyToken, {}, -1,
644 uncacheBuffer, false, {}, 0 /* Undefined transactionId */);
Marissa Wall78b72202019-03-15 14:58:34 -0700645}
646
647void SurfaceComposerClient::Transaction::cacheBuffers() {
648 if (!mContainsBuffer) {
649 return;
650 }
651
652 size_t count = 0;
Vishnu Nairf03652d2019-07-16 17:56:56 -0700653 for (auto& [handle, cs] : mComposerStates) {
Pablo Gamitodbc31672020-09-01 18:28:58 +0000654 layer_state_t* s = &(mComposerStates[handle].state);
Marissa Wall78b72202019-03-15 14:58:34 -0700655 if (!(s->what & layer_state_t::eBufferChanged)) {
656 continue;
Robert Carr28037922020-04-08 10:57:07 -0700657 } else if (s->what & layer_state_t::eCachedBufferChanged) {
658 // If eBufferChanged and eCachedBufferChanged are both trued then that means
659 // we already cached the buffer in a previous call to cacheBuffers, perhaps
660 // from writeToParcel on a Transaction that was merged in to this one.
661 continue;
Marissa Wall78b72202019-03-15 14:58:34 -0700662 }
663
Marissa Wall00597242019-03-27 10:35:19 -0700664 // Don't try to cache a null buffer. Sending null buffers is cheap so we shouldn't waste
665 // time trying to cache them.
666 if (!s->buffer) {
667 continue;
668 }
669
Marissa Wall78b72202019-03-15 14:58:34 -0700670 uint64_t cacheId = 0;
671 status_t ret = BufferCache::getInstance().getCacheId(s->buffer, &cacheId);
672 if (ret == NO_ERROR) {
Robert Carre06ad2b2020-04-10 15:09:33 -0700673 // Cache-hit. Strip the buffer and send only the id.
Marissa Walla141abe2019-03-27 16:28:07 -0700674 s->what &= ~static_cast<uint64_t>(layer_state_t::eBufferChanged);
Marissa Wall78b72202019-03-15 14:58:34 -0700675 s->buffer = nullptr;
676 } else {
Robert Carre06ad2b2020-04-10 15:09:33 -0700677 // Cache-miss. Include the buffer and send the new cacheId.
Marissa Wall78b72202019-03-15 14:58:34 -0700678 cacheId = BufferCache::getInstance().cache(s->buffer);
679 }
680 s->what |= layer_state_t::eCachedBufferChanged;
681 s->cachedBuffer.token = BufferCache::getInstance().getToken();
Marissa Wall947d34e2019-03-29 14:03:53 -0700682 s->cachedBuffer.id = cacheId;
Marissa Wall78b72202019-03-15 14:58:34 -0700683
684 // If we have more buffers than the size of the cache, we should stop caching so we don't
685 // evict other buffers in this transaction
686 count++;
687 if (count >= BUFFER_CACHE_MAX_SIZE) {
688 break;
689 }
690 }
Robert Carr6fb1a7e2018-12-11 12:07:25 -0800691}
692
Robert Carr4cdc58f2017-08-23 14:22:20 -0700693status_t SurfaceComposerClient::Transaction::apply(bool synchronous) {
694 if (mStatus != NO_ERROR) {
695 return mStatus;
696 }
697
698 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
699
Valerie Hau9dab9732019-08-20 09:29:25 -0700700 bool hasListenerCallbacks = !mListenerCallbacks.empty();
Marissa Wall3dad52d2019-03-22 14:03:19 -0700701 std::vector<ListenerCallbacks> listenerCallbacks;
Marissa Wallc837b5e2018-10-12 10:04:44 -0700702 // For every listener with registered callbacks
703 for (const auto& [listener, callbackInfo] : mListenerCallbacks) {
704 auto& [callbackIds, surfaceControls] = callbackInfo;
705 if (callbackIds.empty()) {
706 continue;
707 }
708
Valerie Hau9dab9732019-08-20 09:29:25 -0700709 if (surfaceControls.empty()) {
710 listenerCallbacks.emplace_back(IInterface::asBinder(listener), std::move(callbackIds));
711 } else {
712 // If the listener has any SurfaceControls set on this Transaction update the surface
713 // state
714 for (const auto& surfaceControl : surfaceControls) {
715 layer_state_t* s = getLayerState(surfaceControl);
716 if (!s) {
717 ALOGE("failed to get layer state");
718 continue;
719 }
720 std::vector<CallbackId> callbacks(callbackIds.begin(), callbackIds.end());
721 s->what |= layer_state_t::eHasListenerCallbacksChanged;
722 s->listeners.emplace_back(IInterface::asBinder(listener), callbacks);
Marissa Wallc837b5e2018-10-12 10:04:44 -0700723 }
Marissa Wallc837b5e2018-10-12 10:04:44 -0700724 }
725 }
Valerie Hau9dab9732019-08-20 09:29:25 -0700726
Marissa Wall78b72202019-03-15 14:58:34 -0700727 cacheBuffers();
728
Robert Carr4cdc58f2017-08-23 14:22:20 -0700729 Vector<ComposerState> composerStates;
730 Vector<DisplayState> displayStates;
731 uint32_t flags = 0;
732
733 mForceSynchronous |= synchronous;
734
chaviw8e3fe5d2018-02-22 10:55:42 -0800735 for (auto const& kv : mComposerStates){
736 composerStates.add(kv.second);
737 }
738
Adithya Srinivasand3efcb32020-10-20 18:08:22 -0700739 displayStates = std::move(mDisplayStates);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700740
741 if (mForceSynchronous) {
742 flags |= ISurfaceComposer::eSynchronous;
743 }
744 if (mAnimation) {
745 flags |= ISurfaceComposer::eAnimation;
746 }
Dan Stoza84d619e2018-03-28 17:07:36 -0700747 if (mEarlyWakeup) {
748 flags |= ISurfaceComposer::eEarlyWakeup;
749 }
Robert Carr4cdc58f2017-08-23 14:22:20 -0700750
Ady Abrahambf1349c2020-06-12 14:26:18 -0700751 // If both mExplicitEarlyWakeupStart and mExplicitEarlyWakeupEnd are set
752 // it is equivalent for none
753 if (mExplicitEarlyWakeupStart && !mExplicitEarlyWakeupEnd) {
754 flags |= ISurfaceComposer::eExplicitEarlyWakeupStart;
755 }
756 if (mExplicitEarlyWakeupEnd && !mExplicitEarlyWakeupStart) {
757 flags |= ISurfaceComposer::eExplicitEarlyWakeupEnd;
758 }
759
Marissa Wall713b63f2018-10-17 15:42:43 -0700760 sp<IBinder> applyToken = IInterface::asBinder(TransactionCompletedListener::getIInstance());
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700761 sf->setTransactionState(mFrameTimelineVsyncId, composerStates, displayStates, flags, applyToken,
762 mInputWindowCommands, mDesiredPresentTime,
Marissa Wall3dad52d2019-03-22 14:03:19 -0700763 {} /*uncacheBuffer - only set in doUncacheBufferTransaction*/,
Adithya Srinivasand3efcb32020-10-20 18:08:22 -0700764 hasListenerCallbacks, listenerCallbacks, mId);
765 mId = generateId();
766
767 // Clear the current states and flags
768 clear();
769
Robert Carr4cdc58f2017-08-23 14:22:20 -0700770 mStatus = NO_ERROR;
771 return NO_ERROR;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700772}
773
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800774// ---------------------------------------------------------------------------
775
Robert Carr4cdc58f2017-08-23 14:22:20 -0700776sp<IBinder> SurfaceComposerClient::createDisplay(const String8& displayName, bool secure) {
Jamie Gennisdd3cb842012-10-19 18:19:11 -0700777 return ComposerService::getComposerService()->createDisplay(displayName,
778 secure);
Mathias Agopiane57f2922012-08-09 16:29:12 -0700779}
780
Robert Carr4cdc58f2017-08-23 14:22:20 -0700781void SurfaceComposerClient::destroyDisplay(const sp<IBinder>& display) {
Jesse Hall6c913be2013-08-08 12:15:49 -0700782 return ComposerService::getComposerService()->destroyDisplay(display);
783}
784
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800785std::vector<PhysicalDisplayId> SurfaceComposerClient::getPhysicalDisplayIds() {
786 return ComposerService::getComposerService()->getPhysicalDisplayIds();
787}
788
789std::optional<PhysicalDisplayId> SurfaceComposerClient::getInternalDisplayId() {
790 return ComposerService::getComposerService()->getInternalDisplayId();
791}
792
793sp<IBinder> SurfaceComposerClient::getPhysicalDisplayToken(PhysicalDisplayId displayId) {
794 return ComposerService::getComposerService()->getPhysicalDisplayToken(displayId);
795}
796
797sp<IBinder> SurfaceComposerClient::getInternalDisplayToken() {
798 return ComposerService::getComposerService()->getInternalDisplayToken();
Jeff Brown9d4e3d22012-08-24 20:00:51 -0700799}
800
Robert Carr4cdc58f2017-08-23 14:22:20 -0700801void SurfaceComposerClient::Transaction::setAnimationTransaction() {
Jamie Gennis2d5e2302012-10-15 18:24:43 -0700802 mAnimation = true;
803}
804
Dan Stoza84d619e2018-03-28 17:07:36 -0700805void SurfaceComposerClient::Transaction::setEarlyWakeup() {
806 mEarlyWakeup = true;
807}
808
Ady Abrahambf1349c2020-06-12 14:26:18 -0700809void SurfaceComposerClient::Transaction::setExplicitEarlyWakeupStart() {
810 mExplicitEarlyWakeupStart = true;
811}
812
813void SurfaceComposerClient::Transaction::setExplicitEarlyWakeupEnd() {
814 mExplicitEarlyWakeupEnd = true;
815}
816
Pablo Gamitodbc31672020-09-01 18:28:58 +0000817layer_state_t* SurfaceComposerClient::Transaction::getLayerState(const sp<SurfaceControl>& sc) {
818 auto handle = sc->getHandle();
819
Vishnu Nairf03652d2019-07-16 17:56:56 -0700820 if (mComposerStates.count(handle) == 0) {
Mathias Agopian698c0872011-06-28 19:09:31 -0700821 // we don't have it, add an initialized layer_state to our list
chaviw8e3fe5d2018-02-22 10:55:42 -0800822 ComposerState s;
Pablo Gamitodbc31672020-09-01 18:28:58 +0000823
Vishnu Nairf03652d2019-07-16 17:56:56 -0700824 s.state.surface = handle;
Pablo Gamitodbc31672020-09-01 18:28:58 +0000825 s.state.layerId = sc->getLayerId();
826
Vishnu Nairf03652d2019-07-16 17:56:56 -0700827 mComposerStates[handle] = s;
Mathias Agopian698c0872011-06-28 19:09:31 -0700828 }
829
Vishnu Nairf03652d2019-07-16 17:56:56 -0700830 return &(mComposerStates[handle].state);
Mathias Agopian698c0872011-06-28 19:09:31 -0700831}
832
Marissa Wallc837b5e2018-10-12 10:04:44 -0700833void SurfaceComposerClient::Transaction::registerSurfaceControlForCallback(
834 const sp<SurfaceControl>& sc) {
Marissa Wall80d94ad2019-01-18 16:04:36 -0800835 auto& callbackInfo = mListenerCallbacks[TransactionCompletedListener::getIInstance()];
836 callbackInfo.surfaceControls.insert(sc);
837
838 TransactionCompletedListener::getInstance()
839 ->addSurfaceControlToCallbacks(sc, callbackInfo.callbackIds);
Marissa Wallc837b5e2018-10-12 10:04:44 -0700840}
841
Robert Carr4cdc58f2017-08-23 14:22:20 -0700842SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setPosition(
843 const sp<SurfaceControl>& sc, float x, float y) {
chaviw763ef572018-02-22 16:04:57 -0800844 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700845 if (!s) {
846 mStatus = BAD_INDEX;
847 return *this;
848 }
Mathias Agopian3165cc22012-08-08 19:42:09 -0700849 s->what |= layer_state_t::ePositionChanged;
Mathias Agopian698c0872011-06-28 19:09:31 -0700850 s->x = x;
851 s->y = y;
Marissa Wallc837b5e2018-10-12 10:04:44 -0700852
853 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700854 return *this;
Mathias Agopian698c0872011-06-28 19:09:31 -0700855}
856
Robert Carr4cdc58f2017-08-23 14:22:20 -0700857SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::show(
858 const sp<SurfaceControl>& sc) {
859 return setFlags(sc, 0, layer_state_t::eLayerHidden);
860}
861
862SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::hide(
863 const sp<SurfaceControl>& sc) {
864 return setFlags(sc, layer_state_t::eLayerHidden, layer_state_t::eLayerHidden);
865}
866
867SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setSize(
868 const sp<SurfaceControl>& sc, uint32_t w, uint32_t h) {
chaviw763ef572018-02-22 16:04:57 -0800869 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700870 if (!s) {
871 mStatus = BAD_INDEX;
872 return *this;
873 }
Mathias Agopian3165cc22012-08-08 19:42:09 -0700874 s->what |= layer_state_t::eSizeChanged;
Mathias Agopian698c0872011-06-28 19:09:31 -0700875 s->w = w;
876 s->h = h;
Jamie Gennis28378392011-10-12 17:39:00 -0700877
Marissa Wallc837b5e2018-10-12 10:04:44 -0700878 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700879 return *this;
Mathias Agopian698c0872011-06-28 19:09:31 -0700880}
881
Robert Carr4cdc58f2017-08-23 14:22:20 -0700882SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setLayer(
883 const sp<SurfaceControl>& sc, int32_t z) {
chaviw763ef572018-02-22 16:04:57 -0800884 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700885 if (!s) {
886 mStatus = BAD_INDEX;
887 return *this;
888 }
Mathias Agopian3165cc22012-08-08 19:42:09 -0700889 s->what |= layer_state_t::eLayerChanged;
chaviw32377582019-05-13 11:15:19 -0700890 s->what &= ~layer_state_t::eRelativeLayerChanged;
Mathias Agopian698c0872011-06-28 19:09:31 -0700891 s->z = z;
Marissa Wallc837b5e2018-10-12 10:04:44 -0700892
893 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700894 return *this;
Mathias Agopian698c0872011-06-28 19:09:31 -0700895}
896
Pablo Gamito11dcc222020-09-12 15:49:39 +0000897SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setRelativeLayer(
898 const sp<SurfaceControl>& sc, const sp<SurfaceControl>& relativeTo, int32_t z) {
chaviw763ef572018-02-22 16:04:57 -0800899 layer_state_t* s = getLayerState(sc);
Robert Carrdb66e622017-04-10 16:55:57 -0700900 if (!s) {
Robert Carr4cdc58f2017-08-23 14:22:20 -0700901 mStatus = BAD_INDEX;
Robert Carr30c8d902019-04-04 13:12:49 -0700902 return *this;
Robert Carrdb66e622017-04-10 16:55:57 -0700903 }
904 s->what |= layer_state_t::eRelativeLayerChanged;
chaviw32377582019-05-13 11:15:19 -0700905 s->what &= ~layer_state_t::eLayerChanged;
Pablo Gamito11dcc222020-09-12 15:49:39 +0000906 s->relativeLayerSurfaceControl = relativeTo;
Robert Carrdb66e622017-04-10 16:55:57 -0700907 s->z = z;
Marissa Wallc837b5e2018-10-12 10:04:44 -0700908
909 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700910 return *this;
Robert Carrdb66e622017-04-10 16:55:57 -0700911}
912
Robert Carr4cdc58f2017-08-23 14:22:20 -0700913SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFlags(
914 const sp<SurfaceControl>& sc, uint32_t flags,
Mathias Agopian698c0872011-06-28 19:09:31 -0700915 uint32_t mask) {
chaviw763ef572018-02-22 16:04:57 -0800916 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700917 if (!s) {
918 mStatus = BAD_INDEX;
919 return *this;
920 }
chaviwc5676c62020-09-18 15:01:04 -0700921 if ((mask & layer_state_t::eLayerOpaque) || (mask & layer_state_t::eLayerHidden) ||
922 (mask & layer_state_t::eLayerSecure) || (mask & layer_state_t::eLayerSkipScreenshot)) {
Dan Stoza23116082015-06-18 14:58:39 -0700923 s->what |= layer_state_t::eFlagsChanged;
Andy McFadden4125a4f2014-01-29 17:17:11 -0800924 }
Mathias Agopian698c0872011-06-28 19:09:31 -0700925 s->flags &= ~mask;
926 s->flags |= (flags & mask);
927 s->mask |= mask;
Marissa Wallc837b5e2018-10-12 10:04:44 -0700928
929 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700930 return *this;
Mathias Agopian698c0872011-06-28 19:09:31 -0700931}
932
Robert Carr4cdc58f2017-08-23 14:22:20 -0700933SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setTransparentRegionHint(
934 const sp<SurfaceControl>& sc,
Mathias Agopian698c0872011-06-28 19:09:31 -0700935 const Region& transparentRegion) {
chaviw763ef572018-02-22 16:04:57 -0800936 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700937 if (!s) {
938 mStatus = BAD_INDEX;
939 return *this;
940 }
Mathias Agopian3165cc22012-08-08 19:42:09 -0700941 s->what |= layer_state_t::eTransparentRegionChanged;
Mathias Agopian698c0872011-06-28 19:09:31 -0700942 s->transparentRegion = transparentRegion;
Marissa Wallc837b5e2018-10-12 10:04:44 -0700943
944 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700945 return *this;
Mathias Agopian698c0872011-06-28 19:09:31 -0700946}
947
Robert Carr4cdc58f2017-08-23 14:22:20 -0700948SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setAlpha(
949 const sp<SurfaceControl>& sc, float alpha) {
chaviw763ef572018-02-22 16:04:57 -0800950 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700951 if (!s) {
952 mStatus = BAD_INDEX;
953 return *this;
954 }
Mathias Agopian3165cc22012-08-08 19:42:09 -0700955 s->what |= layer_state_t::eAlphaChanged;
Mathias Agopian698c0872011-06-28 19:09:31 -0700956 s->alpha = alpha;
Marissa Wallc837b5e2018-10-12 10:04:44 -0700957
958 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700959 return *this;
Mathias Agopian698c0872011-06-28 19:09:31 -0700960}
961
Robert Carr4cdc58f2017-08-23 14:22:20 -0700962SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setLayerStack(
963 const sp<SurfaceControl>& sc, uint32_t layerStack) {
chaviw763ef572018-02-22 16:04:57 -0800964 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700965 if (!s) {
966 mStatus = BAD_INDEX;
967 return *this;
968 }
Mathias Agopian3165cc22012-08-08 19:42:09 -0700969 s->what |= layer_state_t::eLayerStackChanged;
Mathias Agopian87855782012-07-24 21:41:09 -0700970 s->layerStack = layerStack;
Marissa Wallc837b5e2018-10-12 10:04:44 -0700971
972 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700973 return *this;
Mathias Agopian87855782012-07-24 21:41:09 -0700974}
975
Evan Rosky1f6d6d52018-12-06 10:47:26 -0800976SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setMetadata(
Garfield Tan01a56132019-08-05 16:44:21 -0700977 const sp<SurfaceControl>& sc, uint32_t key, const Parcel& p) {
Evan Rosky1f6d6d52018-12-06 10:47:26 -0800978 layer_state_t* s = getLayerState(sc);
979 if (!s) {
980 mStatus = BAD_INDEX;
981 return *this;
982 }
983 s->what |= layer_state_t::eMetadataChanged;
Garfield Tan01a56132019-08-05 16:44:21 -0700984
985 s->metadata.mMap[key] = {p.data(), p.data() + p.dataSize()};
Evan Rosky1f6d6d52018-12-06 10:47:26 -0800986
987 registerSurfaceControlForCallback(sc);
988 return *this;
989}
990
Robert Carr4cdc58f2017-08-23 14:22:20 -0700991SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setMatrix(
992 const sp<SurfaceControl>& sc, float dsdx, float dtdx,
Robert Carrcb6e1e32017-02-21 19:48:26 -0800993 float dtdy, float dsdy) {
chaviw763ef572018-02-22 16:04:57 -0800994 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -0700995 if (!s) {
996 mStatus = BAD_INDEX;
997 return *this;
998 }
Mathias Agopian3165cc22012-08-08 19:42:09 -0700999 s->what |= layer_state_t::eMatrixChanged;
Mathias Agopian698c0872011-06-28 19:09:31 -07001000 layer_state_t::matrix22_t matrix;
1001 matrix.dsdx = dsdx;
1002 matrix.dtdx = dtdx;
1003 matrix.dsdy = dsdy;
1004 matrix.dtdy = dtdy;
1005 s->matrix = matrix;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001006
1007 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001008 return *this;
Mathias Agopian698c0872011-06-28 19:09:31 -07001009}
1010
Marissa Wallf58c14b2018-07-24 10:50:43 -07001011SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setCrop_legacy(
Robert Carr4cdc58f2017-08-23 14:22:20 -07001012 const sp<SurfaceControl>& sc, const Rect& crop) {
chaviw763ef572018-02-22 16:04:57 -08001013 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001014 if (!s) {
1015 mStatus = BAD_INDEX;
1016 return *this;
1017 }
Marissa Wallf58c14b2018-07-24 10:50:43 -07001018 s->what |= layer_state_t::eCropChanged_legacy;
1019 s->crop_legacy = crop;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001020
1021 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001022 return *this;
Jamie Gennisf15a83f2012-05-10 20:43:55 -07001023}
1024
Lucas Dupin1b6531c2018-07-05 17:18:21 -07001025SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setCornerRadius(
1026 const sp<SurfaceControl>& sc, float cornerRadius) {
1027 layer_state_t* s = getLayerState(sc);
1028 if (!s) {
1029 mStatus = BAD_INDEX;
1030 return *this;
1031 }
1032 s->what |= layer_state_t::eCornerRadiusChanged;
1033 s->cornerRadius = cornerRadius;
1034 return *this;
1035}
1036
Lucas Dupin19c8f0e2019-11-25 17:55:44 -08001037SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setBackgroundBlurRadius(
1038 const sp<SurfaceControl>& sc, int backgroundBlurRadius) {
1039 layer_state_t* s = getLayerState(sc);
1040 if (!s) {
1041 mStatus = BAD_INDEX;
1042 return *this;
1043 }
1044 s->what |= layer_state_t::eBackgroundBlurRadiusChanged;
1045 s->backgroundBlurRadius = backgroundBlurRadius;
1046 return *this;
1047}
1048
Lucas Dupinc3800b82020-10-02 16:24:48 -07001049SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setBlurRegions(
1050 const sp<SurfaceControl>& sc, const std::vector<BlurRegion>& blurRegions) {
1051 layer_state_t* s = getLayerState(sc);
1052 if (!s) {
1053 mStatus = BAD_INDEX;
1054 return *this;
1055 }
1056 s->what |= layer_state_t::eBlurRegionsChanged;
1057 s->blurRegions = blurRegions;
1058 return *this;
1059}
1060
Marissa Wallf58c14b2018-07-24 10:50:43 -07001061SurfaceComposerClient::Transaction&
Pablo Gamito11dcc222020-09-12 15:49:39 +00001062SurfaceComposerClient::Transaction::deferTransactionUntil_legacy(
1063 const sp<SurfaceControl>& sc, const sp<SurfaceControl>& barrierSurfaceControl,
1064 uint64_t frameNumber) {
chaviw763ef572018-02-22 16:04:57 -08001065 layer_state_t* s = getLayerState(sc);
Dan Stoza7dde5992015-05-22 09:51:44 -07001066 if (!s) {
Robert Carr4cdc58f2017-08-23 14:22:20 -07001067 mStatus = BAD_INDEX;
1068 return *this;
Dan Stoza7dde5992015-05-22 09:51:44 -07001069 }
Marissa Wallf58c14b2018-07-24 10:50:43 -07001070 s->what |= layer_state_t::eDeferTransaction_legacy;
Pablo Gamito11dcc222020-09-12 15:49:39 +00001071 s->barrierSurfaceControl_legacy = barrierSurfaceControl;
Vishnu Nair6b7c5c92020-09-29 17:27:05 -07001072 s->barrierFrameNumber = frameNumber;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001073
1074 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001075 return *this;
Robert Carr0d480722017-01-10 16:42:54 -08001076}
1077
Robert Carr4cdc58f2017-08-23 14:22:20 -07001078SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::reparentChildren(
Pablo Gamito11dcc222020-09-12 15:49:39 +00001079 const sp<SurfaceControl>& sc, const sp<SurfaceControl>& newParent) {
chaviw763ef572018-02-22 16:04:57 -08001080 layer_state_t* s = getLayerState(sc);
Robert Carr1db73f62016-12-21 12:58:51 -08001081 if (!s) {
Robert Carr4cdc58f2017-08-23 14:22:20 -07001082 mStatus = BAD_INDEX;
1083 return *this;
Robert Carr1db73f62016-12-21 12:58:51 -08001084 }
1085 s->what |= layer_state_t::eReparentChildren;
Pablo Gamito11dcc222020-09-12 15:49:39 +00001086 s->reparentSurfaceControl = newParent;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001087
1088 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001089 return *this;
Robert Carr1db73f62016-12-21 12:58:51 -08001090}
1091
Robert Carr4cdc58f2017-08-23 14:22:20 -07001092SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::reparent(
Pablo Gamito11dcc222020-09-12 15:49:39 +00001093 const sp<SurfaceControl>& sc, const sp<SurfaceControl>& newParent) {
chaviw763ef572018-02-22 16:04:57 -08001094 layer_state_t* s = getLayerState(sc);
chaviw06178942017-07-27 10:25:59 -07001095 if (!s) {
Robert Carr4cdc58f2017-08-23 14:22:20 -07001096 mStatus = BAD_INDEX;
1097 return *this;
chaviw06178942017-07-27 10:25:59 -07001098 }
chaviwf1961f72017-09-18 16:41:07 -07001099 s->what |= layer_state_t::eReparent;
Pablo Gamito11dcc222020-09-12 15:49:39 +00001100 s->parentSurfaceControlForChild = newParent;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001101
1102 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001103 return *this;
chaviw06178942017-07-27 10:25:59 -07001104}
1105
Robert Carr4cdc58f2017-08-23 14:22:20 -07001106SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setColor(
1107 const sp<SurfaceControl>& sc,
1108 const half3& color) {
chaviw763ef572018-02-22 16:04:57 -08001109 layer_state_t* s = getLayerState(sc);
Robert Carr9524cb32017-02-13 11:32:32 -08001110 if (!s) {
Robert Carr4cdc58f2017-08-23 14:22:20 -07001111 mStatus = BAD_INDEX;
1112 return *this;
1113 }
1114 s->what |= layer_state_t::eColorChanged;
1115 s->color = color;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001116
1117 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001118 return *this;
1119}
1120
Valerie Haudd0b7572019-01-29 14:59:27 -08001121SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setBackgroundColor(
1122 const sp<SurfaceControl>& sc, const half3& color, float alpha, ui::Dataspace dataspace) {
Valerie Haued54efa2019-01-11 20:03:14 -08001123 layer_state_t* s = getLayerState(sc);
1124 if (!s) {
1125 mStatus = BAD_INDEX;
1126 return *this;
1127 }
1128
Valerie Haudd0b7572019-01-29 14:59:27 -08001129 s->what |= layer_state_t::eBackgroundColorChanged;
1130 s->color = color;
1131 s->bgColorAlpha = alpha;
1132 s->bgColorDataspace = dataspace;
Valerie Haued54efa2019-01-11 20:03:14 -08001133
1134 registerSurfaceControlForCallback(sc);
1135 return *this;
1136}
1137
Marissa Wall61c58622018-07-18 10:12:20 -07001138SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setTransform(
1139 const sp<SurfaceControl>& sc, uint32_t transform) {
1140 layer_state_t* s = getLayerState(sc);
1141 if (!s) {
1142 mStatus = BAD_INDEX;
1143 return *this;
1144 }
1145 s->what |= layer_state_t::eTransformChanged;
1146 s->transform = transform;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001147
1148 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 10:12:20 -07001149 return *this;
1150}
1151
1152SurfaceComposerClient::Transaction&
1153SurfaceComposerClient::Transaction::setTransformToDisplayInverse(const sp<SurfaceControl>& sc,
1154 bool transformToDisplayInverse) {
1155 layer_state_t* s = getLayerState(sc);
1156 if (!s) {
1157 mStatus = BAD_INDEX;
1158 return *this;
1159 }
1160 s->what |= layer_state_t::eTransformToDisplayInverseChanged;
1161 s->transformToDisplayInverse = transformToDisplayInverse;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001162
1163 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 10:12:20 -07001164 return *this;
1165}
1166
1167SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setCrop(
1168 const sp<SurfaceControl>& sc, const Rect& crop) {
1169 layer_state_t* s = getLayerState(sc);
1170 if (!s) {
1171 mStatus = BAD_INDEX;
1172 return *this;
1173 }
1174 s->what |= layer_state_t::eCropChanged;
1175 s->crop = crop;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001176
1177 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 10:12:20 -07001178 return *this;
1179}
1180
Marissa Wall861616d2018-10-22 12:52:23 -07001181SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrame(
1182 const sp<SurfaceControl>& sc, const Rect& frame) {
1183 layer_state_t* s = getLayerState(sc);
1184 if (!s) {
1185 mStatus = BAD_INDEX;
1186 return *this;
1187 }
1188 s->what |= layer_state_t::eFrameChanged;
Marin Shalamanov6ad317c2020-07-29 23:34:07 +02001189 s->orientedDisplaySpaceRect = frame;
Marissa Wall861616d2018-10-22 12:52:23 -07001190
1191 registerSurfaceControlForCallback(sc);
1192 return *this;
1193}
1194
Marissa Wall61c58622018-07-18 10:12:20 -07001195SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setBuffer(
1196 const sp<SurfaceControl>& sc, const sp<GraphicBuffer>& buffer) {
1197 layer_state_t* s = getLayerState(sc);
1198 if (!s) {
1199 mStatus = BAD_INDEX;
1200 return *this;
1201 }
Marissa Wall78b72202019-03-15 14:58:34 -07001202 s->what |= layer_state_t::eBufferChanged;
1203 s->buffer = buffer;
Marissa Wallebc2c052019-01-16 19:16:55 -08001204
1205 registerSurfaceControlForCallback(sc);
Marissa Wall78b72202019-03-15 14:58:34 -07001206
1207 mContainsBuffer = true;
Marissa Wallebc2c052019-01-16 19:16:55 -08001208 return *this;
1209}
1210
Marissa Wall61c58622018-07-18 10:12:20 -07001211SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setAcquireFence(
1212 const sp<SurfaceControl>& sc, const sp<Fence>& fence) {
1213 layer_state_t* s = getLayerState(sc);
1214 if (!s) {
1215 mStatus = BAD_INDEX;
1216 return *this;
1217 }
1218 s->what |= layer_state_t::eAcquireFenceChanged;
1219 s->acquireFence = fence;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001220
1221 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 10:12:20 -07001222 return *this;
1223}
1224
1225SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setDataspace(
1226 const sp<SurfaceControl>& sc, ui::Dataspace dataspace) {
1227 layer_state_t* s = getLayerState(sc);
1228 if (!s) {
1229 mStatus = BAD_INDEX;
1230 return *this;
1231 }
1232 s->what |= layer_state_t::eDataspaceChanged;
1233 s->dataspace = dataspace;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001234
1235 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 10:12:20 -07001236 return *this;
1237}
1238
1239SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setHdrMetadata(
1240 const sp<SurfaceControl>& sc, const HdrMetadata& hdrMetadata) {
1241 layer_state_t* s = getLayerState(sc);
1242 if (!s) {
1243 mStatus = BAD_INDEX;
1244 return *this;
1245 }
1246 s->what |= layer_state_t::eHdrMetadataChanged;
1247 s->hdrMetadata = hdrMetadata;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001248
1249 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 10:12:20 -07001250 return *this;
1251}
1252
1253SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setSurfaceDamageRegion(
1254 const sp<SurfaceControl>& sc, const Region& surfaceDamageRegion) {
1255 layer_state_t* s = getLayerState(sc);
1256 if (!s) {
1257 mStatus = BAD_INDEX;
1258 return *this;
1259 }
1260 s->what |= layer_state_t::eSurfaceDamageRegionChanged;
1261 s->surfaceDamageRegion = surfaceDamageRegion;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001262
1263 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 10:12:20 -07001264 return *this;
1265}
1266
1267SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setApi(
1268 const sp<SurfaceControl>& sc, int32_t api) {
1269 layer_state_t* s = getLayerState(sc);
1270 if (!s) {
1271 mStatus = BAD_INDEX;
1272 return *this;
1273 }
1274 s->what |= layer_state_t::eApiChanged;
1275 s->api = api;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001276
1277 registerSurfaceControlForCallback(sc);
Marissa Wall61c58622018-07-18 10:12:20 -07001278 return *this;
1279}
1280
1281SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setSidebandStream(
1282 const sp<SurfaceControl>& sc, const sp<NativeHandle>& sidebandStream) {
1283 layer_state_t* s = getLayerState(sc);
1284 if (!s) {
1285 mStatus = BAD_INDEX;
1286 return *this;
1287 }
1288 s->what |= layer_state_t::eSidebandStreamChanged;
1289 s->sidebandStream = sidebandStream;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001290
1291 registerSurfaceControlForCallback(sc);
1292 return *this;
1293}
1294
Marissa Wall17b4e452018-12-26 16:32:34 -08001295SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setDesiredPresentTime(
1296 nsecs_t desiredPresentTime) {
1297 mDesiredPresentTime = desiredPresentTime;
1298 return *this;
1299}
1300
Peiyong Linc502cb72019-03-01 15:00:23 -08001301SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setColorSpaceAgnostic(
1302 const sp<SurfaceControl>& sc, const bool agnostic) {
1303 layer_state_t* s = getLayerState(sc);
1304 if (!s) {
1305 mStatus = BAD_INDEX;
1306 return *this;
1307 }
1308 s->what |= layer_state_t::eColorSpaceAgnosticChanged;
1309 s->colorSpaceAgnostic = agnostic;
1310
1311 registerSurfaceControlForCallback(sc);
1312 return *this;
1313}
1314
Marissa Wallc837b5e2018-10-12 10:04:44 -07001315SurfaceComposerClient::Transaction&
Ana Krulecc84d09b2019-11-02 23:10:29 +01001316SurfaceComposerClient::Transaction::setFrameRateSelectionPriority(const sp<SurfaceControl>& sc,
1317 int32_t priority) {
1318 layer_state_t* s = getLayerState(sc);
1319 if (!s) {
1320 mStatus = BAD_INDEX;
1321 return *this;
1322 }
1323
1324 s->what |= layer_state_t::eFrameRateSelectionPriority;
1325 s->frameRateSelectionPriority = priority;
1326
1327 registerSurfaceControlForCallback(sc);
1328 return *this;
1329}
1330
1331SurfaceComposerClient::Transaction&
Marissa Wallc837b5e2018-10-12 10:04:44 -07001332SurfaceComposerClient::Transaction::addTransactionCompletedCallback(
Marissa Walle2ffb422018-10-12 11:33:52 -07001333 TransactionCompletedCallbackTakesContext callback, void* callbackContext) {
Marissa Wallc837b5e2018-10-12 10:04:44 -07001334 auto listener = TransactionCompletedListener::getInstance();
1335
Marissa Wall80d94ad2019-01-18 16:04:36 -08001336 auto callbackWithContext = std::bind(callback, callbackContext, std::placeholders::_1,
1337 std::placeholders::_2, std::placeholders::_3);
1338 const auto& surfaceControls =
1339 mListenerCallbacks[TransactionCompletedListener::getIInstance()].surfaceControls;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001340
Marissa Wall80d94ad2019-01-18 16:04:36 -08001341 CallbackId callbackId = listener->addCallbackFunction(callbackWithContext, surfaceControls);
Marissa Wallc837b5e2018-10-12 10:04:44 -07001342
1343 mListenerCallbacks[TransactionCompletedListener::getIInstance()].callbackIds.emplace(
1344 callbackId);
Marissa Wall61c58622018-07-18 10:12:20 -07001345 return *this;
1346}
1347
Valerie Hau871d6352020-01-29 08:44:02 -08001348SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::notifyProducerDisconnect(
1349 const sp<SurfaceControl>& sc) {
1350 layer_state_t* s = getLayerState(sc);
1351 if (!s) {
1352 mStatus = BAD_INDEX;
1353 return *this;
1354 }
1355
1356 s->what |= layer_state_t::eProducerDisconnect;
1357 return *this;
1358}
1359
Vishnu Nair6b7c5c92020-09-29 17:27:05 -07001360SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrameNumber(
1361 const sp<SurfaceControl>& sc, uint64_t frameNumber) {
1362 layer_state_t* s = getLayerState(sc);
1363 if (!s) {
1364 mStatus = BAD_INDEX;
1365 return *this;
1366 }
1367
1368 s->what |= layer_state_t::eFrameNumberChanged;
1369 s->frameNumber = frameNumber;
1370
1371 return *this;
1372}
1373
Robert Carr4cdc58f2017-08-23 14:22:20 -07001374SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::detachChildren(
1375 const sp<SurfaceControl>& sc) {
chaviw763ef572018-02-22 16:04:57 -08001376 layer_state_t* s = getLayerState(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001377 if (!s) {
1378 mStatus = BAD_INDEX;
Greg Kaiserd45fdc32019-04-30 06:14:19 -07001379 return *this;
Robert Carr9524cb32017-02-13 11:32:32 -08001380 }
1381 s->what |= layer_state_t::eDetachChildren;
Marissa Wallc837b5e2018-10-12 10:04:44 -07001382
1383 registerSurfaceControlForCallback(sc);
Robert Carr4cdc58f2017-08-23 14:22:20 -07001384 return *this;
Robert Carr9524cb32017-02-13 11:32:32 -08001385}
1386
Robert Carr2c358bf2018-08-08 15:58:15 -07001387#ifndef NO_INPUT
1388SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setInputWindowInfo(
1389 const sp<SurfaceControl>& sc,
1390 const InputWindowInfo& info) {
1391 layer_state_t* s = getLayerState(sc);
1392 if (!s) {
1393 mStatus = BAD_INDEX;
1394 return *this;
1395 }
Chris Ye0783e992020-06-02 21:34:49 -07001396 s->inputHandle = new InputWindowHandle(info);
Robert Carr2c358bf2018-08-08 15:58:15 -07001397 s->what |= layer_state_t::eInputInfoChanged;
1398 return *this;
1399}
chaviw273171b2018-12-26 11:46:30 -08001400
Vishnu Naire798b472020-07-23 13:52:21 -07001401SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFocusedWindow(
Vishnu Nair958da932020-08-21 17:12:37 -07001402 const sp<IBinder>& token, const sp<IBinder>& focusedToken, nsecs_t timestampNanos,
1403 int32_t displayId) {
Vishnu Naire798b472020-07-23 13:52:21 -07001404 FocusRequest request;
1405 request.token = token;
1406 request.focusedToken = focusedToken;
1407 request.timestamp = timestampNanos;
Vishnu Nair958da932020-08-21 17:12:37 -07001408 request.displayId = displayId;
Vishnu Naire798b472020-07-23 13:52:21 -07001409 return setFocusedWindow(request);
1410}
1411
1412SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFocusedWindow(
1413 const FocusRequest& request) {
1414 mInputWindowCommands.focusRequests.push_back(request);
1415 return *this;
1416}
1417
chaviwa911b102019-02-14 10:18:33 -08001418SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::syncInputWindows() {
1419 mInputWindowCommands.syncInputWindows = true;
1420 return *this;
1421}
1422
Robert Carr2c358bf2018-08-08 15:58:15 -07001423#endif
1424
Peiyong Lind3788632018-09-18 16:01:31 -07001425SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setColorTransform(
1426 const sp<SurfaceControl>& sc, const mat3& matrix, const vec3& translation) {
1427 layer_state_t* s = getLayerState(sc);
1428 if (!s) {
1429 mStatus = BAD_INDEX;
1430 return *this;
1431 }
1432 s->what |= layer_state_t::eColorTransformChanged;
1433 s->colorTransform = mat4(matrix, translation);
Marissa Wallc837b5e2018-10-12 10:04:44 -07001434
1435 registerSurfaceControlForCallback(sc);
Peiyong Lind3788632018-09-18 16:01:31 -07001436 return *this;
1437}
1438
Robert Carrfb4d58b2019-01-15 09:21:27 -08001439SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setGeometry(
1440 const sp<SurfaceControl>& sc, const Rect& source, const Rect& dst, int transform) {
1441 setCrop_legacy(sc, source);
1442
1443 int x = dst.left;
1444 int y = dst.top;
Robert Carr66365e42019-04-08 16:58:04 -07001445
1446 float sourceWidth = source.getWidth();
1447 float sourceHeight = source.getHeight();
1448
1449 float xScale = sourceWidth < 0 ? 1.0f : dst.getWidth() / sourceWidth;
1450 float yScale = sourceHeight < 0 ? 1.0f : dst.getHeight() / sourceHeight;
Robert Carrfb4d58b2019-01-15 09:21:27 -08001451 float matrix[4] = {1, 0, 0, 1};
1452
1453 switch (transform) {
1454 case NATIVE_WINDOW_TRANSFORM_FLIP_H:
1455 matrix[0] = -xScale; matrix[1] = 0;
1456 matrix[2] = 0; matrix[3] = yScale;
1457 x += source.getWidth();
1458 break;
1459 case NATIVE_WINDOW_TRANSFORM_FLIP_V:
1460 matrix[0] = xScale; matrix[1] = 0;
1461 matrix[2] = 0; matrix[3] = -yScale;
1462 y += source.getHeight();
1463 break;
1464 case NATIVE_WINDOW_TRANSFORM_ROT_90:
1465 matrix[0] = 0; matrix[1] = -yScale;
1466 matrix[2] = xScale; matrix[3] = 0;
1467 x += source.getHeight();
1468 break;
1469 case NATIVE_WINDOW_TRANSFORM_ROT_180:
1470 matrix[0] = -xScale; matrix[1] = 0;
1471 matrix[2] = 0; matrix[3] = -yScale;
1472 x += source.getWidth();
1473 y += source.getHeight();
1474 break;
1475 case NATIVE_WINDOW_TRANSFORM_ROT_270:
1476 matrix[0] = 0; matrix[1] = yScale;
1477 matrix[2] = -xScale; matrix[3] = 0;
1478 y += source.getWidth();
1479 break;
1480 default:
1481 matrix[0] = xScale; matrix[1] = 0;
1482 matrix[2] = 0; matrix[3] = yScale;
1483 break;
1484 }
1485 setMatrix(sc, matrix[0], matrix[1], matrix[2], matrix[3]);
chaviw76f5f2f2019-09-23 10:15:51 -07001486 float offsetX = xScale * source.left;
1487 float offsetY = yScale * source.top;
1488 setPosition(sc, x - offsetX, y - offsetY);
Robert Carrfb4d58b2019-01-15 09:21:27 -08001489
1490 return *this;
1491}
1492
Vishnu Nairc97b8db2019-10-29 18:19:35 -07001493SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setShadowRadius(
1494 const sp<SurfaceControl>& sc, float shadowRadius) {
1495 layer_state_t* s = getLayerState(sc);
1496 if (!s) {
1497 mStatus = BAD_INDEX;
1498 return *this;
1499 }
1500 s->what |= layer_state_t::eShadowRadiusChanged;
1501 s->shadowRadius = shadowRadius;
1502 return *this;
1503}
1504
Steven Thomas3172e202020-01-06 19:25:30 -08001505SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrameRate(
Marin Shalamanov46084422020-10-13 12:33:42 +02001506 const sp<SurfaceControl>& sc, float frameRate, int8_t compatibility,
1507 bool shouldBeSeamless) {
Steven Thomas3172e202020-01-06 19:25:30 -08001508 layer_state_t* s = getLayerState(sc);
1509 if (!s) {
1510 mStatus = BAD_INDEX;
1511 return *this;
1512 }
Steven Thomas62a4cf82020-01-31 12:04:03 -08001513 if (!ValidateFrameRate(frameRate, compatibility, "Transaction::setFrameRate")) {
1514 mStatus = BAD_VALUE;
1515 return *this;
1516 }
Steven Thomas3172e202020-01-06 19:25:30 -08001517 s->what |= layer_state_t::eFrameRateChanged;
1518 s->frameRate = frameRate;
Steven Thomas62a4cf82020-01-31 12:04:03 -08001519 s->frameRateCompatibility = compatibility;
Marin Shalamanov46084422020-10-13 12:33:42 +02001520 s->shouldBeSeamless = shouldBeSeamless;
Steven Thomas3172e202020-01-06 19:25:30 -08001521 return *this;
1522}
1523
Vishnu Nair6213bd92020-05-08 17:42:25 -07001524SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFixedTransformHint(
1525 const sp<SurfaceControl>& sc, int32_t fixedTransformHint) {
1526 layer_state_t* s = getLayerState(sc);
1527 if (!s) {
1528 mStatus = BAD_INDEX;
1529 return *this;
1530 }
1531
1532 const ui::Transform::RotationFlags transform = fixedTransformHint == -1
1533 ? ui::Transform::ROT_INVALID
1534 : ui::Transform::toRotationFlags(static_cast<ui::Rotation>(fixedTransformHint));
1535 s->what |= layer_state_t::eFixedTransformHintChanged;
1536 s->fixedTransformHint = transform;
1537 return *this;
1538}
1539
Ady Abraham22c7b5c2020-09-22 19:33:40 -07001540SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrameTimelineVsync(
1541 int64_t frameTimelineVsyncId) {
1542 mFrameTimelineVsyncId = frameTimelineVsyncId;
1543 return *this;
1544}
1545
Robert Carr9b611b72020-10-19 12:00:23 -07001546SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setFrameTimelineVsync(
1547 const sp<SurfaceControl>& sc, int64_t frameTimelineVsyncId) {
1548 layer_state_t* s = getLayerState(sc);
1549 if (!s) {
1550 mStatus = BAD_INDEX;
1551 return *this;
1552 }
1553
1554 s->what |= layer_state_t::eFrameTimelineVsyncChanged;
1555 s->frameTimelineVsyncId = frameTimelineVsyncId;
1556 return *this;
1557}
1558
Vishnu Naircf26a0a2020-11-13 12:56:20 -08001559SurfaceComposerClient::Transaction& SurfaceComposerClient::Transaction::setAutoRefresh(
1560 const sp<SurfaceControl>& sc, bool autoRefresh) {
1561 layer_state_t* s = getLayerState(sc);
1562 if (!s) {
1563 mStatus = BAD_INDEX;
1564 return *this;
1565 }
1566
1567 s->what |= layer_state_t::eAutoRefreshChanged;
1568 s->autoRefresh = autoRefresh;
1569 return *this;
1570}
1571
Mathias Agopian698c0872011-06-28 19:09:31 -07001572// ---------------------------------------------------------------------------
1573
chaviw763ef572018-02-22 16:04:57 -08001574DisplayState& SurfaceComposerClient::Transaction::getDisplayState(const sp<IBinder>& token) {
Mathias Agopiane57f2922012-08-09 16:29:12 -07001575 DisplayState s;
1576 s.token = token;
1577 ssize_t index = mDisplayStates.indexOf(s);
1578 if (index < 0) {
1579 // we don't have it, add an initialized layer_state to our list
1580 s.what = 0;
1581 index = mDisplayStates.add(s);
1582 }
Dan Stozad723bd72014-11-18 10:24:03 -08001583 return mDisplayStates.editItemAt(static_cast<size_t>(index));
Mathias Agopiane57f2922012-08-09 16:29:12 -07001584}
1585
Robert Carr4cdc58f2017-08-23 14:22:20 -07001586status_t SurfaceComposerClient::Transaction::setDisplaySurface(const sp<IBinder>& token,
1587 const sp<IGraphicBufferProducer>& bufferProducer) {
Pablo Ceballoseddbef82016-09-01 11:21:21 -07001588 if (bufferProducer.get() != nullptr) {
1589 // Make sure that composition can never be stalled by a virtual display
1590 // consumer that isn't processing buffers fast enough.
1591 status_t err = bufferProducer->setAsyncMode(true);
1592 if (err != NO_ERROR) {
1593 ALOGE("Composer::setDisplaySurface Failed to enable async mode on the "
1594 "BufferQueue. This BufferQueue cannot be used for virtual "
1595 "display. (%d)", err);
1596 return err;
1597 }
Pablo Ceballos1aad24c2016-08-04 10:24:22 -07001598 }
chaviw763ef572018-02-22 16:04:57 -08001599 DisplayState& s(getDisplayState(token));
Andy McFadden2adaf042012-12-18 09:49:45 -08001600 s.surface = bufferProducer;
Mathias Agopiane57f2922012-08-09 16:29:12 -07001601 s.what |= DisplayState::eSurfaceChanged;
Pablo Ceballos1aad24c2016-08-04 10:24:22 -07001602 return NO_ERROR;
Mathias Agopiane57f2922012-08-09 16:29:12 -07001603}
1604
Robert Carr4cdc58f2017-08-23 14:22:20 -07001605void SurfaceComposerClient::Transaction::setDisplayLayerStack(const sp<IBinder>& token,
Mathias Agopiane57f2922012-08-09 16:29:12 -07001606 uint32_t layerStack) {
chaviw763ef572018-02-22 16:04:57 -08001607 DisplayState& s(getDisplayState(token));
Mathias Agopiane57f2922012-08-09 16:29:12 -07001608 s.layerStack = layerStack;
1609 s.what |= DisplayState::eLayerStackChanged;
1610}
1611
Robert Carr4cdc58f2017-08-23 14:22:20 -07001612void SurfaceComposerClient::Transaction::setDisplayProjection(const sp<IBinder>& token,
Dominik Laskowski718f9602019-11-09 20:01:35 -08001613 ui::Rotation orientation,
1614 const Rect& layerStackRect,
1615 const Rect& displayRect) {
chaviw763ef572018-02-22 16:04:57 -08001616 DisplayState& s(getDisplayState(token));
Mathias Agopiane57f2922012-08-09 16:29:12 -07001617 s.orientation = orientation;
Marin Shalamanov6ad317c2020-07-29 23:34:07 +02001618 s.layerStackSpaceRect = layerStackRect;
1619 s.orientedDisplaySpaceRect = displayRect;
Mathias Agopian00e8c7a2012-09-04 19:30:46 -07001620 s.what |= DisplayState::eDisplayProjectionChanged;
Jorim Jaggi092123c2016-04-13 01:40:35 +00001621 mForceSynchronous = true; // TODO: do we actually still need this?
Mathias Agopiane57f2922012-08-09 16:29:12 -07001622}
1623
Robert Carr4cdc58f2017-08-23 14:22:20 -07001624void SurfaceComposerClient::Transaction::setDisplaySize(const sp<IBinder>& token, uint32_t width, uint32_t height) {
chaviw763ef572018-02-22 16:04:57 -08001625 DisplayState& s(getDisplayState(token));
Michael Wright1f6078a2014-06-26 16:01:02 -07001626 s.width = width;
1627 s.height = height;
1628 s.what |= DisplayState::eDisplaySizeChanged;
1629}
1630
Mathias Agopiane57f2922012-08-09 16:29:12 -07001631// ---------------------------------------------------------------------------
1632
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001633SurfaceComposerClient::SurfaceComposerClient()
Robert Carr4cdc58f2017-08-23 14:22:20 -07001634 : mStatus(NO_INIT)
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001635{
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001636}
1637
Jorim Jaggif3cf4bc2017-11-30 14:19:23 +01001638SurfaceComposerClient::SurfaceComposerClient(const sp<ISurfaceComposerClient>& client)
1639 : mStatus(NO_ERROR), mClient(client)
1640{
1641}
1642
Mathias Agopian698c0872011-06-28 19:09:31 -07001643void SurfaceComposerClient::onFirstRef() {
Robert Carr4cdc58f2017-08-23 14:22:20 -07001644 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
Yi Kong48a619f2018-06-05 16:34:59 -07001645 if (sf != nullptr && mStatus == NO_INIT) {
Robert Carr1db73f62016-12-21 12:58:51 -08001646 sp<ISurfaceComposerClient> conn;
Robert Carrb89ea9d2018-12-10 13:01:14 -08001647 conn = sf->createConnection();
Yi Kong48a619f2018-06-05 16:34:59 -07001648 if (conn != nullptr) {
Mathias Agopiand4784a32010-05-27 19:41:15 -07001649 mClient = conn;
Mathias Agopiand4784a32010-05-27 19:41:15 -07001650 mStatus = NO_ERROR;
1651 }
1652 }
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001653}
1654
Mathias Agopian698c0872011-06-28 19:09:31 -07001655SurfaceComposerClient::~SurfaceComposerClient() {
Mathias Agopian631f3582010-05-25 17:51:34 -07001656 dispose();
1657}
Mathias Agopiandd3423c2009-09-23 15:44:05 -07001658
Mathias Agopian698c0872011-06-28 19:09:31 -07001659status_t SurfaceComposerClient::initCheck() const {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001660 return mStatus;
1661}
1662
Mathias Agopian698c0872011-06-28 19:09:31 -07001663sp<IBinder> SurfaceComposerClient::connection() const {
Marco Nelissen2ea926b2014-11-14 08:01:01 -08001664 return IInterface::asBinder(mClient);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001665}
1666
Mathias Agopiand4784a32010-05-27 19:41:15 -07001667status_t SurfaceComposerClient::linkToComposerDeath(
1668 const sp<IBinder::DeathRecipient>& recipient,
Mathias Agopian698c0872011-06-28 19:09:31 -07001669 void* cookie, uint32_t flags) {
Robert Carr4cdc58f2017-08-23 14:22:20 -07001670 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
1671 return IInterface::asBinder(sf)->linkToDeath(recipient, cookie, flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001672}
1673
Mathias Agopian698c0872011-06-28 19:09:31 -07001674void SurfaceComposerClient::dispose() {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001675 // this can be called more than once.
Mathias Agopian7e27f052010-05-28 14:22:23 -07001676 sp<ISurfaceComposerClient> client;
Mathias Agopiand4784a32010-05-27 19:41:15 -07001677 Mutex::Autolock _lm(mLock);
Yi Kong48a619f2018-06-05 16:34:59 -07001678 if (mClient != nullptr) {
Mathias Agopiand4784a32010-05-27 19:41:15 -07001679 client = mClient; // hold ref while lock is held
1680 mClient.clear();
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001681 }
Mathias Agopiand4784a32010-05-27 19:41:15 -07001682 mStatus = NO_INIT;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001683}
1684
Evan Rosky1f6d6d52018-12-06 10:47:26 -08001685sp<SurfaceControl> SurfaceComposerClient::createSurface(const String8& name, uint32_t w, uint32_t h,
1686 PixelFormat format, uint32_t flags,
Vishnu Nair992496b2020-10-22 17:27:21 -07001687 const sp<IBinder>& parentHandle,
Valerie Hau1acd6962019-10-28 16:35:48 -07001688 LayerMetadata metadata,
1689 uint32_t* outTransformHint) {
Robert Carr3b382ed2018-03-14 13:49:41 -07001690 sp<SurfaceControl> s;
Vishnu Nair992496b2020-10-22 17:27:21 -07001691 createSurfaceChecked(name, w, h, format, &s, flags, parentHandle, std::move(metadata),
Valerie Hau1acd6962019-10-28 16:35:48 -07001692 outTransformHint);
Robert Carr3b382ed2018-03-14 13:49:41 -07001693 return s;
1694}
1695
Marissa Wall35187b32019-01-08 10:08:52 -08001696sp<SurfaceControl> SurfaceComposerClient::createWithSurfaceParent(const String8& name, uint32_t w,
1697 uint32_t h, PixelFormat format,
1698 uint32_t flags, Surface* parent,
Valerie Hau1acd6962019-10-28 16:35:48 -07001699 LayerMetadata metadata,
1700 uint32_t* outTransformHint) {
Marissa Wall35187b32019-01-08 10:08:52 -08001701 sp<SurfaceControl> sur;
1702 status_t err = mStatus;
1703
1704 if (mStatus == NO_ERROR) {
1705 sp<IBinder> handle;
1706 sp<IGraphicBufferProducer> parentGbp = parent->getIGraphicBufferProducer();
1707 sp<IGraphicBufferProducer> gbp;
1708
Valerie Hau1acd6962019-10-28 16:35:48 -07001709 uint32_t transformHint = 0;
Pablo Gamito2ec1f7b2020-09-01 14:18:49 +00001710 int32_t id = -1;
Evan Rosky1f6d6d52018-12-06 10:47:26 -08001711 err = mClient->createWithSurfaceParent(name, w, h, format, flags, parentGbp,
Pablo Gamito2ec1f7b2020-09-01 14:18:49 +00001712 std::move(metadata), &handle, &gbp, &id,
1713 &transformHint);
Valerie Hau1acd6962019-10-28 16:35:48 -07001714 if (outTransformHint) {
1715 *outTransformHint = transformHint;
1716 }
Marissa Wall35187b32019-01-08 10:08:52 -08001717 ALOGE_IF(err, "SurfaceComposerClient::createWithSurfaceParent error %s", strerror(-err));
1718 if (err == NO_ERROR) {
Pablo Gamitodbc31672020-09-01 18:28:58 +00001719 return new SurfaceControl(this, handle, gbp, id, transformHint);
Marissa Wall35187b32019-01-08 10:08:52 -08001720 }
1721 }
1722 return nullptr;
1723}
1724
Evan Rosky1f6d6d52018-12-06 10:47:26 -08001725status_t SurfaceComposerClient::createSurfaceChecked(const String8& name, uint32_t w, uint32_t h,
1726 PixelFormat format,
1727 sp<SurfaceControl>* outSurface, uint32_t flags,
Vishnu Nair992496b2020-10-22 17:27:21 -07001728 const sp<IBinder>& parentHandle,
1729 LayerMetadata metadata,
Valerie Hau1acd6962019-10-28 16:35:48 -07001730 uint32_t* outTransformHint) {
Mathias Agopian4d9b8222013-03-12 17:11:48 -07001731 sp<SurfaceControl> sur;
Robert Carr740eaf02018-03-27 12:59:18 -07001732 status_t err = mStatus;
Robert Carr3b382ed2018-03-14 13:49:41 -07001733
Mathias Agopian698c0872011-06-28 19:09:31 -07001734 if (mStatus == NO_ERROR) {
Mathias Agopian4d9b8222013-03-12 17:11:48 -07001735 sp<IBinder> handle;
1736 sp<IGraphicBufferProducer> gbp;
Robert Carr1f0a16a2016-10-24 16:27:39 -07001737
Valerie Hau1acd6962019-10-28 16:35:48 -07001738 uint32_t transformHint = 0;
Pablo Gamito2ec1f7b2020-09-01 14:18:49 +00001739 int32_t id = -1;
Evan Rosky1f6d6d52018-12-06 10:47:26 -08001740 err = mClient->createSurface(name, w, h, format, flags, parentHandle, std::move(metadata),
Pablo Gamito2ec1f7b2020-09-01 14:18:49 +00001741 &handle, &gbp, &id, &transformHint);
1742
Valerie Hau1acd6962019-10-28 16:35:48 -07001743 if (outTransformHint) {
1744 *outTransformHint = transformHint;
1745 }
Mathias Agopian4d9b8222013-03-12 17:11:48 -07001746 ALOGE_IF(err, "SurfaceComposerClient::createSurface error %s", strerror(-err));
1747 if (err == NO_ERROR) {
Pablo Gamitodbc31672020-09-01 18:28:58 +00001748 *outSurface = new SurfaceControl(this, handle, gbp, id, transformHint);
Mathias Agopian698c0872011-06-28 19:09:31 -07001749 }
1750 }
Robert Carr3b382ed2018-03-14 13:49:41 -07001751 return err;
Mathias Agopian698c0872011-06-28 19:09:31 -07001752}
1753
chaviwfe94a222019-08-21 13:52:59 -07001754sp<SurfaceControl> SurfaceComposerClient::mirrorSurface(SurfaceControl* mirrorFromSurface) {
1755 if (mirrorFromSurface == nullptr) {
1756 return nullptr;
1757 }
1758
1759 sp<IBinder> handle;
1760 sp<IBinder> mirrorFromHandle = mirrorFromSurface->getHandle();
Pablo Gamito2ec1f7b2020-09-01 14:18:49 +00001761 int32_t layer_id = -1;
1762 status_t err = mClient->mirrorSurface(mirrorFromHandle, &handle, &layer_id);
chaviwfe94a222019-08-21 13:52:59 -07001763 if (err == NO_ERROR) {
Pablo Gamitodbc31672020-09-01 18:28:58 +00001764 return new SurfaceControl(this, handle, nullptr, layer_id, true /* owned */);
chaviwfe94a222019-08-21 13:52:59 -07001765 }
1766 return nullptr;
1767}
1768
Svetoslavd85084b2014-03-20 10:28:31 -07001769status_t SurfaceComposerClient::clearLayerFrameStats(const sp<IBinder>& token) const {
1770 if (mStatus != NO_ERROR) {
1771 return mStatus;
1772 }
1773 return mClient->clearLayerFrameStats(token);
1774}
1775
1776status_t SurfaceComposerClient::getLayerFrameStats(const sp<IBinder>& token,
1777 FrameStats* outStats) const {
1778 if (mStatus != NO_ERROR) {
1779 return mStatus;
1780 }
1781 return mClient->getLayerFrameStats(token, outStats);
1782}
1783
Mathias Agopian698c0872011-06-28 19:09:31 -07001784// ----------------------------------------------------------------------------
1785
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -07001786status_t SurfaceComposerClient::enableVSyncInjections(bool enable) {
Robert Carr4cdc58f2017-08-23 14:22:20 -07001787 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
1788 return sf->enableVSyncInjections(enable);
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -07001789}
1790
1791status_t SurfaceComposerClient::injectVSync(nsecs_t when) {
Robert Carr4cdc58f2017-08-23 14:22:20 -07001792 sp<ISurfaceComposer> sf(ComposerService::getComposerService());
1793 return sf->injectVSync(when);
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -07001794}
1795
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -08001796status_t SurfaceComposerClient::getDisplayState(const sp<IBinder>& display,
1797 ui::DisplayState* state) {
1798 return ComposerService::getComposerService()->getDisplayState(display, state);
1799}
1800
1801status_t SurfaceComposerClient::getDisplayInfo(const sp<IBinder>& display, DisplayInfo* info) {
1802 return ComposerService::getComposerService()->getDisplayInfo(display, info);
1803}
1804
1805status_t SurfaceComposerClient::getDisplayConfigs(const sp<IBinder>& display,
1806 Vector<DisplayConfig>* configs) {
Dan Stoza7f7da322014-05-02 15:26:25 -07001807 return ComposerService::getComposerService()->getDisplayConfigs(display, configs);
1808}
1809
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -08001810status_t SurfaceComposerClient::getActiveDisplayConfig(const sp<IBinder>& display,
1811 DisplayConfig* config) {
1812 Vector<DisplayConfig> configs;
Dan Stoza7f7da322014-05-02 15:26:25 -07001813 status_t result = getDisplayConfigs(display, &configs);
1814 if (result != NO_ERROR) {
1815 return result;
1816 }
1817
1818 int activeId = getActiveConfig(display);
1819 if (activeId < 0) {
1820 ALOGE("No active configuration found");
1821 return NAME_NOT_FOUND;
1822 }
1823
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -08001824 *config = configs[static_cast<size_t>(activeId)];
Dan Stoza7f7da322014-05-02 15:26:25 -07001825 return NO_ERROR;
1826}
1827
1828int SurfaceComposerClient::getActiveConfig(const sp<IBinder>& display) {
1829 return ComposerService::getComposerService()->getActiveConfig(display);
1830}
1831
Marin Shalamanov30b0b3c2020-10-13 19:15:06 +02001832status_t SurfaceComposerClient::setDesiredDisplayConfigSpecs(
1833 const sp<IBinder>& displayToken, int32_t defaultConfig, bool allowGroupSwitching,
1834 float primaryRefreshRateMin, float primaryRefreshRateMax, float appRequestRefreshRateMin,
1835 float appRequestRefreshRateMax) {
Steven Thomasf734df42020-04-13 21:09:28 -07001836 return ComposerService::getComposerService()
Marin Shalamanov30b0b3c2020-10-13 19:15:06 +02001837 ->setDesiredDisplayConfigSpecs(displayToken, defaultConfig, allowGroupSwitching,
1838 primaryRefreshRateMin, primaryRefreshRateMax,
1839 appRequestRefreshRateMin, appRequestRefreshRateMax);
Ana Krulec0782b882019-10-15 17:34:54 -07001840}
1841
Marin Shalamanov30b0b3c2020-10-13 19:15:06 +02001842status_t SurfaceComposerClient::getDesiredDisplayConfigSpecs(
1843 const sp<IBinder>& displayToken, int32_t* outDefaultConfig, bool* outAllowGroupSwitching,
1844 float* outPrimaryRefreshRateMin, float* outPrimaryRefreshRateMax,
1845 float* outAppRequestRefreshRateMin, float* outAppRequestRefreshRateMax) {
Steven Thomasf734df42020-04-13 21:09:28 -07001846 return ComposerService::getComposerService()
Marin Shalamanov30b0b3c2020-10-13 19:15:06 +02001847 ->getDesiredDisplayConfigSpecs(displayToken, outDefaultConfig, outAllowGroupSwitching,
1848 outPrimaryRefreshRateMin, outPrimaryRefreshRateMax,
1849 outAppRequestRefreshRateMin,
Steven Thomasf734df42020-04-13 21:09:28 -07001850 outAppRequestRefreshRateMax);
Ana Krulec234bb162019-11-10 22:55:55 +01001851}
1852
Michael Wright28f24d02016-07-12 13:30:53 -07001853status_t SurfaceComposerClient::getDisplayColorModes(const sp<IBinder>& display,
Peiyong Lina52f0292018-03-14 17:26:31 -07001854 Vector<ColorMode>* outColorModes) {
Michael Wright28f24d02016-07-12 13:30:53 -07001855 return ComposerService::getComposerService()->getDisplayColorModes(display, outColorModes);
1856}
1857
Daniel Solomon42d04562019-01-20 21:03:19 -08001858status_t SurfaceComposerClient::getDisplayNativePrimaries(const sp<IBinder>& display,
1859 ui::DisplayPrimaries& outPrimaries) {
1860 return ComposerService::getComposerService()->getDisplayNativePrimaries(display, outPrimaries);
1861}
1862
Peiyong Lina52f0292018-03-14 17:26:31 -07001863ColorMode SurfaceComposerClient::getActiveColorMode(const sp<IBinder>& display) {
Michael Wright28f24d02016-07-12 13:30:53 -07001864 return ComposerService::getComposerService()->getActiveColorMode(display);
1865}
1866
1867status_t SurfaceComposerClient::setActiveColorMode(const sp<IBinder>& display,
Peiyong Lina52f0292018-03-14 17:26:31 -07001868 ColorMode colorMode) {
Michael Wright28f24d02016-07-12 13:30:53 -07001869 return ComposerService::getComposerService()->setActiveColorMode(display, colorMode);
1870}
1871
Galia Peycheva5492cb52019-10-30 14:13:16 +01001872bool SurfaceComposerClient::getAutoLowLatencyModeSupport(const sp<IBinder>& display) {
1873 bool supported = false;
1874 ComposerService::getComposerService()->getAutoLowLatencyModeSupport(display, &supported);
1875 return supported;
1876}
1877
1878void SurfaceComposerClient::setAutoLowLatencyMode(const sp<IBinder>& display, bool on) {
1879 ComposerService::getComposerService()->setAutoLowLatencyMode(display, on);
1880}
1881
1882bool SurfaceComposerClient::getGameContentTypeSupport(const sp<IBinder>& display) {
1883 bool supported = false;
1884 ComposerService::getComposerService()->getGameContentTypeSupport(display, &supported);
1885 return supported;
1886}
1887
1888void SurfaceComposerClient::setGameContentType(const sp<IBinder>& display, bool on) {
1889 ComposerService::getComposerService()->setGameContentType(display, on);
1890}
1891
Prashant Malani2c9b11f2014-05-25 01:36:31 -07001892void SurfaceComposerClient::setDisplayPowerMode(const sp<IBinder>& token,
1893 int mode) {
1894 ComposerService::getComposerService()->setPowerMode(token, mode);
Jeff Brown2a09bb32012-10-08 19:13:57 -07001895}
1896
Peiyong Linc6780972018-10-28 15:24:08 -07001897status_t SurfaceComposerClient::getCompositionPreference(
1898 ui::Dataspace* defaultDataspace, ui::PixelFormat* defaultPixelFormat,
1899 ui::Dataspace* wideColorGamutDataspace, ui::PixelFormat* wideColorGamutPixelFormat) {
1900 return ComposerService::getComposerService()
1901 ->getCompositionPreference(defaultDataspace, defaultPixelFormat,
1902 wideColorGamutDataspace, wideColorGamutPixelFormat);
Peiyong Lin0256f722018-08-31 15:45:10 -07001903}
1904
Peiyong Lin08d10512019-01-16 13:27:35 -08001905bool SurfaceComposerClient::getProtectedContentSupport() {
1906 bool supported = false;
1907 ComposerService::getComposerService()->getProtectedContentSupport(&supported);
1908 return supported;
1909}
1910
Svetoslavd85084b2014-03-20 10:28:31 -07001911status_t SurfaceComposerClient::clearAnimationFrameStats() {
1912 return ComposerService::getComposerService()->clearAnimationFrameStats();
1913}
1914
1915status_t SurfaceComposerClient::getAnimationFrameStats(FrameStats* outStats) {
1916 return ComposerService::getComposerService()->getAnimationFrameStats(outStats);
1917}
1918
Dan Stozac4f471e2016-03-24 09:31:08 -07001919status_t SurfaceComposerClient::getHdrCapabilities(const sp<IBinder>& display,
1920 HdrCapabilities* outCapabilities) {
1921 return ComposerService::getComposerService()->getHdrCapabilities(display,
1922 outCapabilities);
1923}
1924
Kevin DuBois9c0a1762018-10-16 13:32:31 -07001925status_t SurfaceComposerClient::getDisplayedContentSamplingAttributes(const sp<IBinder>& display,
1926 ui::PixelFormat* outFormat,
1927 ui::Dataspace* outDataspace,
1928 uint8_t* outComponentMask) {
1929 return ComposerService::getComposerService()
1930 ->getDisplayedContentSamplingAttributes(display, outFormat, outDataspace,
1931 outComponentMask);
1932}
1933
Kevin DuBois74e53772018-11-19 10:52:38 -08001934status_t SurfaceComposerClient::setDisplayContentSamplingEnabled(const sp<IBinder>& display,
1935 bool enable, uint8_t componentMask,
1936 uint64_t maxFrames) {
1937 return ComposerService::getComposerService()->setDisplayContentSamplingEnabled(display, enable,
1938 componentMask,
1939 maxFrames);
1940}
1941
Kevin DuBois1d4249a2018-08-29 10:45:14 -07001942status_t SurfaceComposerClient::getDisplayedContentSample(const sp<IBinder>& display,
1943 uint64_t maxFrames, uint64_t timestamp,
1944 DisplayedFrameStats* outStats) {
1945 return ComposerService::getComposerService()->getDisplayedContentSample(display, maxFrames,
1946 timestamp, outStats);
1947}
Marissa Wall35187b32019-01-08 10:08:52 -08001948
Peiyong Lin4f3fddf2019-01-24 17:21:24 -08001949status_t SurfaceComposerClient::isWideColorDisplay(const sp<IBinder>& display,
1950 bool* outIsWideColorDisplay) {
1951 return ComposerService::getComposerService()->isWideColorDisplay(display,
1952 outIsWideColorDisplay);
1953}
1954
Kevin DuBois00c66832019-02-18 16:21:31 -08001955status_t SurfaceComposerClient::addRegionSamplingListener(
1956 const Rect& samplingArea, const sp<IBinder>& stopLayerHandle,
1957 const sp<IRegionSamplingListener>& listener) {
1958 return ComposerService::getComposerService()->addRegionSamplingListener(samplingArea,
1959 stopLayerHandle,
1960 listener);
1961}
1962
1963status_t SurfaceComposerClient::removeRegionSamplingListener(
1964 const sp<IRegionSamplingListener>& listener) {
1965 return ComposerService::getComposerService()->removeRegionSamplingListener(listener);
1966}
1967
Dan Gittik57e63c52019-01-18 16:37:54 +00001968bool SurfaceComposerClient::getDisplayBrightnessSupport(const sp<IBinder>& displayToken) {
1969 bool support = false;
1970 ComposerService::getComposerService()->getDisplayBrightnessSupport(displayToken, &support);
1971 return support;
1972}
1973
1974status_t SurfaceComposerClient::setDisplayBrightness(const sp<IBinder>& displayToken,
1975 float brightness) {
1976 return ComposerService::getComposerService()->setDisplayBrightness(displayToken, brightness);
1977}
1978
Lais Andrade3a6e47d2020-04-02 11:20:16 +01001979status_t SurfaceComposerClient::notifyPowerBoost(int32_t boostId) {
1980 return ComposerService::getComposerService()->notifyPowerBoost(boostId);
Ady Abraham8532d012019-05-08 14:50:56 -07001981}
1982
Vishnu Nairb13bb952019-11-15 10:24:08 -08001983status_t SurfaceComposerClient::setGlobalShadowSettings(const half4& ambientColor,
1984 const half4& spotColor, float lightPosY,
1985 float lightPosZ, float lightRadius) {
1986 return ComposerService::getComposerService()->setGlobalShadowSettings(ambientColor, spotColor,
1987 lightPosY, lightPosZ,
1988 lightRadius);
1989}
1990
Mathias Agopian698c0872011-06-28 19:09:31 -07001991// ----------------------------------------------------------------------------
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001992
chaviw690db382020-07-27 16:46:46 -07001993status_t ScreenshotClient::captureDisplay(const DisplayCaptureArgs& captureArgs,
chaviwe7b9f272020-08-18 16:08:59 -07001994 const sp<IScreenCaptureListener>& captureListener) {
Mathias Agopian2a9fc492013-03-01 13:42:57 -08001995 sp<ISurfaceComposer> s(ComposerService::getComposerService());
Yi Kong48a619f2018-06-05 16:34:59 -07001996 if (s == nullptr) return NO_INIT;
chaviw8ffc7b82020-08-18 11:25:37 -07001997
chaviwe7b9f272020-08-18 16:08:59 -07001998 return s->captureDisplay(captureArgs, captureListener);
Robert Carr673134e2017-01-09 19:48:38 -08001999}
2000
chaviw690db382020-07-27 16:46:46 -07002001status_t ScreenshotClient::captureDisplay(uint64_t displayOrLayerStack,
chaviwe7b9f272020-08-18 16:08:59 -07002002 const sp<IScreenCaptureListener>& captureListener) {
chaviw93df2ea2019-04-30 16:45:12 -07002003 sp<ISurfaceComposer> s(ComposerService::getComposerService());
2004 if (s == nullptr) return NO_INIT;
chaviw8ffc7b82020-08-18 11:25:37 -07002005
chaviwe7b9f272020-08-18 16:08:59 -07002006 return s->captureDisplay(displayOrLayerStack, captureListener);
chaviw93df2ea2019-04-30 16:45:12 -07002007}
2008
chaviw26c52482020-07-28 16:25:52 -07002009status_t ScreenshotClient::captureLayers(const LayerCaptureArgs& captureArgs,
chaviwe7b9f272020-08-18 16:08:59 -07002010 const sp<IScreenCaptureListener>& captureListener) {
chaviwa76b2712017-09-20 12:02:26 -07002011 sp<ISurfaceComposer> s(ComposerService::getComposerService());
Yi Kong48a619f2018-06-05 16:34:59 -07002012 if (s == nullptr) return NO_INIT;
chaviw8ffc7b82020-08-18 11:25:37 -07002013
chaviwe7b9f272020-08-18 16:08:59 -07002014 return s->captureLayers(captureArgs, captureListener);
chaviwa76b2712017-09-20 12:02:26 -07002015}
Dominik Laskowski718f9602019-11-09 20:01:35 -08002016
2017} // namespace android