blob: 891379977a6c1a1f0a326906ee1ed407d3413e7d [file] [log] [blame]
Marissa Wallf6a73fa2018-12-10 10:41:08 -08001/*
2 * Copyright 2018 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
Marissa Wall1be5a102019-01-18 16:14:04 -080017#include <android/hardware/configstore/1.0/ISurfaceFlingerConfigs.h>
Marissa Wallf6a73fa2018-12-10 10:41:08 -080018#include <android/native_window.h>
19#include <android/surface_control.h>
Bo Liu789103b2022-09-15 16:24:31 -040020#include <android/surface_control_jni.h>
21#include <android_runtime/android_view_SurfaceControl.h>
Marissa Wall1be5a102019-01-18 16:14:04 -080022#include <configstore/Utils.h>
Marissa Wall1be5a102019-01-18 16:14:04 -080023#include <gui/HdrMetadata.h>
24#include <gui/ISurfaceComposer.h>
Marissa Wallf6a73fa2018-12-10 10:41:08 -080025#include <gui/Surface.h>
26#include <gui/SurfaceComposerClient.h>
27#include <gui/SurfaceControl.h>
Rachel Leeb6c93aa2022-02-22 15:48:28 -080028#include <private/android/choreographer.h>
29#include <surface_control_private.h>
Marin Shalamanov463ad8e2021-01-28 22:58:37 +010030#include <ui/DynamicDisplayInfo.h>
Marissa Wall1be5a102019-01-18 16:14:04 -080031#include <utils/Timers.h>
32
Bo Liu789103b2022-09-15 16:24:31 -040033#include <utility>
34
Marissa Wall1be5a102019-01-18 16:14:04 -080035using namespace android::hardware::configstore;
36using namespace android::hardware::configstore::V1_0;
Marissa Wallf6a73fa2018-12-10 10:41:08 -080037using namespace android;
38
39using Transaction = SurfaceComposerClient::Transaction;
40
41#define CHECK_NOT_NULL(name) \
42 LOG_ALWAYS_FATAL_IF(name == nullptr, "nullptr passed as " #name " argument");
43
44#define CHECK_VALID_RECT(name) \
45 LOG_ALWAYS_FATAL_IF(!static_cast<const Rect&>(name).isValid(), \
46 "invalid arg passed as " #name " argument");
47
John Reck2b2ba932021-07-12 21:51:09 -040048static_assert(static_cast<int>(ADATASPACE_UNKNOWN) == static_cast<int>(HAL_DATASPACE_UNKNOWN));
49static_assert(static_cast<int>(ADATASPACE_SCRGB_LINEAR) ==
50 static_cast<int>(HAL_DATASPACE_V0_SCRGB_LINEAR));
51static_assert(static_cast<int>(ADATASPACE_SRGB) == static_cast<int>(HAL_DATASPACE_V0_SRGB));
52static_assert(static_cast<int>(ADATASPACE_SCRGB) == static_cast<int>(HAL_DATASPACE_V0_SCRGB));
53static_assert(static_cast<int>(ADATASPACE_DISPLAY_P3) ==
54 static_cast<int>(HAL_DATASPACE_DISPLAY_P3));
55static_assert(static_cast<int>(ADATASPACE_BT2020_PQ) == static_cast<int>(HAL_DATASPACE_BT2020_PQ));
Valerie Hau5bbfd512019-01-22 17:39:43 -080056
Marissa Wallf6a73fa2018-12-10 10:41:08 -080057Transaction* ASurfaceTransaction_to_Transaction(ASurfaceTransaction* aSurfaceTransaction) {
58 return reinterpret_cast<Transaction*>(aSurfaceTransaction);
59}
60
61SurfaceControl* ASurfaceControl_to_SurfaceControl(ASurfaceControl* aSurfaceControl) {
62 return reinterpret_cast<SurfaceControl*>(aSurfaceControl);
63}
64
65void SurfaceControl_acquire(SurfaceControl* surfaceControl) {
66 // incStrong/decStrong token must be the same, doesn't matter what it is
67 surfaceControl->incStrong((void*)SurfaceControl_acquire);
68}
69
70void SurfaceControl_release(SurfaceControl* surfaceControl) {
71 // incStrong/decStrong token must be the same, doesn't matter what it is
72 surfaceControl->decStrong((void*)SurfaceControl_acquire);
73}
74
75ASurfaceControl* ASurfaceControl_createFromWindow(ANativeWindow* window, const char* debug_name) {
76 CHECK_NOT_NULL(window);
77 CHECK_NOT_NULL(debug_name);
78
79 sp<SurfaceComposerClient> client = new SurfaceComposerClient();
80 if (client->initCheck() != NO_ERROR) {
81 return nullptr;
82 }
83
Vishnu Nairce1a6482020-10-22 17:41:30 -070084 Surface* surface = static_cast<Surface*>(window);
85 sp<IBinder> parentHandle = surface->getSurfaceControlHandle();
86
Huihong Luo36b55bc2022-03-08 14:50:45 -080087 int32_t flags = ISurfaceComposerClient::eFXSurfaceBufferState;
Vishnu Nairce1a6482020-10-22 17:41:30 -070088 sp<SurfaceControl> surfaceControl;
89 if (parentHandle) {
90 surfaceControl =
91 client->createSurface(String8(debug_name), 0 /* width */, 0 /* height */,
92 // Format is only relevant for buffer queue layers.
93 PIXEL_FORMAT_UNKNOWN /* format */, flags, parentHandle);
94 } else {
Huihong Luo36b55bc2022-03-08 14:50:45 -080095 // deprecated, this should no longer be used
96 surfaceControl = nullptr;
Vishnu Nairce1a6482020-10-22 17:41:30 -070097 }
98
Marissa Wallf6a73fa2018-12-10 10:41:08 -080099 if (!surfaceControl) {
100 return nullptr;
101 }
102
103 SurfaceControl_acquire(surfaceControl.get());
104 return reinterpret_cast<ASurfaceControl*>(surfaceControl.get());
105}
106
107ASurfaceControl* ASurfaceControl_create(ASurfaceControl* parent, const char* debug_name) {
108 CHECK_NOT_NULL(parent);
109 CHECK_NOT_NULL(debug_name);
110
111 SurfaceComposerClient* client = ASurfaceControl_to_SurfaceControl(parent)->getClient().get();
112
113 SurfaceControl* surfaceControlParent = ASurfaceControl_to_SurfaceControl(parent);
114
115 uint32_t flags = ISurfaceComposerClient::eFXSurfaceBufferState;
116 sp<SurfaceControl> surfaceControl =
117 client->createSurface(String8(debug_name), 0 /* width */, 0 /* height */,
118 // Format is only relevant for buffer queue layers.
119 PIXEL_FORMAT_UNKNOWN /* format */, flags,
Vishnu Nairce1a6482020-10-22 17:41:30 -0700120 surfaceControlParent->getHandle());
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800121 if (!surfaceControl) {
122 return nullptr;
123 }
124
125 SurfaceControl_acquire(surfaceControl.get());
126 return reinterpret_cast<ASurfaceControl*>(surfaceControl.get());
127}
128
Huihong Luo91697e12021-01-28 15:24:19 -0800129void ASurfaceControl_acquire(ASurfaceControl* aSurfaceControl) {
130 SurfaceControl* surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800131
Huihong Luo91697e12021-01-28 15:24:19 -0800132 SurfaceControl_acquire(surfaceControl);
133}
134
135void ASurfaceControl_release(ASurfaceControl* aSurfaceControl) {
136 SurfaceControl* surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
137
138 SurfaceControl_release(surfaceControl);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800139}
140
Bo Liu789103b2022-09-15 16:24:31 -0400141ASurfaceControl* ASurfaceControl_fromSurfaceControl(JNIEnv* env, jobject surfaceControlObj) {
Bo Liudd89c3b2022-10-11 20:26:31 -0400142 LOG_ALWAYS_FATAL_IF(!env,
143 "nullptr passed to ASurfaceControl_fromSurfaceControl as env argument");
144 LOG_ALWAYS_FATAL_IF(!surfaceControlObj,
145 "nullptr passed to ASurfaceControl_fromSurfaceControl as surfaceControlObj "
146 "argument");
147 SurfaceControl* surfaceControl =
148 android_view_SurfaceControl_getNativeSurfaceControl(env, surfaceControlObj);
149 LOG_ALWAYS_FATAL_IF(!surfaceControl,
150 "surfaceControlObj passed to ASurfaceControl_fromSurfaceControl is not "
151 "valid");
152 SurfaceControl_acquire(surfaceControl);
153 return reinterpret_cast<ASurfaceControl*>(surfaceControl);
Bo Liu789103b2022-09-15 16:24:31 -0400154}
155
Jorim Jaggi71db8892021-02-03 23:19:29 +0100156struct ASurfaceControlStats {
Ady Abraham62e15f02022-01-21 17:00:50 -0800157 std::variant<int64_t, sp<Fence>> acquireTimeOrFence;
Jorim Jaggi71db8892021-02-03 23:19:29 +0100158 sp<Fence> previousReleaseFence;
159 uint64_t frameNumber;
160};
161
Pablo Gamitobc9e5292021-08-23 17:12:29 +0200162void ASurfaceControl_registerSurfaceStatsListener(ASurfaceControl* control, int32_t id,
163 void* context,
164 ASurfaceControl_SurfaceStatsListener func) {
Pablo Gamito14b28ce9c2021-09-06 16:33:23 +0000165 SurfaceStatsCallback callback = [func, id](void* callback_context, nsecs_t, const sp<Fence>&,
166 const SurfaceStats& surfaceStats) {
Jorim Jaggi71db8892021-02-03 23:19:29 +0100167 ASurfaceControlStats aSurfaceControlStats;
168
Ady Abraham62e15f02022-01-21 17:00:50 -0800169 aSurfaceControlStats.acquireTimeOrFence = surfaceStats.acquireTimeOrFence;
Jorim Jaggi71db8892021-02-03 23:19:29 +0100170 aSurfaceControlStats.previousReleaseFence = surfaceStats.previousReleaseFence;
171 aSurfaceControlStats.frameNumber = surfaceStats.eventStats.frameNumber;
172
Pablo Gamito14b28ce9c2021-09-06 16:33:23 +0000173 (*func)(callback_context, id, &aSurfaceControlStats);
Jorim Jaggi71db8892021-02-03 23:19:29 +0100174 };
Pablo Gamitobc9e5292021-08-23 17:12:29 +0200175
Jorim Jaggi71db8892021-02-03 23:19:29 +0100176 TransactionCompletedListener::getInstance()->addSurfaceStatsListener(context,
177 reinterpret_cast<void*>(func), ASurfaceControl_to_SurfaceControl(control), callback);
178}
179
Jorim Jaggi71db8892021-02-03 23:19:29 +0100180void ASurfaceControl_unregisterSurfaceStatsListener(void* context,
181 ASurfaceControl_SurfaceStatsListener func) {
182 TransactionCompletedListener::getInstance()->removeSurfaceStatsListener(context,
183 reinterpret_cast<void*>(func));
184}
185
186int64_t ASurfaceControlStats_getAcquireTime(ASurfaceControlStats* stats) {
Ady Abraham62e15f02022-01-21 17:00:50 -0800187 if (const auto* fence = std::get_if<sp<Fence>>(&stats->acquireTimeOrFence)) {
188 // We got a fence instead of the acquire time due to latch unsignaled.
189 // Ideally the client could just get the acquire time dericly from
190 // the fence instead of calling this function which needs to block.
191 (*fence)->waitForever("ASurfaceControlStats_getAcquireTime");
192 return (*fence)->getSignalTime();
193 }
194
195 return std::get<int64_t>(stats->acquireTimeOrFence);
Jorim Jaggi71db8892021-02-03 23:19:29 +0100196}
197
198uint64_t ASurfaceControlStats_getFrameNumber(ASurfaceControlStats* stats) {
199 return stats->frameNumber;
200}
201
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800202ASurfaceTransaction* ASurfaceTransaction_create() {
203 Transaction* transaction = new Transaction;
204 return reinterpret_cast<ASurfaceTransaction*>(transaction);
205}
206
207void ASurfaceTransaction_delete(ASurfaceTransaction* aSurfaceTransaction) {
208 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
209 delete transaction;
210}
211
Bo Liu789103b2022-09-15 16:24:31 -0400212ASurfaceTransaction* ASurfaceTransaction_fromTransaction(JNIEnv* env, jobject transactionObj) {
Bo Liudd89c3b2022-10-11 20:26:31 -0400213 LOG_ALWAYS_FATAL_IF(!env,
214 "nullptr passed to ASurfaceTransaction_fromTransaction as env argument");
215 LOG_ALWAYS_FATAL_IF(!transactionObj,
216 "nullptr passed to ASurfaceTransaction_fromTransaction as transactionObj "
217 "argument");
218 Transaction* transaction =
219 android_view_SurfaceTransaction_getNativeSurfaceTransaction(env, transactionObj);
220 LOG_ALWAYS_FATAL_IF(!transaction,
221 "surfaceControlObj passed to ASurfaceTransaction_fromTransaction is not "
222 "valid");
223 return reinterpret_cast<ASurfaceTransaction*>(transaction);
Bo Liu789103b2022-09-15 16:24:31 -0400224}
225
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800226void ASurfaceTransaction_apply(ASurfaceTransaction* aSurfaceTransaction) {
227 CHECK_NOT_NULL(aSurfaceTransaction);
228
229 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
230
231 transaction->apply();
232}
233
Marissa Wall1be5a102019-01-18 16:14:04 -0800234struct ASurfaceTransactionStats {
235 std::unordered_map<ASurfaceControl*, ASurfaceControlStats> aSurfaceControlStats;
236 int64_t latchTime;
237 sp<Fence> presentFence;
Vishnu Nairbeb3b482021-04-21 08:31:27 -0700238 bool transactionCompleted;
Marissa Wall1be5a102019-01-18 16:14:04 -0800239};
240
241int64_t ASurfaceTransactionStats_getLatchTime(ASurfaceTransactionStats* aSurfaceTransactionStats) {
242 CHECK_NOT_NULL(aSurfaceTransactionStats);
243 return aSurfaceTransactionStats->latchTime;
244}
245
246int ASurfaceTransactionStats_getPresentFenceFd(ASurfaceTransactionStats* aSurfaceTransactionStats) {
247 CHECK_NOT_NULL(aSurfaceTransactionStats);
Vishnu Nairbeb3b482021-04-21 08:31:27 -0700248 LOG_ALWAYS_FATAL_IF(!aSurfaceTransactionStats->transactionCompleted,
249 "ASurfaceTransactionStats queried from an incomplete transaction callback");
250
Marissa Wall1be5a102019-01-18 16:14:04 -0800251 auto& presentFence = aSurfaceTransactionStats->presentFence;
252 return (presentFence) ? presentFence->dup() : -1;
253}
254
255void ASurfaceTransactionStats_getASurfaceControls(ASurfaceTransactionStats* aSurfaceTransactionStats,
256 ASurfaceControl*** outASurfaceControls,
257 size_t* outASurfaceControlsSize) {
258 CHECK_NOT_NULL(aSurfaceTransactionStats);
259 CHECK_NOT_NULL(outASurfaceControls);
260 CHECK_NOT_NULL(outASurfaceControlsSize);
261
262 size_t size = aSurfaceTransactionStats->aSurfaceControlStats.size();
263
264 SurfaceControl** surfaceControls = new SurfaceControl*[size];
265 ASurfaceControl** aSurfaceControls = reinterpret_cast<ASurfaceControl**>(surfaceControls);
266
267 size_t i = 0;
268 for (auto& [aSurfaceControl, aSurfaceControlStats] : aSurfaceTransactionStats->aSurfaceControlStats) {
269 aSurfaceControls[i] = aSurfaceControl;
270 i++;
271 }
272
273 *outASurfaceControls = aSurfaceControls;
274 *outASurfaceControlsSize = size;
275}
276
277int64_t ASurfaceTransactionStats_getAcquireTime(ASurfaceTransactionStats* aSurfaceTransactionStats,
278 ASurfaceControl* aSurfaceControl) {
279 CHECK_NOT_NULL(aSurfaceTransactionStats);
280 CHECK_NOT_NULL(aSurfaceControl);
281
282 const auto& aSurfaceControlStats =
283 aSurfaceTransactionStats->aSurfaceControlStats.find(aSurfaceControl);
284 LOG_ALWAYS_FATAL_IF(
285 aSurfaceControlStats == aSurfaceTransactionStats->aSurfaceControlStats.end(),
286 "ASurfaceControl not found");
287
Ady Abraham62e15f02022-01-21 17:00:50 -0800288 return ASurfaceControlStats_getAcquireTime(&aSurfaceControlStats->second);
Marissa Wall1be5a102019-01-18 16:14:04 -0800289}
290
291int ASurfaceTransactionStats_getPreviousReleaseFenceFd(
292 ASurfaceTransactionStats* aSurfaceTransactionStats, ASurfaceControl* aSurfaceControl) {
293 CHECK_NOT_NULL(aSurfaceTransactionStats);
294 CHECK_NOT_NULL(aSurfaceControl);
Vishnu Nairbeb3b482021-04-21 08:31:27 -0700295 LOG_ALWAYS_FATAL_IF(!aSurfaceTransactionStats->transactionCompleted,
296 "ASurfaceTransactionStats queried from an incomplete transaction callback");
Marissa Wall1be5a102019-01-18 16:14:04 -0800297
298 const auto& aSurfaceControlStats =
299 aSurfaceTransactionStats->aSurfaceControlStats.find(aSurfaceControl);
300 LOG_ALWAYS_FATAL_IF(
301 aSurfaceControlStats == aSurfaceTransactionStats->aSurfaceControlStats.end(),
302 "ASurfaceControl not found");
303
304 auto& previousReleaseFence = aSurfaceControlStats->second.previousReleaseFence;
305 return (previousReleaseFence) ? previousReleaseFence->dup() : -1;
306}
307
308void ASurfaceTransactionStats_releaseASurfaceControls(ASurfaceControl** aSurfaceControls) {
309 CHECK_NOT_NULL(aSurfaceControls);
310
311 SurfaceControl** surfaceControls = reinterpret_cast<SurfaceControl**>(aSurfaceControls);
312 delete[] surfaceControls;
313}
314
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800315void ASurfaceTransaction_setOnComplete(ASurfaceTransaction* aSurfaceTransaction, void* context,
316 ASurfaceTransaction_OnComplete func) {
317 CHECK_NOT_NULL(aSurfaceTransaction);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800318 CHECK_NOT_NULL(func);
319
320 TransactionCompletedCallbackTakesContext callback = [func](void* callback_context,
Marissa Wall1be5a102019-01-18 16:14:04 -0800321 nsecs_t latchTime,
322 const sp<Fence>& presentFence,
323 const std::vector<SurfaceControlStats>& surfaceControlStats) {
324 ASurfaceTransactionStats aSurfaceTransactionStats;
325
326 aSurfaceTransactionStats.latchTime = latchTime;
327 aSurfaceTransactionStats.presentFence = presentFence;
Vishnu Nairbeb3b482021-04-21 08:31:27 -0700328 aSurfaceTransactionStats.transactionCompleted = true;
Marissa Wall1be5a102019-01-18 16:14:04 -0800329
330 auto& aSurfaceControlStats = aSurfaceTransactionStats.aSurfaceControlStats;
331
Ady Abraham62e15f02022-01-21 17:00:50 -0800332 for (const auto& [surfaceControl, latchTime, acquireTimeOrFence, presentFence,
Rob Carr7c703732022-09-27 00:57:27 +0000333 previousReleaseFence, transformHint, frameEvents, ignore] : surfaceControlStats) {
Marissa Wall1be5a102019-01-18 16:14:04 -0800334 ASurfaceControl* aSurfaceControl = reinterpret_cast<ASurfaceControl*>(surfaceControl.get());
Ady Abraham62e15f02022-01-21 17:00:50 -0800335 aSurfaceControlStats[aSurfaceControl].acquireTimeOrFence = acquireTimeOrFence;
Marissa Wall1be5a102019-01-18 16:14:04 -0800336 aSurfaceControlStats[aSurfaceControl].previousReleaseFence = previousReleaseFence;
337 }
338
339 (*func)(callback_context, &aSurfaceTransactionStats);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800340 };
341
342 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
343
344 transaction->addTransactionCompletedCallback(callback, context);
345}
346
Marissa Wall1be5a102019-01-18 16:14:04 -0800347void ASurfaceTransaction_reparent(ASurfaceTransaction* aSurfaceTransaction,
348 ASurfaceControl* aSurfaceControl,
349 ASurfaceControl* newParentASurfaceControl) {
350 CHECK_NOT_NULL(aSurfaceTransaction);
351 CHECK_NOT_NULL(aSurfaceControl);
352
353 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
354 sp<SurfaceControl> newParentSurfaceControl = ASurfaceControl_to_SurfaceControl(
355 newParentASurfaceControl);
Marissa Wall1be5a102019-01-18 16:14:04 -0800356 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
357
Pablo Gamito117040c2020-09-14 08:24:41 +0000358 transaction->reparent(surfaceControl, newParentSurfaceControl);
Marissa Wall1be5a102019-01-18 16:14:04 -0800359}
360
361void ASurfaceTransaction_setVisibility(ASurfaceTransaction* aSurfaceTransaction,
362 ASurfaceControl* aSurfaceControl,
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800363 int8_t visibility) {
364 CHECK_NOT_NULL(aSurfaceTransaction);
365 CHECK_NOT_NULL(aSurfaceControl);
366
367 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
368 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
369
370 switch (visibility) {
371 case ASURFACE_TRANSACTION_VISIBILITY_SHOW:
372 transaction->show(surfaceControl);
373 break;
374 case ASURFACE_TRANSACTION_VISIBILITY_HIDE:
375 transaction->hide(surfaceControl);
376 break;
377 default:
378 LOG_ALWAYS_FATAL("invalid visibility %d", visibility);
379 }
380}
381
Marissa Wall1be5a102019-01-18 16:14:04 -0800382void ASurfaceTransaction_setZOrder(ASurfaceTransaction* aSurfaceTransaction,
383 ASurfaceControl* aSurfaceControl,
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800384 int32_t z_order) {
385 CHECK_NOT_NULL(aSurfaceTransaction);
386 CHECK_NOT_NULL(aSurfaceControl);
387
388 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
389 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
390
391 transaction->setLayer(surfaceControl, z_order);
392}
393
Marissa Wall1be5a102019-01-18 16:14:04 -0800394void ASurfaceTransaction_setBuffer(ASurfaceTransaction* aSurfaceTransaction,
395 ASurfaceControl* aSurfaceControl,
396 AHardwareBuffer* buffer, int acquire_fence_fd) {
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800397 CHECK_NOT_NULL(aSurfaceTransaction);
398 CHECK_NOT_NULL(aSurfaceControl);
399
400 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
401 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
402
John Reck7f55b132021-09-20 14:42:29 -0400403 sp<GraphicBuffer> graphic_buffer(GraphicBuffer::fromAHardwareBuffer(buffer));
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800404
chaviw5513c612021-09-15 15:26:23 -0500405 std::optional<sp<Fence>> fence = std::nullopt;
Marissa Wall1be5a102019-01-18 16:14:04 -0800406 if (acquire_fence_fd != -1) {
chaviw5513c612021-09-15 15:26:23 -0500407 fence = new Fence(acquire_fence_fd);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800408 }
chaviw5513c612021-09-15 15:26:23 -0500409 transaction->setBuffer(surfaceControl, graphic_buffer, fence);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800410}
411
412void ASurfaceTransaction_setGeometry(ASurfaceTransaction* aSurfaceTransaction,
413 ASurfaceControl* aSurfaceControl, const ARect& source,
414 const ARect& destination, int32_t transform) {
415 CHECK_NOT_NULL(aSurfaceTransaction);
416 CHECK_NOT_NULL(aSurfaceControl);
chaviw87a07ea2021-04-29 09:04:41 -0500417 CHECK_VALID_RECT(source);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800418 CHECK_VALID_RECT(destination);
419
420 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
421 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
422
chaviw87a07ea2021-04-29 09:04:41 -0500423 Rect sourceRect = static_cast<const Rect&>(source);
424 Rect destRect = static_cast<const Rect&>(destination);
425 // Adjust the source so its top and left are not negative
426 sourceRect.left = std::max(sourceRect.left, 0);
427 sourceRect.top = std::max(sourceRect.top, 0);
428
429 if (!sourceRect.isValid()) {
430 sourceRect.makeInvalid();
431 }
chaviw9b2ac242021-04-27 15:52:09 -0500432 transaction->setBufferCrop(surfaceControl, sourceRect);
Vishnu Nair0d7aff72021-05-10 15:01:20 -0700433 transaction->setDestinationFrame(surfaceControl, destRect);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800434 transaction->setTransform(surfaceControl, transform);
Vishnu Nair1ad69542019-05-23 16:27:45 +0800435 bool transformToInverseDisplay = (NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY & transform) ==
436 NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY;
437 transaction->setTransformToDisplayInverse(surfaceControl, transformToInverseDisplay);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800438}
439
chaviwccf3e8b2021-03-25 15:28:44 -0500440void ASurfaceTransaction_setCrop(ASurfaceTransaction* aSurfaceTransaction,
441 ASurfaceControl* aSurfaceControl, const ARect& crop) {
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500442 CHECK_NOT_NULL(aSurfaceTransaction);
443 CHECK_NOT_NULL(aSurfaceControl);
chaviwccf3e8b2021-03-25 15:28:44 -0500444 CHECK_VALID_RECT(crop);
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500445
446 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
447 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
448
chaviwccf3e8b2021-03-25 15:28:44 -0500449 transaction->setCrop(surfaceControl, static_cast<const Rect&>(crop));
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500450}
451
chaviwccf3e8b2021-03-25 15:28:44 -0500452void ASurfaceTransaction_setPosition(ASurfaceTransaction* aSurfaceTransaction,
453 ASurfaceControl* aSurfaceControl, int32_t x, int32_t y) {
454 CHECK_NOT_NULL(aSurfaceTransaction);
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500455 CHECK_NOT_NULL(aSurfaceControl);
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500456
457 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
458 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
459
chaviwccf3e8b2021-03-25 15:28:44 -0500460 transaction->setPosition(surfaceControl, x, y);
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500461}
462
chaviwccf3e8b2021-03-25 15:28:44 -0500463void ASurfaceTransaction_setBufferTransform(ASurfaceTransaction* aSurfaceTransaction,
464 ASurfaceControl* aSurfaceControl, int32_t transform) {
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500465 CHECK_NOT_NULL(aSurfaceTransaction);
466 CHECK_NOT_NULL(aSurfaceControl);
467
468 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
469 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
470
471 transaction->setTransform(surfaceControl, transform);
472 bool transformToInverseDisplay = (NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY & transform) ==
473 NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY;
474 transaction->setTransformToDisplayInverse(surfaceControl, transformToInverseDisplay);
475}
476
chaviwccf3e8b2021-03-25 15:28:44 -0500477void ASurfaceTransaction_setScale(ASurfaceTransaction* aSurfaceTransaction,
478 ASurfaceControl* aSurfaceControl, float xScale, float yScale) {
479 CHECK_NOT_NULL(aSurfaceTransaction);
480 CHECK_NOT_NULL(aSurfaceControl);
481 LOG_ALWAYS_FATAL_IF(xScale < 0, "negative value passed in for xScale");
482 LOG_ALWAYS_FATAL_IF(yScale < 0, "negative value passed in for yScale");
483
484 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
485 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
486
487 transaction->setMatrix(surfaceControl, xScale, 0, 0, yScale);
488}
489
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800490void ASurfaceTransaction_setBufferTransparency(ASurfaceTransaction* aSurfaceTransaction,
491 ASurfaceControl* aSurfaceControl,
492 int8_t transparency) {
493 CHECK_NOT_NULL(aSurfaceTransaction);
494 CHECK_NOT_NULL(aSurfaceControl);
495
496 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
497 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
498
499 uint32_t flags = (transparency == ASURFACE_TRANSACTION_TRANSPARENCY_OPAQUE) ?
500 layer_state_t::eLayerOpaque : 0;
501 transaction->setFlags(surfaceControl, flags, layer_state_t::eLayerOpaque);
502}
503
Marissa Wall1be5a102019-01-18 16:14:04 -0800504void ASurfaceTransaction_setDamageRegion(ASurfaceTransaction* aSurfaceTransaction,
505 ASurfaceControl* aSurfaceControl,
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800506 const ARect rects[], uint32_t count) {
507 CHECK_NOT_NULL(aSurfaceTransaction);
508 CHECK_NOT_NULL(aSurfaceControl);
509
510 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
511 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
512
513 Region region;
514 for (uint32_t i = 0; i < count; ++i) {
Marissa Wallbb9b14f2019-04-23 14:10:15 -0700515 region.orSelf(static_cast<const Rect&>(rects[i]));
516 }
517
518 // Hardware composer interprets a DamageRegion with a single Rect of {0,0,0,0} to be an
519 // undamaged region and {0,0,-1,-1} to be a fully damaged buffer. This is a confusing
520 // distinction for a public api. Instead, default both cases to be a fully damaged buffer.
521 if (count == 1 && region.getBounds().isEmpty()) {
522 transaction->setSurfaceDamageRegion(surfaceControl, Region::INVALID_REGION);
523 return;
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800524 }
525
526 transaction->setSurfaceDamageRegion(surfaceControl, region);
527}
Marissa Wall1be5a102019-01-18 16:14:04 -0800528
529void ASurfaceTransaction_setDesiredPresentTime(ASurfaceTransaction* aSurfaceTransaction,
530 int64_t desiredPresentTime) {
531 CHECK_NOT_NULL(aSurfaceTransaction);
532
533 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
534
535 transaction->setDesiredPresentTime(static_cast<nsecs_t>(desiredPresentTime));
536}
537
538void ASurfaceTransaction_setBufferAlpha(ASurfaceTransaction* aSurfaceTransaction,
539 ASurfaceControl* aSurfaceControl,
540 float alpha) {
541 CHECK_NOT_NULL(aSurfaceTransaction);
542 CHECK_NOT_NULL(aSurfaceControl);
543
544 LOG_ALWAYS_FATAL_IF(alpha < 0.0 || alpha > 1.0, "invalid alpha");
545
546 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
547 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
548
549 transaction->setAlpha(surfaceControl, alpha);
550}
551
Marissa Wall7f24f792019-02-07 14:06:04 -0800552void ASurfaceTransaction_setBufferDataSpace(ASurfaceTransaction* aSurfaceTransaction,
553 ASurfaceControl* aSurfaceControl,
554 ADataSpace aDataSpace) {
555 CHECK_NOT_NULL(aSurfaceTransaction);
556 CHECK_NOT_NULL(aSurfaceControl);
557
558 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Marissa Wall7f24f792019-02-07 14:06:04 -0800559 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
Marissa Wall7f24f792019-02-07 14:06:04 -0800560 transaction->setDataspace(surfaceControl, static_cast<ui::Dataspace>(aDataSpace));
561}
562
Marissa Wall1be5a102019-01-18 16:14:04 -0800563void ASurfaceTransaction_setHdrMetadata_smpte2086(ASurfaceTransaction* aSurfaceTransaction,
564 ASurfaceControl* aSurfaceControl,
565 struct AHdrMetadata_smpte2086* metadata) {
566 CHECK_NOT_NULL(aSurfaceTransaction);
567 CHECK_NOT_NULL(aSurfaceControl);
568
569 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
570 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
571
572 HdrMetadata hdrMetadata;
573
574 if (metadata) {
575 hdrMetadata.smpte2086.displayPrimaryRed.x = metadata->displayPrimaryRed.x;
576 hdrMetadata.smpte2086.displayPrimaryRed.y = metadata->displayPrimaryRed.y;
577 hdrMetadata.smpte2086.displayPrimaryGreen.x = metadata->displayPrimaryGreen.x;
578 hdrMetadata.smpte2086.displayPrimaryGreen.y = metadata->displayPrimaryGreen.y;
579 hdrMetadata.smpte2086.displayPrimaryBlue.x = metadata->displayPrimaryBlue.x;
580 hdrMetadata.smpte2086.displayPrimaryBlue.y = metadata->displayPrimaryBlue.y;
581 hdrMetadata.smpte2086.whitePoint.x = metadata->whitePoint.x;
582 hdrMetadata.smpte2086.whitePoint.y = metadata->whitePoint.y;
583 hdrMetadata.smpte2086.minLuminance = metadata->minLuminance;
584 hdrMetadata.smpte2086.maxLuminance = metadata->maxLuminance;
585
586 hdrMetadata.validTypes |= HdrMetadata::SMPTE2086;
587 } else {
588 hdrMetadata.validTypes &= ~HdrMetadata::SMPTE2086;
589 }
590
591 transaction->setHdrMetadata(surfaceControl, hdrMetadata);
592}
593
594void ASurfaceTransaction_setHdrMetadata_cta861_3(ASurfaceTransaction* aSurfaceTransaction,
595 ASurfaceControl* aSurfaceControl,
596 struct AHdrMetadata_cta861_3* metadata) {
597 CHECK_NOT_NULL(aSurfaceTransaction);
598 CHECK_NOT_NULL(aSurfaceControl);
599
600 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
601 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
602
603 HdrMetadata hdrMetadata;
604
605 if (metadata) {
606 hdrMetadata.cta8613.maxContentLightLevel = metadata->maxContentLightLevel;
607 hdrMetadata.cta8613.maxFrameAverageLightLevel = metadata->maxFrameAverageLightLevel;
608
609 hdrMetadata.validTypes |= HdrMetadata::CTA861_3;
610 } else {
611 hdrMetadata.validTypes &= ~HdrMetadata::CTA861_3;
612 }
613
614 transaction->setHdrMetadata(surfaceControl, hdrMetadata);
615}
Valerie Hau5bbfd512019-01-22 17:39:43 -0800616
617void ASurfaceTransaction_setColor(ASurfaceTransaction* aSurfaceTransaction,
618 ASurfaceControl* aSurfaceControl,
619 float r, float g, float b, float alpha,
620 ADataSpace dataspace) {
621 CHECK_NOT_NULL(aSurfaceTransaction);
622 CHECK_NOT_NULL(aSurfaceControl);
623
624 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Valerie Hau5bbfd512019-01-22 17:39:43 -0800625 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
626
627 half3 color;
628 color.r = r;
629 color.g = g;
630 color.b = b;
631
Marin Shalamanov511f9142021-03-16 18:03:30 +0100632 transaction->setBackgroundColor(surfaceControl, color, alpha,
633 static_cast<ui::Dataspace>(dataspace));
Valerie Hau5bbfd512019-01-22 17:39:43 -0800634}
Steven Thomas6cf051e2020-01-14 11:37:21 -0800635
636void ASurfaceTransaction_setFrameRate(ASurfaceTransaction* aSurfaceTransaction,
Steven Thomasdd7bf2f2020-01-31 18:50:02 -0800637 ASurfaceControl* aSurfaceControl, float frameRate,
638 int8_t compatibility) {
Marin Shalamanov511f9142021-03-16 18:03:30 +0100639 ASurfaceTransaction_setFrameRateWithChangeStrategy(
640 aSurfaceTransaction, aSurfaceControl, frameRate, compatibility,
641 ANATIVEWINDOW_CHANGE_FRAME_RATE_ONLY_IF_SEAMLESS);
Marin Shalamanov41ffa8d2020-10-13 12:35:20 +0200642}
643
Marin Shalamanov511f9142021-03-16 18:03:30 +0100644void ASurfaceTransaction_setFrameRateWithChangeStrategy(ASurfaceTransaction* aSurfaceTransaction,
645 ASurfaceControl* aSurfaceControl,
646 float frameRate, int8_t compatibility,
647 int8_t changeFrameRateStrategy) {
Steven Thomas6cf051e2020-01-14 11:37:21 -0800648 CHECK_NOT_NULL(aSurfaceTransaction);
649 CHECK_NOT_NULL(aSurfaceControl);
Steven Thomas6cf051e2020-01-14 11:37:21 -0800650 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
Steven Thomasdd7bf2f2020-01-31 18:50:02 -0800651 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Marin Shalamanov511f9142021-03-16 18:03:30 +0100652 transaction->setFrameRate(surfaceControl, frameRate, compatibility, changeFrameRateStrategy);
Steven Thomas6cf051e2020-01-14 11:37:21 -0800653}
Robert Carrf57c0162021-03-24 15:48:25 -0700654
Kriti Dang4bfeeb42022-08-11 15:15:36 +0200655void ASurfaceTransaction_clearFrameRate(ASurfaceTransaction* aSurfaceTransaction,
656 ASurfaceControl* aSurfaceControl) {
657 CHECK_NOT_NULL(aSurfaceTransaction);
658 CHECK_NOT_NULL(aSurfaceControl);
659 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
660 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
661 transaction->setFrameRate(surfaceControl, 0, ANATIVEWINDOW_FRAME_RATE_COMPATIBILITY_DEFAULT,
662 ANATIVEWINDOW_CHANGE_FRAME_RATE_ONLY_IF_SEAMLESS);
663}
664
Robert Carrf57c0162021-03-24 15:48:25 -0700665void ASurfaceTransaction_setEnableBackPressure(ASurfaceTransaction* aSurfaceTransaction,
666 ASurfaceControl* aSurfaceControl,
667 bool enableBackpressure) {
668 CHECK_NOT_NULL(aSurfaceControl);
669 CHECK_NOT_NULL(aSurfaceTransaction);
670
671 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
672 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
673
674 const uint32_t flags = enableBackpressure ?
675 layer_state_t::eEnableBackpressure : 0;
676 transaction->setFlags(surfaceControl, flags, layer_state_t::eEnableBackpressure);
677}
Vishnu Nairbeb3b482021-04-21 08:31:27 -0700678
679void ASurfaceTransaction_setOnCommit(ASurfaceTransaction* aSurfaceTransaction, void* context,
680 ASurfaceTransaction_OnCommit func) {
681 CHECK_NOT_NULL(aSurfaceTransaction);
682 CHECK_NOT_NULL(func);
683
684 TransactionCompletedCallbackTakesContext callback =
685 [func](void* callback_context, nsecs_t latchTime, const sp<Fence>& /* presentFence */,
686 const std::vector<SurfaceControlStats>& surfaceControlStats) {
687 ASurfaceTransactionStats aSurfaceTransactionStats;
688 aSurfaceTransactionStats.latchTime = latchTime;
689 aSurfaceTransactionStats.transactionCompleted = false;
690
691 auto& aSurfaceControlStats = aSurfaceTransactionStats.aSurfaceControlStats;
Ady Abraham62e15f02022-01-21 17:00:50 -0800692 for (const auto& [surfaceControl, latchTime, acquireTimeOrFence, presentFence,
Rob Carr7c703732022-09-27 00:57:27 +0000693 previousReleaseFence, transformHint, frameEvents, ignore] :
Ady Abraham62e15f02022-01-21 17:00:50 -0800694 surfaceControlStats) {
Vishnu Nairbeb3b482021-04-21 08:31:27 -0700695 ASurfaceControl* aSurfaceControl =
696 reinterpret_cast<ASurfaceControl*>(surfaceControl.get());
Ady Abraham62e15f02022-01-21 17:00:50 -0800697 aSurfaceControlStats[aSurfaceControl].acquireTimeOrFence = acquireTimeOrFence;
Vishnu Nairbeb3b482021-04-21 08:31:27 -0700698 }
699
700 (*func)(callback_context, &aSurfaceTransactionStats);
701 };
702
703 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
704
705 transaction->addTransactionCommittedCallback(callback, context);
Pablo Gamito88660d72021-08-09 14:37:56 +0000706}
Rachel Leee1e77cc2021-10-19 16:40:41 -0700707
708void ASurfaceTransaction_setFrameTimeline(ASurfaceTransaction* aSurfaceTransaction,
Rachel Lee7e47b3d2022-01-12 14:28:26 -0800709 AVsyncId vsyncId) {
Rachel Leee1e77cc2021-10-19 16:40:41 -0700710 CHECK_NOT_NULL(aSurfaceTransaction);
Rachel Leeb6c93aa2022-02-22 15:48:28 -0800711 const auto startTime = AChoreographer_getStartTimeNanosForVsyncId(vsyncId);
Huihong Luo4fed9b42022-03-03 15:10:33 -0800712 FrameTimelineInfo ftInfo;
713 ftInfo.vsyncId = vsyncId;
714 ftInfo.startTimeNanos = startTime;
715 ASurfaceTransaction_to_Transaction(aSurfaceTransaction)->setFrameTimelineInfo(ftInfo);
Rachel Leee1e77cc2021-10-19 16:40:41 -0700716}