blob: 6c12c438554fe6e48405ba8781847c5d3655a996 [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);
435 CHECK_VALID_RECT(source);
436 CHECK_VALID_RECT(destination);
437
438 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
439 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
440
441 transaction->setCrop(surfaceControl, static_cast<const Rect&>(source));
442 transaction->setFrame(surfaceControl, static_cast<const Rect&>(destination));
443 transaction->setTransform(surfaceControl, transform);
Vishnu Nair1ad69542019-05-23 16:27:45 +0800444 bool transformToInverseDisplay = (NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY & transform) ==
445 NATIVE_WINDOW_TRANSFORM_INVERSE_DISPLAY;
446 transaction->setTransformToDisplayInverse(surfaceControl, transformToInverseDisplay);
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800447}
448
449void ASurfaceTransaction_setBufferTransparency(ASurfaceTransaction* aSurfaceTransaction,
450 ASurfaceControl* aSurfaceControl,
451 int8_t transparency) {
452 CHECK_NOT_NULL(aSurfaceTransaction);
453 CHECK_NOT_NULL(aSurfaceControl);
454
455 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
456 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
457
458 uint32_t flags = (transparency == ASURFACE_TRANSACTION_TRANSPARENCY_OPAQUE) ?
459 layer_state_t::eLayerOpaque : 0;
460 transaction->setFlags(surfaceControl, flags, layer_state_t::eLayerOpaque);
461}
462
Marissa Wall1be5a102019-01-18 16:14:04 -0800463void ASurfaceTransaction_setDamageRegion(ASurfaceTransaction* aSurfaceTransaction,
464 ASurfaceControl* aSurfaceControl,
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800465 const ARect rects[], uint32_t count) {
466 CHECK_NOT_NULL(aSurfaceTransaction);
467 CHECK_NOT_NULL(aSurfaceControl);
468
469 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
470 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
471
472 Region region;
473 for (uint32_t i = 0; i < count; ++i) {
Marissa Wallbb9b14f2019-04-23 14:10:15 -0700474 region.orSelf(static_cast<const Rect&>(rects[i]));
475 }
476
477 // Hardware composer interprets a DamageRegion with a single Rect of {0,0,0,0} to be an
478 // undamaged region and {0,0,-1,-1} to be a fully damaged buffer. This is a confusing
479 // distinction for a public api. Instead, default both cases to be a fully damaged buffer.
480 if (count == 1 && region.getBounds().isEmpty()) {
481 transaction->setSurfaceDamageRegion(surfaceControl, Region::INVALID_REGION);
482 return;
Marissa Wallf6a73fa2018-12-10 10:41:08 -0800483 }
484
485 transaction->setSurfaceDamageRegion(surfaceControl, region);
486}
Marissa Wall1be5a102019-01-18 16:14:04 -0800487
488void ASurfaceTransaction_setDesiredPresentTime(ASurfaceTransaction* aSurfaceTransaction,
489 int64_t desiredPresentTime) {
490 CHECK_NOT_NULL(aSurfaceTransaction);
491
492 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
493
494 transaction->setDesiredPresentTime(static_cast<nsecs_t>(desiredPresentTime));
495}
496
497void ASurfaceTransaction_setBufferAlpha(ASurfaceTransaction* aSurfaceTransaction,
498 ASurfaceControl* aSurfaceControl,
499 float alpha) {
500 CHECK_NOT_NULL(aSurfaceTransaction);
501 CHECK_NOT_NULL(aSurfaceControl);
502
503 LOG_ALWAYS_FATAL_IF(alpha < 0.0 || alpha > 1.0, "invalid alpha");
504
505 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
506 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
507
508 transaction->setAlpha(surfaceControl, alpha);
509}
510
Marissa Wall7f24f792019-02-07 14:06:04 -0800511void ASurfaceTransaction_setBufferDataSpace(ASurfaceTransaction* aSurfaceTransaction,
512 ASurfaceControl* aSurfaceControl,
513 ADataSpace aDataSpace) {
514 CHECK_NOT_NULL(aSurfaceTransaction);
515 CHECK_NOT_NULL(aSurfaceControl);
516
517 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Valerie Hau5e18c432019-08-26 12:48:49 -0700518 if (!isDataSpaceValid(surfaceControl, aDataSpace)) {
519 ALOGE("Failed to set buffer dataspace - invalid dataspace");
520 return;
521 }
Marissa Wall7f24f792019-02-07 14:06:04 -0800522 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
Marissa Wall7f24f792019-02-07 14:06:04 -0800523 transaction->setDataspace(surfaceControl, static_cast<ui::Dataspace>(aDataSpace));
524}
525
Marissa Wall1be5a102019-01-18 16:14:04 -0800526void ASurfaceTransaction_setHdrMetadata_smpte2086(ASurfaceTransaction* aSurfaceTransaction,
527 ASurfaceControl* aSurfaceControl,
528 struct AHdrMetadata_smpte2086* metadata) {
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 HdrMetadata hdrMetadata;
536
537 if (metadata) {
538 hdrMetadata.smpte2086.displayPrimaryRed.x = metadata->displayPrimaryRed.x;
539 hdrMetadata.smpte2086.displayPrimaryRed.y = metadata->displayPrimaryRed.y;
540 hdrMetadata.smpte2086.displayPrimaryGreen.x = metadata->displayPrimaryGreen.x;
541 hdrMetadata.smpte2086.displayPrimaryGreen.y = metadata->displayPrimaryGreen.y;
542 hdrMetadata.smpte2086.displayPrimaryBlue.x = metadata->displayPrimaryBlue.x;
543 hdrMetadata.smpte2086.displayPrimaryBlue.y = metadata->displayPrimaryBlue.y;
544 hdrMetadata.smpte2086.whitePoint.x = metadata->whitePoint.x;
545 hdrMetadata.smpte2086.whitePoint.y = metadata->whitePoint.y;
546 hdrMetadata.smpte2086.minLuminance = metadata->minLuminance;
547 hdrMetadata.smpte2086.maxLuminance = metadata->maxLuminance;
548
549 hdrMetadata.validTypes |= HdrMetadata::SMPTE2086;
550 } else {
551 hdrMetadata.validTypes &= ~HdrMetadata::SMPTE2086;
552 }
553
554 transaction->setHdrMetadata(surfaceControl, hdrMetadata);
555}
556
557void ASurfaceTransaction_setHdrMetadata_cta861_3(ASurfaceTransaction* aSurfaceTransaction,
558 ASurfaceControl* aSurfaceControl,
559 struct AHdrMetadata_cta861_3* metadata) {
560 CHECK_NOT_NULL(aSurfaceTransaction);
561 CHECK_NOT_NULL(aSurfaceControl);
562
563 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
564 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
565
566 HdrMetadata hdrMetadata;
567
568 if (metadata) {
569 hdrMetadata.cta8613.maxContentLightLevel = metadata->maxContentLightLevel;
570 hdrMetadata.cta8613.maxFrameAverageLightLevel = metadata->maxFrameAverageLightLevel;
571
572 hdrMetadata.validTypes |= HdrMetadata::CTA861_3;
573 } else {
574 hdrMetadata.validTypes &= ~HdrMetadata::CTA861_3;
575 }
576
577 transaction->setHdrMetadata(surfaceControl, hdrMetadata);
578}
Valerie Hau5bbfd512019-01-22 17:39:43 -0800579
580void ASurfaceTransaction_setColor(ASurfaceTransaction* aSurfaceTransaction,
581 ASurfaceControl* aSurfaceControl,
582 float r, float g, float b, float alpha,
583 ADataSpace dataspace) {
584 CHECK_NOT_NULL(aSurfaceTransaction);
585 CHECK_NOT_NULL(aSurfaceControl);
586
587 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Valerie Hau5e18c432019-08-26 12:48:49 -0700588 if (!isDataSpaceValid(surfaceControl, dataspace)) {
589 ALOGE("Failed to set buffer dataspace - invalid dataspace");
590 return;
591 }
Valerie Hau5bbfd512019-01-22 17:39:43 -0800592 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
593
594 half3 color;
595 color.r = r;
596 color.g = g;
597 color.b = b;
598
Marin Shalamanov511f9142021-03-16 18:03:30 +0100599 transaction->setBackgroundColor(surfaceControl, color, alpha,
600 static_cast<ui::Dataspace>(dataspace));
Valerie Hau5bbfd512019-01-22 17:39:43 -0800601}
Steven Thomas6cf051e2020-01-14 11:37:21 -0800602
603void ASurfaceTransaction_setFrameRate(ASurfaceTransaction* aSurfaceTransaction,
Steven Thomasdd7bf2f2020-01-31 18:50:02 -0800604 ASurfaceControl* aSurfaceControl, float frameRate,
605 int8_t compatibility) {
Marin Shalamanov511f9142021-03-16 18:03:30 +0100606 ASurfaceTransaction_setFrameRateWithChangeStrategy(
607 aSurfaceTransaction, aSurfaceControl, frameRate, compatibility,
608 ANATIVEWINDOW_CHANGE_FRAME_RATE_ONLY_IF_SEAMLESS);
Marin Shalamanov41ffa8d2020-10-13 12:35:20 +0200609}
610
Marin Shalamanov511f9142021-03-16 18:03:30 +0100611void ASurfaceTransaction_setFrameRateWithChangeStrategy(ASurfaceTransaction* aSurfaceTransaction,
612 ASurfaceControl* aSurfaceControl,
613 float frameRate, int8_t compatibility,
614 int8_t changeFrameRateStrategy) {
Steven Thomas6cf051e2020-01-14 11:37:21 -0800615 CHECK_NOT_NULL(aSurfaceTransaction);
616 CHECK_NOT_NULL(aSurfaceControl);
Steven Thomas6cf051e2020-01-14 11:37:21 -0800617 Transaction* transaction = ASurfaceTransaction_to_Transaction(aSurfaceTransaction);
Steven Thomasdd7bf2f2020-01-31 18:50:02 -0800618 sp<SurfaceControl> surfaceControl = ASurfaceControl_to_SurfaceControl(aSurfaceControl);
Marin Shalamanov511f9142021-03-16 18:03:30 +0100619 transaction->setFrameRate(surfaceControl, frameRate, compatibility, changeFrameRateStrategy);
Steven Thomas6cf051e2020-01-14 11:37:21 -0800620}