blob: 3d14c425ed4db4f5440f86aacd0470fa4c07f20d [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>
Jorim Jaggi71db8892021-02-03 23:19:29 +010020#include <surface_control_private.h>
Marissa Wallf6a73fa2018-12-10 10:41:08 -080021
Marissa Wall1be5a102019-01-18 16:14:04 -080022#include <configstore/Utils.h>
23
24#include <gui/HdrMetadata.h>
25#include <gui/ISurfaceComposer.h>
Marissa Wallf6a73fa2018-12-10 10:41:08 -080026#include <gui/Surface.h>
27#include <gui/SurfaceComposerClient.h>
28#include <gui/SurfaceControl.h>
29
Marin Shalamanov463ad8e2021-01-28 22:58:37 +010030#include <ui/DynamicDisplayInfo.h>
Marissa Wall1be5a102019-01-18 16:14:04 -080031
32#include <utils/Timers.h>
33
34using namespace android::hardware::configstore;
35using namespace android::hardware::configstore::V1_0;
Marissa Wallf6a73fa2018-12-10 10:41:08 -080036using namespace android;
37
38using Transaction = SurfaceComposerClient::Transaction;
39
40#define CHECK_NOT_NULL(name) \
41 LOG_ALWAYS_FATAL_IF(name == nullptr, "nullptr passed as " #name " argument");
42
43#define CHECK_VALID_RECT(name) \
44 LOG_ALWAYS_FATAL_IF(!static_cast<const Rect&>(name).isValid(), \
45 "invalid arg passed as " #name " argument");
46
Valerie Hau5bbfd512019-01-22 17:39:43 -080047static bool getWideColorSupport(const sp<SurfaceControl>& surfaceControl) {
48 sp<SurfaceComposerClient> client = surfaceControl->getClient();
Dominik Laskowski3316a0a2019-01-25 02:56:41 -080049
50 const sp<IBinder> display = client->getInternalDisplayToken();
51 if (display == nullptr) {
52 ALOGE("unable to get wide color support for disconnected internal display");
53 return false;
54 }
55
Peiyong Lin0d04f322019-01-24 17:49:46 -080056 bool isWideColorDisplay = false;
57 status_t err = client->isWideColorDisplay(display, &isWideColorDisplay);
Valerie Hau5bbfd512019-01-22 17:39:43 -080058 if (err) {
59 ALOGE("unable to get wide color support");
60 return false;
61 }
Peiyong Lin0d04f322019-01-24 17:49:46 -080062 return isWideColorDisplay;
Valerie Hau5bbfd512019-01-22 17:39:43 -080063}
64
65static bool getHdrSupport(const sp<SurfaceControl>& surfaceControl) {
66 sp<SurfaceComposerClient> client = surfaceControl->getClient();
Dominik Laskowski3316a0a2019-01-25 02:56:41 -080067
68 const sp<IBinder> display = client->getInternalDisplayToken();
69 if (display == nullptr) {
70 ALOGE("unable to get hdr capabilities for disconnected internal display");
71 return false;
72 }
Valerie Hau5bbfd512019-01-22 17:39:43 -080073
Marin Shalamanov463ad8e2021-01-28 22:58:37 +010074 ui::DynamicDisplayInfo info;
75 if (status_t err = client->getDynamicDisplayInfo(display, &info); err != NO_ERROR) {
Valerie Hau5bbfd512019-01-22 17:39:43 -080076 ALOGE("unable to get hdr capabilities");
Marin Shalamanov463ad8e2021-01-28 22:58:37 +010077 return err;
Valerie Hau5bbfd512019-01-22 17:39:43 -080078 }
79
Marin Shalamanov463ad8e2021-01-28 22:58:37 +010080 return !info.hdrCapabilities.getSupportedHdrTypes().empty();
Valerie Hau5bbfd512019-01-22 17:39:43 -080081}
82
83static bool isDataSpaceValid(const sp<SurfaceControl>& surfaceControl, ADataSpace dataSpace) {
84 static_assert(static_cast<int>(ADATASPACE_UNKNOWN) == static_cast<int>(HAL_DATASPACE_UNKNOWN));
85 static_assert(static_cast<int>(ADATASPACE_SCRGB_LINEAR) == static_cast<int>(HAL_DATASPACE_V0_SCRGB_LINEAR));
86 static_assert(static_cast<int>(ADATASPACE_SRGB) == static_cast<int>(HAL_DATASPACE_V0_SRGB));
87 static_assert(static_cast<int>(ADATASPACE_SCRGB) == static_cast<int>(HAL_DATASPACE_V0_SCRGB));
88 static_assert(static_cast<int>(ADATASPACE_DISPLAY_P3) == static_cast<int>(HAL_DATASPACE_DISPLAY_P3));
89 static_assert(static_cast<int>(ADATASPACE_BT2020_PQ) == static_cast<int>(HAL_DATASPACE_BT2020_PQ));
90
91 switch (static_cast<android_dataspace_t>(dataSpace)) {
92 case HAL_DATASPACE_UNKNOWN:
93 case HAL_DATASPACE_V0_SRGB:
94 return true;
95 // These data space need wide gamut support.
96 case HAL_DATASPACE_V0_SCRGB_LINEAR:
97 case HAL_DATASPACE_V0_SCRGB:
98 case HAL_DATASPACE_DISPLAY_P3:
99 return getWideColorSupport(surfaceControl);
100 // These data space need HDR support.
101 case HAL_DATASPACE_BT2020_PQ:
Valerie Hau5e18c432019-08-26 12:48:49 -0700102 if (!getHdrSupport(surfaceControl)) {
103 ALOGE("Invalid dataspace - device does not support hdr");
104 return false;
105 }
106 return true;
Valerie Hau5bbfd512019-01-22 17:39:43 -0800107 default:
108 return false;
109 }
110}
111
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800112Transaction* ASurfaceTransaction_to_Transaction(ASurfaceTransaction* aSurfaceTransaction) {
113 return reinterpret_cast<Transaction*>(aSurfaceTransaction);
114}
115
116SurfaceControl* ASurfaceControl_to_SurfaceControl(ASurfaceControl* aSurfaceControl) {
117 return reinterpret_cast<SurfaceControl*>(aSurfaceControl);
118}
119
120void SurfaceControl_acquire(SurfaceControl* surfaceControl) {
121 // incStrong/decStrong token must be the same, doesn't matter what it is
122 surfaceControl->incStrong((void*)SurfaceControl_acquire);
123}
124
125void SurfaceControl_release(SurfaceControl* surfaceControl) {
126 // incStrong/decStrong token must be the same, doesn't matter what it is
127 surfaceControl->decStrong((void*)SurfaceControl_acquire);
128}
129
130ASurfaceControl* ASurfaceControl_createFromWindow(ANativeWindow* window, const char* debug_name) {
131 CHECK_NOT_NULL(window);
132 CHECK_NOT_NULL(debug_name);
133
134 sp<SurfaceComposerClient> client = new SurfaceComposerClient();
135 if (client->initCheck() != NO_ERROR) {
136 return nullptr;
137 }
138
Vishnu Nairce1a6482020-10-22 17:41:30 -0700139 Surface* surface = static_cast<Surface*>(window);
140 sp<IBinder> parentHandle = surface->getSurfaceControlHandle();
141
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800142 uint32_t flags = ISurfaceComposerClient::eFXSurfaceBufferState;
Vishnu Nairce1a6482020-10-22 17:41:30 -0700143 sp<SurfaceControl> surfaceControl;
144 if (parentHandle) {
145 surfaceControl =
146 client->createSurface(String8(debug_name), 0 /* width */, 0 /* height */,
147 // Format is only relevant for buffer queue layers.
148 PIXEL_FORMAT_UNKNOWN /* format */, flags, parentHandle);
149 } else {
150 surfaceControl =
151 client->createWithSurfaceParent(String8(debug_name), 0 /* width */, 0 /* height */,
152 // Format is only relevant for buffer queue layers.
153 PIXEL_FORMAT_UNKNOWN /* format */, flags,
154 static_cast<Surface*>(window));
155 }
156
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800157 if (!surfaceControl) {
158 return nullptr;
159 }
160
161 SurfaceControl_acquire(surfaceControl.get());
162 return reinterpret_cast<ASurfaceControl*>(surfaceControl.get());
163}
164
165ASurfaceControl* ASurfaceControl_create(ASurfaceControl* parent, const char* debug_name) {
166 CHECK_NOT_NULL(parent);
167 CHECK_NOT_NULL(debug_name);
168
169 SurfaceComposerClient* client = ASurfaceControl_to_SurfaceControl(parent)->getClient().get();
170
171 SurfaceControl* surfaceControlParent = ASurfaceControl_to_SurfaceControl(parent);
172
173 uint32_t flags = ISurfaceComposerClient::eFXSurfaceBufferState;
174 sp<SurfaceControl> surfaceControl =
175 client->createSurface(String8(debug_name), 0 /* width */, 0 /* height */,
176 // Format is only relevant for buffer queue layers.
177 PIXEL_FORMAT_UNKNOWN /* format */, flags,
Vishnu Nairce1a6482020-10-22 17:41:30 -0700178 surfaceControlParent->getHandle());
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800179 if (!surfaceControl) {
180 return nullptr;
181 }
182
183 SurfaceControl_acquire(surfaceControl.get());
184 return reinterpret_cast<ASurfaceControl*>(surfaceControl.get());
185}
186
Huihong Luo91697e12021-01-28 15:24:19 -0800187void ASurfaceControl_acquire(ASurfaceControl* aSurfaceControl) {
188 SurfaceControl* surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800189
Huihong Luo91697e12021-01-28 15:24:19 -0800190 SurfaceControl_acquire(surfaceControl);
191}
192
193void ASurfaceControl_release(ASurfaceControl* aSurfaceControl) {
194 SurfaceControl* surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
195
196 SurfaceControl_release(surfaceControl);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800197}
198
Jorim Jaggi71db8892021-02-03 23:19:29 +0100199struct ASurfaceControlStats {
200 int64_t acquireTime;
201 sp<Fence> previousReleaseFence;
202 uint64_t frameNumber;
203};
204
205void ASurfaceControl_registerSurfaceStatsListener(ASurfaceControl* control, void* context,
206 ASurfaceControl_SurfaceStatsListener func) {
207 SurfaceStatsCallback callback = [func](void* callback_context,
208 nsecs_t,
209 const sp<Fence>&,
210 const SurfaceStats& surfaceStats) {
211
212 ASurfaceControlStats aSurfaceControlStats;
213
214 ASurfaceControl* aSurfaceControl =
215 reinterpret_cast<ASurfaceControl*>(surfaceStats.surfaceControl.get());
216 aSurfaceControlStats.acquireTime = surfaceStats.acquireTime;
217 aSurfaceControlStats.previousReleaseFence = surfaceStats.previousReleaseFence;
218 aSurfaceControlStats.frameNumber = surfaceStats.eventStats.frameNumber;
219
220 (*func)(callback_context, aSurfaceControl, &aSurfaceControlStats);
221 };
222 TransactionCompletedListener::getInstance()->addSurfaceStatsListener(context,
223 reinterpret_cast<void*>(func), ASurfaceControl_to_SurfaceControl(control), callback);
224}
225
226
227void ASurfaceControl_unregisterSurfaceStatsListener(void* context,
228 ASurfaceControl_SurfaceStatsListener func) {
229 TransactionCompletedListener::getInstance()->removeSurfaceStatsListener(context,
230 reinterpret_cast<void*>(func));
231}
232
233int64_t ASurfaceControlStats_getAcquireTime(ASurfaceControlStats* stats) {
234 return stats->acquireTime;
235}
236
237uint64_t ASurfaceControlStats_getFrameNumber(ASurfaceControlStats* stats) {
238 return stats->frameNumber;
239}
240
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800241ASurfaceTransaction* ASurfaceTransaction_create() {
242 Transaction* transaction = new Transaction;
243 return reinterpret_cast<ASurfaceTransaction*>(transaction);
244}
245
246void ASurfaceTransaction_delete(ASurfaceTransaction* aSurfaceTransaction) {
247 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
248 delete transaction;
249}
250
251void ASurfaceTransaction_apply(ASurfaceTransaction* aSurfaceTransaction) {
252 CHECK_NOT_NULL(aSurfaceTransaction);
253
254 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
255
256 transaction->apply();
257}
258
Marissa Wall1be5a102019-01-18 16:14:04 -0800259struct ASurfaceTransactionStats {
260 std::unordered_map<ASurfaceControl*, ASurfaceControlStats> aSurfaceControlStats;
261 int64_t latchTime;
262 sp<Fence> presentFence;
263};
264
265int64_t ASurfaceTransactionStats_getLatchTime(ASurfaceTransactionStats* aSurfaceTransactionStats) {
266 CHECK_NOT_NULL(aSurfaceTransactionStats);
267 return aSurfaceTransactionStats->latchTime;
268}
269
270int ASurfaceTransactionStats_getPresentFenceFd(ASurfaceTransactionStats* aSurfaceTransactionStats) {
271 CHECK_NOT_NULL(aSurfaceTransactionStats);
272 auto& presentFence = aSurfaceTransactionStats->presentFence;
273 return (presentFence) ? presentFence->dup() : -1;
274}
275
276void ASurfaceTransactionStats_getASurfaceControls(ASurfaceTransactionStats* aSurfaceTransactionStats,
277 ASurfaceControl*** outASurfaceControls,
278 size_t* outASurfaceControlsSize) {
279 CHECK_NOT_NULL(aSurfaceTransactionStats);
280 CHECK_NOT_NULL(outASurfaceControls);
281 CHECK_NOT_NULL(outASurfaceControlsSize);
282
283 size_t size = aSurfaceTransactionStats->aSurfaceControlStats.size();
284
285 SurfaceControl** surfaceControls = new SurfaceControl*[size];
286 ASurfaceControl** aSurfaceControls = reinterpret_cast<ASurfaceControl**>(surfaceControls);
287
288 size_t i = 0;
289 for (auto& [aSurfaceControl, aSurfaceControlStats] : aSurfaceTransactionStats->aSurfaceControlStats) {
290 aSurfaceControls[i] = aSurfaceControl;
291 i++;
292 }
293
294 *outASurfaceControls = aSurfaceControls;
295 *outASurfaceControlsSize = size;
296}
297
298int64_t ASurfaceTransactionStats_getAcquireTime(ASurfaceTransactionStats* aSurfaceTransactionStats,
299 ASurfaceControl* aSurfaceControl) {
300 CHECK_NOT_NULL(aSurfaceTransactionStats);
301 CHECK_NOT_NULL(aSurfaceControl);
302
303 const auto& aSurfaceControlStats =
304 aSurfaceTransactionStats->aSurfaceControlStats.find(aSurfaceControl);
305 LOG_ALWAYS_FATAL_IF(
306 aSurfaceControlStats == aSurfaceTransactionStats->aSurfaceControlStats.end(),
307 "ASurfaceControl not found");
308
309 return aSurfaceControlStats->second.acquireTime;
310}
311
312int ASurfaceTransactionStats_getPreviousReleaseFenceFd(
313 ASurfaceTransactionStats* aSurfaceTransactionStats, ASurfaceControl* aSurfaceControl) {
314 CHECK_NOT_NULL(aSurfaceTransactionStats);
315 CHECK_NOT_NULL(aSurfaceControl);
316
317 const auto& aSurfaceControlStats =
318 aSurfaceTransactionStats->aSurfaceControlStats.find(aSurfaceControl);
319 LOG_ALWAYS_FATAL_IF(
320 aSurfaceControlStats == aSurfaceTransactionStats->aSurfaceControlStats.end(),
321 "ASurfaceControl not found");
322
323 auto& previousReleaseFence = aSurfaceControlStats->second.previousReleaseFence;
324 return (previousReleaseFence) ? previousReleaseFence->dup() : -1;
325}
326
327void ASurfaceTransactionStats_releaseASurfaceControls(ASurfaceControl** aSurfaceControls) {
328 CHECK_NOT_NULL(aSurfaceControls);
329
330 SurfaceControl** surfaceControls = reinterpret_cast<SurfaceControl**>(aSurfaceControls);
331 delete[] surfaceControls;
332}
333
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800334void ASurfaceTransaction_setOnComplete(ASurfaceTransaction* aSurfaceTransaction, void* context,
335 ASurfaceTransaction_OnComplete func) {
336 CHECK_NOT_NULL(aSurfaceTransaction);
337 CHECK_NOT_NULL(context);
338 CHECK_NOT_NULL(func);
339
340 TransactionCompletedCallbackTakesContext callback = [func](void* callback_context,
Marissa Wall1be5a102019-01-18 16:14:04 -0800341 nsecs_t latchTime,
342 const sp<Fence>& presentFence,
343 const std::vector<SurfaceControlStats>& surfaceControlStats) {
344 ASurfaceTransactionStats aSurfaceTransactionStats;
345
346 aSurfaceTransactionStats.latchTime = latchTime;
347 aSurfaceTransactionStats.presentFence = presentFence;
348
349 auto& aSurfaceControlStats = aSurfaceTransactionStats.aSurfaceControlStats;
350
Valerie Haud6a222e2020-01-29 14:27:09 -0800351 for (const auto& [surfaceControl, latchTime, acquireTime, presentFence, previousReleaseFence, transformHint, frameEvents] : surfaceControlStats) {
Marissa Wall1be5a102019-01-18 16:14:04 -0800352 ASurfaceControl* aSurfaceControl = reinterpret_cast<ASurfaceControl*>(surfaceControl.get());
353 aSurfaceControlStats[aSurfaceControl].acquireTime = acquireTime;
354 aSurfaceControlStats[aSurfaceControl].previousReleaseFence = previousReleaseFence;
355 }
356
357 (*func)(callback_context, &aSurfaceTransactionStats);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800358 };
359
360 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
361
362 transaction->addTransactionCompletedCallback(callback, context);
363}
364
Marissa Wall1be5a102019-01-18 16:14:04 -0800365void ASurfaceTransaction_reparent(ASurfaceTransaction* aSurfaceTransaction,
366 ASurfaceControl* aSurfaceControl,
367 ASurfaceControl* newParentASurfaceControl) {
368 CHECK_NOT_NULL(aSurfaceTransaction);
369 CHECK_NOT_NULL(aSurfaceControl);
370
371 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
372 sp<SurfaceControl> newParentSurfaceControl = ASurfaceControl_to_SurfaceControl(
373 newParentASurfaceControl);
Marissa Wall1be5a102019-01-18 16:14:04 -0800374 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
375
Pablo Gamito117040c2020-09-14 08:24:41 +0000376 transaction->reparent(surfaceControl, newParentSurfaceControl);
Marissa Wall1be5a102019-01-18 16:14:04 -0800377}
378
379void ASurfaceTransaction_setVisibility(ASurfaceTransaction* aSurfaceTransaction,
380 ASurfaceControl* aSurfaceControl,
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800381 int8_t visibility) {
382 CHECK_NOT_NULL(aSurfaceTransaction);
383 CHECK_NOT_NULL(aSurfaceControl);
384
385 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
386 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
387
388 switch (visibility) {
389 case ASURFACE_TRANSACTION_VISIBILITY_SHOW:
390 transaction->show(surfaceControl);
391 break;
392 case ASURFACE_TRANSACTION_VISIBILITY_HIDE:
393 transaction->hide(surfaceControl);
394 break;
395 default:
396 LOG_ALWAYS_FATAL("invalid visibility %d", visibility);
397 }
398}
399
Marissa Wall1be5a102019-01-18 16:14:04 -0800400void ASurfaceTransaction_setZOrder(ASurfaceTransaction* aSurfaceTransaction,
401 ASurfaceControl* aSurfaceControl,
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800402 int32_t z_order) {
403 CHECK_NOT_NULL(aSurfaceTransaction);
404 CHECK_NOT_NULL(aSurfaceControl);
405
406 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
407 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
408
409 transaction->setLayer(surfaceControl, z_order);
410}
411
Marissa Wall1be5a102019-01-18 16:14:04 -0800412void ASurfaceTransaction_setBuffer(ASurfaceTransaction* aSurfaceTransaction,
413 ASurfaceControl* aSurfaceControl,
414 AHardwareBuffer* buffer, int acquire_fence_fd) {
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800415 CHECK_NOT_NULL(aSurfaceTransaction);
416 CHECK_NOT_NULL(aSurfaceControl);
417
418 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
419 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
420
421 sp<GraphicBuffer> graphic_buffer(reinterpret_cast<GraphicBuffer*>(buffer));
422
423 transaction->setBuffer(surfaceControl, graphic_buffer);
Marissa Wall1be5a102019-01-18 16:14:04 -0800424 if (acquire_fence_fd != -1) {
425 sp<Fence> fence = new Fence(acquire_fence_fd);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800426 transaction->setAcquireFence(surfaceControl, fence);
427 }
428}
429
430void ASurfaceTransaction_setGeometry(ASurfaceTransaction* aSurfaceTransaction,
431 ASurfaceControl* aSurfaceControl, const ARect& source,
432 const ARect& destination, int32_t transform) {
433 CHECK_NOT_NULL(aSurfaceTransaction);
434 CHECK_NOT_NULL(aSurfaceControl);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800435 CHECK_VALID_RECT(destination);
436
Chavi Weingarten305ec1d2021-04-09 13:37:33 +0000437 Rect sourceRect = static_cast<const Rect&>(source);
438 // Adjust the source so its top and left are not negative
439 sourceRect.left = std::max(sourceRect.left, 0);
440 sourceRect.top = std::max(sourceRect.top, 0);
441 LOG_ALWAYS_FATAL_IF(sourceRect.isEmpty(), "invalid arg passed as source argument");
442
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800443 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
444 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
445
Chavi Weingarten305ec1d2021-04-09 13:37:33 +0000446 transaction->setCrop(surfaceControl, sourceRect);
447
448 float dsdx = (destination.right - destination.left) /
449 static_cast<float>(sourceRect.right - sourceRect.left);
450 float dsdy = (destination.bottom - destination.top) /
451 static_cast<float>(sourceRect.bottom - sourceRect.top);
452
453 transaction->setPosition(surfaceControl, destination.left - (sourceRect.left * dsdx),
454 destination.top - (sourceRect.top * dsdy));
455 transaction->setMatrix(surfaceControl, dsdx, 0, 0, dsdy);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800456 transaction->setTransform(surfaceControl, transform);
Vishnu Nair1ad69542019-05-23 16:27:45 +0800457 bool transformToInverseDisplay = (NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY & transform) ==
458 NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY;
459 transaction->setTransformToDisplayInverse(surfaceControl, transformToInverseDisplay);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800460}
461
chaviwccf3e8b2021-03-25 15:28:44 -0500462void ASurfaceTransaction_setCrop(ASurfaceTransaction* aSurfaceTransaction,
463 ASurfaceControl* aSurfaceControl, const ARect& crop) {
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500464 CHECK_NOT_NULL(aSurfaceTransaction);
465 CHECK_NOT_NULL(aSurfaceControl);
chaviwccf3e8b2021-03-25 15:28:44 -0500466 CHECK_VALID_RECT(crop);
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500467
468 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
469 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
470
chaviwccf3e8b2021-03-25 15:28:44 -0500471 transaction->setCrop(surfaceControl, static_cast<const Rect&>(crop));
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500472}
473
chaviwccf3e8b2021-03-25 15:28:44 -0500474void ASurfaceTransaction_setPosition(ASurfaceTransaction* aSurfaceTransaction,
475 ASurfaceControl* aSurfaceControl, int32_t x, int32_t y) {
476 CHECK_NOT_NULL(aSurfaceTransaction);
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500477 CHECK_NOT_NULL(aSurfaceControl);
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500478
479 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
480 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
481
chaviwccf3e8b2021-03-25 15:28:44 -0500482 transaction->setPosition(surfaceControl, x, y);
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500483}
484
chaviwccf3e8b2021-03-25 15:28:44 -0500485void ASurfaceTransaction_setBufferTransform(ASurfaceTransaction* aSurfaceTransaction,
486 ASurfaceControl* aSurfaceControl, int32_t transform) {
Vasiliy Telezhnikov5ead3aa2021-03-13 19:55:00 -0500487 CHECK_NOT_NULL(aSurfaceTransaction);
488 CHECK_NOT_NULL(aSurfaceControl);
489
490 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
491 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
492
493 transaction->setTransform(surfaceControl, transform);
494 bool transformToInverseDisplay = (NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY & transform) ==
495 NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY;
496 transaction->setTransformToDisplayInverse(surfaceControl, transformToInverseDisplay);
497}
498
chaviwccf3e8b2021-03-25 15:28:44 -0500499void ASurfaceTransaction_setScale(ASurfaceTransaction* aSurfaceTransaction,
500 ASurfaceControl* aSurfaceControl, float xScale, float yScale) {
501 CHECK_NOT_NULL(aSurfaceTransaction);
502 CHECK_NOT_NULL(aSurfaceControl);
503 LOG_ALWAYS_FATAL_IF(xScale < 0, "negative value passed in for xScale");
504 LOG_ALWAYS_FATAL_IF(yScale < 0, "negative value passed in for yScale");
505
506 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
507 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
508
509 transaction->setMatrix(surfaceControl, xScale, 0, 0, yScale);
510}
511
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800512void ASurfaceTransaction_setBufferTransparency(ASurfaceTransaction* aSurfaceTransaction,
513 ASurfaceControl* aSurfaceControl,
514 int8_t transparency) {
515 CHECK_NOT_NULL(aSurfaceTransaction);
516 CHECK_NOT_NULL(aSurfaceControl);
517
518 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
519 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
520
521 uint32_t flags = (transparency == ASURFACE_TRANSACTION_TRANSPARENCY_OPAQUE) ?
522 layer_state_t::eLayerOpaque : 0;
523 transaction->setFlags(surfaceControl, flags, layer_state_t::eLayerOpaque);
524}
525
Marissa Wall1be5a102019-01-18 16:14:04 -0800526void ASurfaceTransaction_setDamageRegion(ASurfaceTransaction* aSurfaceTransaction,
527 ASurfaceControl* aSurfaceControl,
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800528 const ARect rects[], uint32_t count) {
529 CHECK_NOT_NULL(aSurfaceTransaction);
530 CHECK_NOT_NULL(aSurfaceControl);
531
532 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
533 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
534
535 Region region;
536 for (uint32_t i = 0; i < count; ++i) {
Marissa Wallbb9b14f2019-04-23 14:10:15 -0700537 region.orSelf(static_cast<const Rect&>(rects[i]));
538 }
539
540 // Hardware composer interprets a DamageRegion with a single Rect of {0,0,0,0} to be an
541 // undamaged region and {0,0,-1,-1} to be a fully damaged buffer. This is a confusing
542 // distinction for a public api. Instead, default both cases to be a fully damaged buffer.
543 if (count == 1 && region.getBounds().isEmpty()) {
544 transaction->setSurfaceDamageRegion(surfaceControl, Region::INVALID_REGION);
545 return;
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800546 }
547
548 transaction->setSurfaceDamageRegion(surfaceControl, region);
549}
Marissa Wall1be5a102019-01-18 16:14:04 -0800550
551void ASurfaceTransaction_setDesiredPresentTime(ASurfaceTransaction* aSurfaceTransaction,
552 int64_t desiredPresentTime) {
553 CHECK_NOT_NULL(aSurfaceTransaction);
554
555 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
556
557 transaction->setDesiredPresentTime(static_cast<nsecs_t>(desiredPresentTime));
558}
559
560void ASurfaceTransaction_setBufferAlpha(ASurfaceTransaction* aSurfaceTransaction,
561 ASurfaceControl* aSurfaceControl,
562 float alpha) {
563 CHECK_NOT_NULL(aSurfaceTransaction);
564 CHECK_NOT_NULL(aSurfaceControl);
565
566 LOG_ALWAYS_FATAL_IF(alpha < 0.0 || alpha > 1.0, "invalid alpha");
567
568 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
569 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
570
571 transaction->setAlpha(surfaceControl, alpha);
572}
573
Marissa Wall7f24f792019-02-07 14:06:04 -0800574void ASurfaceTransaction_setBufferDataSpace(ASurfaceTransaction* aSurfaceTransaction,
575 ASurfaceControl* aSurfaceControl,
576 ADataSpace aDataSpace) {
577 CHECK_NOT_NULL(aSurfaceTransaction);
578 CHECK_NOT_NULL(aSurfaceControl);
579
580 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Valerie Hau5e18c432019-08-26 12:48:49 -0700581 if (!isDataSpaceValid(surfaceControl, aDataSpace)) {
582 ALOGE("Failed to set buffer dataspace - invalid dataspace");
583 return;
584 }
Marissa Wall7f24f792019-02-07 14:06:04 -0800585 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
Marissa Wall7f24f792019-02-07 14:06:04 -0800586 transaction->setDataspace(surfaceControl, static_cast<ui::Dataspace>(aDataSpace));
587}
588
Marissa Wall1be5a102019-01-18 16:14:04 -0800589void ASurfaceTransaction_setHdrMetadata_smpte2086(ASurfaceTransaction* aSurfaceTransaction,
590 ASurfaceControl* aSurfaceControl,
591 struct AHdrMetadata_smpte2086* metadata) {
592 CHECK_NOT_NULL(aSurfaceTransaction);
593 CHECK_NOT_NULL(aSurfaceControl);
594
595 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
596 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
597
598 HdrMetadata hdrMetadata;
599
600 if (metadata) {
601 hdrMetadata.smpte2086.displayPrimaryRed.x = metadata->displayPrimaryRed.x;
602 hdrMetadata.smpte2086.displayPrimaryRed.y = metadata->displayPrimaryRed.y;
603 hdrMetadata.smpte2086.displayPrimaryGreen.x = metadata->displayPrimaryGreen.x;
604 hdrMetadata.smpte2086.displayPrimaryGreen.y = metadata->displayPrimaryGreen.y;
605 hdrMetadata.smpte2086.displayPrimaryBlue.x = metadata->displayPrimaryBlue.x;
606 hdrMetadata.smpte2086.displayPrimaryBlue.y = metadata->displayPrimaryBlue.y;
607 hdrMetadata.smpte2086.whitePoint.x = metadata->whitePoint.x;
608 hdrMetadata.smpte2086.whitePoint.y = metadata->whitePoint.y;
609 hdrMetadata.smpte2086.minLuminance = metadata->minLuminance;
610 hdrMetadata.smpte2086.maxLuminance = metadata->maxLuminance;
611
612 hdrMetadata.validTypes |= HdrMetadata::SMPTE2086;
613 } else {
614 hdrMetadata.validTypes &= ~HdrMetadata::SMPTE2086;
615 }
616
617 transaction->setHdrMetadata(surfaceControl, hdrMetadata);
618}
619
620void ASurfaceTransaction_setHdrMetadata_cta861_3(ASurfaceTransaction* aSurfaceTransaction,
621 ASurfaceControl* aSurfaceControl,
622 struct AHdrMetadata_cta861_3* metadata) {
623 CHECK_NOT_NULL(aSurfaceTransaction);
624 CHECK_NOT_NULL(aSurfaceControl);
625
626 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
627 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
628
629 HdrMetadata hdrMetadata;
630
631 if (metadata) {
632 hdrMetadata.cta8613.maxContentLightLevel = metadata->maxContentLightLevel;
633 hdrMetadata.cta8613.maxFrameAverageLightLevel = metadata->maxFrameAverageLightLevel;
634
635 hdrMetadata.validTypes |= HdrMetadata::CTA861_3;
636 } else {
637 hdrMetadata.validTypes &= ~HdrMetadata::CTA861_3;
638 }
639
640 transaction->setHdrMetadata(surfaceControl, hdrMetadata);
641}
Valerie Hau5bbfd512019-01-22 17:39:43 -0800642
643void ASurfaceTransaction_setColor(ASurfaceTransaction* aSurfaceTransaction,
644 ASurfaceControl* aSurfaceControl,
645 float r, float g, float b, float alpha,
646 ADataSpace dataspace) {
647 CHECK_NOT_NULL(aSurfaceTransaction);
648 CHECK_NOT_NULL(aSurfaceControl);
649
650 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Valerie Hau5e18c432019-08-26 12:48:49 -0700651 if (!isDataSpaceValid(surfaceControl, dataspace)) {
652 ALOGE("Failed to set buffer dataspace - invalid dataspace");
653 return;
654 }
Valerie Hau5bbfd512019-01-22 17:39:43 -0800655 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
656
657 half3 color;
658 color.r = r;
659 color.g = g;
660 color.b = b;
661
Marin Shalamanov511f9142021-03-16 18:03:30 +0100662 transaction->setBackgroundColor(surfaceControl, color, alpha,
663 static_cast<ui::Dataspace>(dataspace));
Valerie Hau5bbfd512019-01-22 17:39:43 -0800664}
Steven Thomas6cf051e2020-01-14 11:37:21 -0800665
666void ASurfaceTransaction_setFrameRate(ASurfaceTransaction* aSurfaceTransaction,
Steven Thomasdd7bf2f2020-01-31 18:50:02 -0800667 ASurfaceControl* aSurfaceControl, float frameRate,
668 int8_t compatibility) {
Marin Shalamanov511f9142021-03-16 18:03:30 +0100669 ASurfaceTransaction_setFrameRateWithChangeStrategy(
670 aSurfaceTransaction, aSurfaceControl, frameRate, compatibility,
671 ANATIVEWINDOW_CHANGE_FRAME_RATE_ONLY_IF_SEAMLESS);
Marin Shalamanov41ffa8d2020-10-13 12:35:20 +0200672}
673
Marin Shalamanov511f9142021-03-16 18:03:30 +0100674void ASurfaceTransaction_setFrameRateWithChangeStrategy(ASurfaceTransaction* aSurfaceTransaction,
675 ASurfaceControl* aSurfaceControl,
676 float frameRate, int8_t compatibility,
677 int8_t changeFrameRateStrategy) {
Steven Thomas6cf051e2020-01-14 11:37:21 -0800678 CHECK_NOT_NULL(aSurfaceTransaction);
679 CHECK_NOT_NULL(aSurfaceControl);
Steven Thomas6cf051e2020-01-14 11:37:21 -0800680 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
Steven Thomasdd7bf2f2020-01-31 18:50:02 -0800681 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Marin Shalamanov511f9142021-03-16 18:03:30 +0100682 transaction->setFrameRate(surfaceControl, frameRate, compatibility, changeFrameRateStrategy);
Steven Thomas6cf051e2020-01-14 11:37:21 -0800683}
Robert Carrf57c0162021-03-24 15:48:25 -0700684
685void ASurfaceTransaction_setEnableBackPressure(ASurfaceTransaction* aSurfaceTransaction,
686 ASurfaceControl* aSurfaceControl,
687 bool enableBackpressure) {
688 CHECK_NOT_NULL(aSurfaceControl);
689 CHECK_NOT_NULL(aSurfaceTransaction);
690
691 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
692 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
693
694 const uint32_t flags = enableBackpressure ?
695 layer_state_t::eEnableBackpressure : 0;
696 transaction->setFlags(surfaceControl, flags, layer_state_t::eEnableBackpressure);
697}