blob: ae628e13d4ac7e5f52dd4ac28039e0ecb319b460 [file] [log] [blame]
Chia-I Wuaab99f52016-10-05 12:59:58 +08001/*
2 * Copyright 2016 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#undef LOG_TAG
18#define LOG_TAG "HwcComposer"
19
20#include <inttypes.h>
21#include <log/log.h>
Chia-I Wu06d63de2017-01-04 14:58:51 +080022#include <gui/BufferQueue.h>
Chia-I Wuaab99f52016-10-05 12:59:58 +080023
24#include "ComposerHal.h"
25
26namespace android {
27
28using hardware::Return;
29using hardware::hidl_vec;
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010030using hardware::hidl_handle;
Chia-I Wuaab99f52016-10-05 12:59:58 +080031
32namespace Hwc2 {
33
34namespace {
35
36class BufferHandle {
37public:
38 BufferHandle(const native_handle_t* buffer)
39 {
40 // nullptr is not a valid handle to HIDL
41 mHandle = (buffer) ? buffer : native_handle_init(mStorage, 0, 0);
42 }
43
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010044 operator const hidl_handle&() const
Chia-I Wuaab99f52016-10-05 12:59:58 +080045 {
46 return mHandle;
47 }
48
49private:
50 NATIVE_HANDLE_DECLARE_STORAGE(mStorage, 0, 0);
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010051 hidl_handle mHandle;
Chia-I Wuaab99f52016-10-05 12:59:58 +080052};
53
54class FenceHandle
55{
56public:
57 FenceHandle(int fd, bool owned)
58 : mOwned(owned)
59 {
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010060 native_handle_t* handle;
Chia-I Wuaab99f52016-10-05 12:59:58 +080061 if (fd >= 0) {
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010062 handle = native_handle_init(mStorage, 1, 0);
63 handle->data[0] = fd;
Chia-I Wuaab99f52016-10-05 12:59:58 +080064 } else {
65 // nullptr is not a valid handle to HIDL
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010066 handle = native_handle_init(mStorage, 0, 0);
Chia-I Wuaab99f52016-10-05 12:59:58 +080067 }
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010068 mHandle = handle;
Chia-I Wuaab99f52016-10-05 12:59:58 +080069 }
70
71 ~FenceHandle()
72 {
73 if (mOwned) {
74 native_handle_close(mHandle);
75 }
76 }
77
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010078 operator const hidl_handle&() const
Chia-I Wuaab99f52016-10-05 12:59:58 +080079 {
80 return mHandle;
81 }
82
83private:
84 bool mOwned;
85 NATIVE_HANDLE_DECLARE_STORAGE(mStorage, 1, 0);
Martijn Coenen7c5a92f2016-11-21 10:01:07 +010086 hidl_handle mHandle;
Chia-I Wuaab99f52016-10-05 12:59:58 +080087};
88
89// assume NO_RESOURCES when Status::isOk returns false
90constexpr Error kDefaultError = Error::NO_RESOURCES;
91
92template<typename T, typename U>
93T unwrapRet(Return<T>& ret, const U& default_val)
94{
Steven Moreland9d021002017-01-03 17:10:54 -080095 return (ret.isOk()) ? static_cast<T>(ret) :
Chia-I Wuaab99f52016-10-05 12:59:58 +080096 static_cast<T>(default_val);
97}
98
99Error unwrapRet(Return<Error>& ret)
100{
101 return unwrapRet(ret, kDefaultError);
102}
103
Chia-I Wuaab99f52016-10-05 12:59:58 +0800104} // anonymous namespace
105
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500106Composer::CommandWriter::CommandWriter(uint32_t initialMaxSize)
107 : CommandWriterBase(initialMaxSize) {}
108
109Composer::CommandWriter::~CommandWriter()
Chia-I Wuaab99f52016-10-05 12:59:58 +0800110{
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500111}
112
113void Composer::CommandWriter::setLayerInfo(uint32_t type, uint32_t appId)
114{
115 constexpr uint16_t kSetLayerInfoLength = 2;
116 beginCommand(
117 static_cast<IComposerClient::Command>(
118 IVrComposerClient::VrCommand::SET_LAYER_INFO),
119 kSetLayerInfoLength);
120 write(type);
121 write(appId);
122 endCommand();
123}
124
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -0400125void Composer::CommandWriter::setClientTargetMetadata(
126 const IVrComposerClient::BufferMetadata& metadata)
127{
128 constexpr uint16_t kSetClientTargetMetadataLength = 7;
129 beginCommand(
130 static_cast<IComposerClient::Command>(
131 IVrComposerClient::VrCommand::SET_CLIENT_TARGET_METADATA),
132 kSetClientTargetMetadataLength);
133 writeBufferMetadata(metadata);
134 endCommand();
135}
136
137void Composer::CommandWriter::setLayerBufferMetadata(
138 const IVrComposerClient::BufferMetadata& metadata)
139{
140 constexpr uint16_t kSetLayerBufferMetadataLength = 7;
141 beginCommand(
142 static_cast<IComposerClient::Command>(
143 IVrComposerClient::VrCommand::SET_LAYER_BUFFER_METADATA),
144 kSetLayerBufferMetadataLength);
145 writeBufferMetadata(metadata);
146 endCommand();
147}
148
149void Composer::CommandWriter::writeBufferMetadata(
150 const IVrComposerClient::BufferMetadata& metadata)
151{
152 write(metadata.width);
153 write(metadata.height);
154 write(metadata.stride);
155 write(metadata.layerCount);
156 writeSigned(static_cast<int32_t>(metadata.format));
157 write64(metadata.usage);
158}
159
Hendrik Wagenaar87670ff2017-02-01 12:10:46 -0800160Composer::Composer(bool useVrComposer)
161 : mWriter(kWriterInitialSize),
162 mIsUsingVrComposer(useVrComposer)
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500163{
Hendrik Wagenaar87670ff2017-02-01 12:10:46 -0800164 if (mIsUsingVrComposer) {
Daniel Nicoarae96afe62017-03-24 15:15:50 -0400165 mComposer = IComposer::getService("vr");
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500166 } else {
Chris Phoenixf5eb5e62017-01-24 14:08:33 -0800167 mComposer = IComposer::getService(); // use default name
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500168 }
169
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800170 if (mComposer == nullptr) {
Chia-I Wuaab99f52016-10-05 12:59:58 +0800171 LOG_ALWAYS_FATAL("failed to get hwcomposer service");
172 }
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800173
174 mComposer->createClient(
175 [&](const auto& tmpError, const auto& tmpClient)
176 {
177 if (tmpError == Error::NONE) {
178 mClient = tmpClient;
179 }
180 });
181 if (mClient == nullptr) {
182 LOG_ALWAYS_FATAL("failed to create composer client");
183 }
Daniel Nicoaraa50abc22017-05-15 10:34:08 -0400184
185 if (mIsUsingVrComposer) {
186 sp<IVrComposerClient> vrClient = IVrComposerClient::castFrom(mClient);
187 if (vrClient == nullptr) {
188 LOG_ALWAYS_FATAL("failed to create vr composer client");
189 }
190 }
Chia-I Wuaab99f52016-10-05 12:59:58 +0800191}
192
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800193std::vector<IComposer::Capability> Composer::getCapabilities()
Chia-I Wuaab99f52016-10-05 12:59:58 +0800194{
195 std::vector<IComposer::Capability> capabilities;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800196 mComposer->getCapabilities(
Chia-I Wuaab99f52016-10-05 12:59:58 +0800197 [&](const auto& tmpCapabilities) {
Chia-I Wu67e376d2016-12-19 11:36:22 +0800198 capabilities = tmpCapabilities;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800199 });
200
201 return capabilities;
202}
203
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800204std::string Composer::dumpDebugInfo()
Chia-I Wuaab99f52016-10-05 12:59:58 +0800205{
206 std::string info;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800207 mComposer->dumpDebugInfo([&](const auto& tmpInfo) {
Chia-I Wuaab99f52016-10-05 12:59:58 +0800208 info = tmpInfo.c_str();
209 });
210
211 return info;
212}
213
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800214void Composer::registerCallback(const sp<IComposerCallback>& callback)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800215{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800216 auto ret = mClient->registerCallback(callback);
Steven Moreland9d021002017-01-03 17:10:54 -0800217 if (!ret.isOk()) {
Chia-I Wuaab99f52016-10-05 12:59:58 +0800218 ALOGE("failed to register IComposerCallback");
219 }
220}
221
Steven Thomas0af4b9f2017-04-26 14:34:01 -0700222void Composer::resetCommands() {
223 mWriter.reset();
224}
225
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800226uint32_t Composer::getMaxVirtualDisplayCount()
Chia-I Wuaab99f52016-10-05 12:59:58 +0800227{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800228 auto ret = mClient->getMaxVirtualDisplayCount();
Chia-I Wuaab99f52016-10-05 12:59:58 +0800229 return unwrapRet(ret, 0);
230}
231
232Error Composer::createVirtualDisplay(uint32_t width, uint32_t height,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800233 PixelFormat* format, Display* outDisplay)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800234{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800235 const uint32_t bufferSlotCount = 1;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800236 Error error = kDefaultError;
Chia-I Wu67e376d2016-12-19 11:36:22 +0800237 mClient->createVirtualDisplay(width, height, *format, bufferSlotCount,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800238 [&](const auto& tmpError, const auto& tmpDisplay,
239 const auto& tmpFormat) {
240 error = tmpError;
241 if (error != Error::NONE) {
242 return;
243 }
244
Chia-I Wu67e376d2016-12-19 11:36:22 +0800245 *outDisplay = tmpDisplay;
246 *format = tmpFormat;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800247 });
248
249 return error;
250}
251
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800252Error Composer::destroyVirtualDisplay(Display display)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800253{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800254 auto ret = mClient->destroyVirtualDisplay(display);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800255 return unwrapRet(ret);
256}
257
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800258Error Composer::acceptDisplayChanges(Display display)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800259{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800260 mWriter.selectDisplay(display);
261 mWriter.acceptDisplayChanges();
262 return Error::NONE;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800263}
264
Chia-I Wu67e376d2016-12-19 11:36:22 +0800265Error Composer::createLayer(Display display, Layer* outLayer)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800266{
267 Error error = kDefaultError;
Chia-I Wu06d63de2017-01-04 14:58:51 +0800268 mClient->createLayer(display, BufferQueue::NUM_BUFFER_SLOTS,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800269 [&](const auto& tmpError, const auto& tmpLayer) {
270 error = tmpError;
271 if (error != Error::NONE) {
272 return;
273 }
274
Chia-I Wu67e376d2016-12-19 11:36:22 +0800275 *outLayer = tmpLayer;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800276 });
277
278 return error;
279}
280
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800281Error Composer::destroyLayer(Display display, Layer layer)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800282{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800283 auto ret = mClient->destroyLayer(display, layer);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800284 return unwrapRet(ret);
285}
286
Chia-I Wu67e376d2016-12-19 11:36:22 +0800287Error Composer::getActiveConfig(Display display, Config* outConfig)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800288{
289 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800290 mClient->getActiveConfig(display,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800291 [&](const auto& tmpError, const auto& tmpConfig) {
292 error = tmpError;
293 if (error != Error::NONE) {
294 return;
295 }
296
Chia-I Wu67e376d2016-12-19 11:36:22 +0800297 *outConfig = tmpConfig;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800298 });
299
300 return error;
301}
302
303Error Composer::getChangedCompositionTypes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800304 std::vector<Layer>* outLayers,
305 std::vector<IComposerClient::Composition>* outTypes)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800306{
Chia-I Wu67e376d2016-12-19 11:36:22 +0800307 mReader.takeChangedCompositionTypes(display, outLayers, outTypes);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800308 return Error::NONE;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800309}
310
311Error Composer::getColorModes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800312 std::vector<ColorMode>* outModes)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800313{
314 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800315 mClient->getColorModes(display,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800316 [&](const auto& tmpError, const auto& tmpModes) {
317 error = tmpError;
318 if (error != Error::NONE) {
319 return;
320 }
321
Chia-I Wu67e376d2016-12-19 11:36:22 +0800322 *outModes = tmpModes;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800323 });
324
325 return error;
326}
327
328Error Composer::getDisplayAttribute(Display display, Config config,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800329 IComposerClient::Attribute attribute, int32_t* outValue)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800330{
331 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800332 mClient->getDisplayAttribute(display, config, attribute,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800333 [&](const auto& tmpError, const auto& tmpValue) {
334 error = tmpError;
335 if (error != Error::NONE) {
336 return;
337 }
338
Chia-I Wu67e376d2016-12-19 11:36:22 +0800339 *outValue = tmpValue;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800340 });
341
342 return error;
343}
344
345Error Composer::getDisplayConfigs(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800346 std::vector<Config>* outConfigs)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800347{
348 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800349 mClient->getDisplayConfigs(display,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800350 [&](const auto& tmpError, const auto& tmpConfigs) {
351 error = tmpError;
352 if (error != Error::NONE) {
353 return;
354 }
355
Chia-I Wu67e376d2016-12-19 11:36:22 +0800356 *outConfigs = tmpConfigs;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800357 });
358
359 return error;
360}
361
Chia-I Wu67e376d2016-12-19 11:36:22 +0800362Error Composer::getDisplayName(Display display, std::string* outName)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800363{
364 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800365 mClient->getDisplayName(display,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800366 [&](const auto& tmpError, const auto& tmpName) {
367 error = tmpError;
368 if (error != Error::NONE) {
369 return;
370 }
371
Chia-I Wu67e376d2016-12-19 11:36:22 +0800372 *outName = tmpName.c_str();
Chia-I Wuaab99f52016-10-05 12:59:58 +0800373 });
374
375 return error;
376}
377
378Error Composer::getDisplayRequests(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800379 uint32_t* outDisplayRequestMask, std::vector<Layer>* outLayers,
380 std::vector<uint32_t>* outLayerRequestMasks)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800381{
Chia-I Wu67e376d2016-12-19 11:36:22 +0800382 mReader.takeDisplayRequests(display, outDisplayRequestMask,
383 outLayers, outLayerRequestMasks);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800384 return Error::NONE;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800385}
386
Chia-I Wu67e376d2016-12-19 11:36:22 +0800387Error Composer::getDisplayType(Display display,
388 IComposerClient::DisplayType* outType)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800389{
390 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800391 mClient->getDisplayType(display,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800392 [&](const auto& tmpError, const auto& tmpType) {
393 error = tmpError;
394 if (error != Error::NONE) {
395 return;
396 }
397
Chia-I Wu67e376d2016-12-19 11:36:22 +0800398 *outType = tmpType;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800399 });
400
401 return error;
402}
403
Chia-I Wu67e376d2016-12-19 11:36:22 +0800404Error Composer::getDozeSupport(Display display, bool* outSupport)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800405{
406 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800407 mClient->getDozeSupport(display,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800408 [&](const auto& tmpError, const auto& tmpSupport) {
409 error = tmpError;
410 if (error != Error::NONE) {
411 return;
412 }
413
Chia-I Wu67e376d2016-12-19 11:36:22 +0800414 *outSupport = tmpSupport;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800415 });
416
417 return error;
418}
419
Chia-I Wu67e376d2016-12-19 11:36:22 +0800420Error Composer::getHdrCapabilities(Display display,
421 std::vector<Hdr>* outTypes, float* outMaxLuminance,
422 float* outMaxAverageLuminance, float* outMinLuminance)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800423{
424 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800425 mClient->getHdrCapabilities(display,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800426 [&](const auto& tmpError, const auto& tmpTypes,
427 const auto& tmpMaxLuminance,
428 const auto& tmpMaxAverageLuminance,
429 const auto& tmpMinLuminance) {
430 error = tmpError;
431 if (error != Error::NONE) {
432 return;
433 }
434
Chia-I Wu67e376d2016-12-19 11:36:22 +0800435 *outTypes = tmpTypes;
436 *outMaxLuminance = tmpMaxLuminance;
437 *outMaxAverageLuminance = tmpMaxAverageLuminance;
438 *outMinLuminance = tmpMinLuminance;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800439 });
440
441 return error;
442}
443
Chia-I Wu67e376d2016-12-19 11:36:22 +0800444Error Composer::getReleaseFences(Display display,
445 std::vector<Layer>* outLayers, std::vector<int>* outReleaseFences)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800446{
Chia-I Wu67e376d2016-12-19 11:36:22 +0800447 mReader.takeReleaseFences(display, outLayers, outReleaseFences);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800448 return Error::NONE;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800449}
450
Chia-I Wu67e376d2016-12-19 11:36:22 +0800451Error Composer::presentDisplay(Display display, int* outPresentFence)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800452{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800453 mWriter.selectDisplay(display);
454 mWriter.presentDisplay();
Chia-I Wuaab99f52016-10-05 12:59:58 +0800455
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800456 Error error = execute();
457 if (error != Error::NONE) {
458 return error;
459 }
Chia-I Wuaab99f52016-10-05 12:59:58 +0800460
Chia-I Wu67e376d2016-12-19 11:36:22 +0800461 mReader.takePresentFence(display, outPresentFence);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800462
463 return Error::NONE;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800464}
465
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800466Error Composer::setActiveConfig(Display display, Config config)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800467{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800468 auto ret = mClient->setActiveConfig(display, config);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800469 return unwrapRet(ret);
470}
471
Chia-I Wu06d63de2017-01-04 14:58:51 +0800472Error Composer::setClientTarget(Display display, uint32_t slot,
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -0400473 const sp<GraphicBuffer>& target,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800474 int acquireFence, Dataspace dataspace,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800475 const std::vector<IComposerClient::Rect>& damage)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800476{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800477 mWriter.selectDisplay(display);
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -0400478 if (mIsUsingVrComposer && target.get()) {
479 IVrComposerClient::BufferMetadata metadata = {
480 .width = target->getWidth(),
481 .height = target->getHeight(),
482 .stride = target->getStride(),
483 .layerCount = target->getLayerCount(),
484 .format = static_cast<PixelFormat>(target->getPixelFormat()),
485 .usage = target->getUsage(),
486 };
487 mWriter.setClientTargetMetadata(metadata);
488 }
489
490 const native_handle_t* handle = nullptr;
491 if (target.get()) {
492 handle = target->getNativeBuffer()->handle;
493 }
494
495 mWriter.setClientTarget(slot, handle, acquireFence, dataspace, damage);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800496 return Error::NONE;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800497}
498
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800499Error Composer::setColorMode(Display display, ColorMode mode)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800500{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800501 auto ret = mClient->setColorMode(display, mode);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800502 return unwrapRet(ret);
503}
504
505Error Composer::setColorTransform(Display display, const float* matrix,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800506 ColorTransform hint)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800507{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800508 mWriter.selectDisplay(display);
509 mWriter.setColorTransform(matrix, hint);
510 return Error::NONE;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800511}
512
513Error Composer::setOutputBuffer(Display display, const native_handle_t* buffer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800514 int releaseFence)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800515{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800516 mWriter.selectDisplay(display);
517 mWriter.setOutputBuffer(0, buffer, dup(releaseFence));
518 return Error::NONE;
519}
Chia-I Wuaab99f52016-10-05 12:59:58 +0800520
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800521Error Composer::setPowerMode(Display display, IComposerClient::PowerMode mode)
522{
523 auto ret = mClient->setPowerMode(display, mode);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800524 return unwrapRet(ret);
525}
526
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800527Error Composer::setVsyncEnabled(Display display, IComposerClient::Vsync enabled)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800528{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800529 auto ret = mClient->setVsyncEnabled(display, enabled);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800530 return unwrapRet(ret);
531}
532
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800533Error Composer::setClientTargetSlotCount(Display display)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800534{
Chia-I Wu06d63de2017-01-04 14:58:51 +0800535 const uint32_t bufferSlotCount = BufferQueue::NUM_BUFFER_SLOTS;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800536 auto ret = mClient->setClientTargetSlotCount(display, bufferSlotCount);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800537 return unwrapRet(ret);
538}
539
Chia-I Wu67e376d2016-12-19 11:36:22 +0800540Error Composer::validateDisplay(Display display, uint32_t* outNumTypes,
541 uint32_t* outNumRequests)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800542{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800543 mWriter.selectDisplay(display);
544 mWriter.validateDisplay();
545
546 Error error = execute();
547 if (error != Error::NONE) {
548 return error;
549 }
550
Chia-I Wu67e376d2016-12-19 11:36:22 +0800551 mReader.hasChanges(display, outNumTypes, outNumRequests);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800552
553 return Error::NONE;
554}
555
556Error Composer::setCursorPosition(Display display, Layer layer,
557 int32_t x, int32_t y)
558{
559 mWriter.selectDisplay(display);
560 mWriter.selectLayer(layer);
561 mWriter.setLayerCursorPosition(x, y);
562 return Error::NONE;
563}
564
565Error Composer::setLayerBuffer(Display display, Layer layer,
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -0400566 uint32_t slot, const sp<GraphicBuffer>& buffer, int acquireFence)
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800567{
568 mWriter.selectDisplay(display);
569 mWriter.selectLayer(layer);
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -0400570 if (mIsUsingVrComposer && buffer.get()) {
571 IVrComposerClient::BufferMetadata metadata = {
572 .width = buffer->getWidth(),
573 .height = buffer->getHeight(),
574 .stride = buffer->getStride(),
575 .layerCount = buffer->getLayerCount(),
576 .format = static_cast<PixelFormat>(buffer->getPixelFormat()),
577 .usage = buffer->getUsage(),
578 };
579 mWriter.setLayerBufferMetadata(metadata);
580 }
581
582 const native_handle_t* handle = nullptr;
583 if (buffer.get()) {
584 handle = buffer->getNativeBuffer()->handle;
585 }
586
587 mWriter.setLayerBuffer(slot, handle, acquireFence);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800588 return Error::NONE;
589}
590
591Error Composer::setLayerSurfaceDamage(Display display, Layer layer,
592 const std::vector<IComposerClient::Rect>& damage)
593{
594 mWriter.selectDisplay(display);
595 mWriter.selectLayer(layer);
596 mWriter.setLayerSurfaceDamage(damage);
597 return Error::NONE;
598}
599
600Error Composer::setLayerBlendMode(Display display, Layer layer,
601 IComposerClient::BlendMode mode)
602{
603 mWriter.selectDisplay(display);
604 mWriter.selectLayer(layer);
605 mWriter.setLayerBlendMode(mode);
606 return Error::NONE;
607}
608
609Error Composer::setLayerColor(Display display, Layer layer,
610 const IComposerClient::Color& color)
611{
612 mWriter.selectDisplay(display);
613 mWriter.selectLayer(layer);
614 mWriter.setLayerColor(color);
615 return Error::NONE;
616}
617
618Error Composer::setLayerCompositionType(Display display, Layer layer,
619 IComposerClient::Composition type)
620{
621 mWriter.selectDisplay(display);
622 mWriter.selectLayer(layer);
623 mWriter.setLayerCompositionType(type);
624 return Error::NONE;
625}
626
627Error Composer::setLayerDataspace(Display display, Layer layer,
628 Dataspace dataspace)
629{
630 mWriter.selectDisplay(display);
631 mWriter.selectLayer(layer);
632 mWriter.setLayerDataspace(dataspace);
633 return Error::NONE;
634}
635
636Error Composer::setLayerDisplayFrame(Display display, Layer layer,
637 const IComposerClient::Rect& frame)
638{
639 mWriter.selectDisplay(display);
640 mWriter.selectLayer(layer);
641 mWriter.setLayerDisplayFrame(frame);
642 return Error::NONE;
643}
644
645Error Composer::setLayerPlaneAlpha(Display display, Layer layer,
646 float alpha)
647{
648 mWriter.selectDisplay(display);
649 mWriter.selectLayer(layer);
650 mWriter.setLayerPlaneAlpha(alpha);
651 return Error::NONE;
652}
653
654Error Composer::setLayerSidebandStream(Display display, Layer layer,
655 const native_handle_t* stream)
656{
657 mWriter.selectDisplay(display);
658 mWriter.selectLayer(layer);
659 mWriter.setLayerSidebandStream(stream);
660 return Error::NONE;
661}
662
663Error Composer::setLayerSourceCrop(Display display, Layer layer,
664 const IComposerClient::FRect& crop)
665{
666 mWriter.selectDisplay(display);
667 mWriter.selectLayer(layer);
668 mWriter.setLayerSourceCrop(crop);
669 return Error::NONE;
670}
671
672Error Composer::setLayerTransform(Display display, Layer layer,
673 Transform transform)
674{
675 mWriter.selectDisplay(display);
676 mWriter.selectLayer(layer);
677 mWriter.setLayerTransform(transform);
678 return Error::NONE;
679}
680
681Error Composer::setLayerVisibleRegion(Display display, Layer layer,
682 const std::vector<IComposerClient::Rect>& visible)
683{
684 mWriter.selectDisplay(display);
685 mWriter.selectLayer(layer);
686 mWriter.setLayerVisibleRegion(visible);
687 return Error::NONE;
688}
689
690Error Composer::setLayerZOrder(Display display, Layer layer, uint32_t z)
691{
692 mWriter.selectDisplay(display);
693 mWriter.selectLayer(layer);
694 mWriter.setLayerZOrder(z);
695 return Error::NONE;
696}
697
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500698Error Composer::setLayerInfo(Display display, Layer layer, uint32_t type,
699 uint32_t appId)
700{
Hendrik Wagenaar87670ff2017-02-01 12:10:46 -0800701 if (mIsUsingVrComposer) {
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500702 mWriter.selectDisplay(display);
703 mWriter.selectLayer(layer);
704 mWriter.setLayerInfo(type, appId);
705 }
706 return Error::NONE;
707}
708
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800709Error Composer::execute()
710{
711 // prepare input command queue
712 bool queueChanged = false;
713 uint32_t commandLength = 0;
714 hidl_vec<hidl_handle> commandHandles;
Chia-I Wu67e376d2016-12-19 11:36:22 +0800715 if (!mWriter.writeQueue(&queueChanged, &commandLength, &commandHandles)) {
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800716 mWriter.reset();
717 return Error::NO_RESOURCES;
718 }
719
720 // set up new input command queue if necessary
721 if (queueChanged) {
722 auto ret = mClient->setInputCommandQueue(*mWriter.getMQDescriptor());
723 auto error = unwrapRet(ret);
724 if (error != Error::NONE) {
725 mWriter.reset();
726 return error;
727 }
728 }
729
Chia-I Wuaab99f52016-10-05 12:59:58 +0800730 Error error = kDefaultError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800731 mClient->executeCommands(commandLength, commandHandles,
732 [&](const auto& tmpError, const auto& tmpOutChanged,
733 const auto& tmpOutLength, const auto& tmpOutHandles)
734 {
Chia-I Wuaab99f52016-10-05 12:59:58 +0800735 error = tmpError;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800736
737 // set up new output command queue if necessary
738 if (error == Error::NONE && tmpOutChanged) {
739 error = kDefaultError;
740 mClient->getOutputCommandQueue(
741 [&](const auto& tmpError,
742 const auto& tmpDescriptor)
743 {
744 error = tmpError;
745 if (error != Error::NONE) {
746 return;
747 }
748
749 mReader.setMQDescriptor(tmpDescriptor);
750 });
751 }
752
Chia-I Wuaab99f52016-10-05 12:59:58 +0800753 if (error != Error::NONE) {
754 return;
755 }
756
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800757 if (mReader.readQueue(tmpOutLength, tmpOutHandles)) {
758 error = mReader.parse();
759 mReader.reset();
760 } else {
761 error = Error::NO_RESOURCES;
762 }
Chia-I Wuaab99f52016-10-05 12:59:58 +0800763 });
764
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800765 if (error == Error::NONE) {
766 std::vector<CommandReader::CommandError> commandErrors =
767 mReader.takeErrors();
768
769 for (const auto& cmdErr : commandErrors) {
770 auto command = mWriter.getCommand(cmdErr.location);
771
772 if (command == IComposerClient::Command::VALIDATE_DISPLAY ||
773 command == IComposerClient::Command::PRESENT_DISPLAY) {
774 error = cmdErr.error;
775 } else {
776 ALOGW("command 0x%x generated error %d",
777 command, cmdErr.error);
778 }
779 }
780 }
781
782 mWriter.reset();
783
Chia-I Wuaab99f52016-10-05 12:59:58 +0800784 return error;
785}
786
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800787CommandReader::~CommandReader()
Chia-I Wuaab99f52016-10-05 12:59:58 +0800788{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800789 resetData();
Chia-I Wuaab99f52016-10-05 12:59:58 +0800790}
791
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800792Error CommandReader::parse()
Chia-I Wuaab99f52016-10-05 12:59:58 +0800793{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800794 resetData();
Chia-I Wuaab99f52016-10-05 12:59:58 +0800795
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800796 IComposerClient::Command command;
797 uint16_t length = 0;
798
799 while (!isEmpty()) {
Chia-I Wu67e376d2016-12-19 11:36:22 +0800800 if (!beginCommand(&command, &length)) {
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800801 break;
802 }
803
804 bool parsed = false;
805 switch (command) {
806 case IComposerClient::Command::SELECT_DISPLAY:
807 parsed = parseSelectDisplay(length);
808 break;
809 case IComposerClient::Command::SET_ERROR:
810 parsed = parseSetError(length);
811 break;
812 case IComposerClient::Command::SET_CHANGED_COMPOSITION_TYPES:
813 parsed = parseSetChangedCompositionTypes(length);
814 break;
815 case IComposerClient::Command::SET_DISPLAY_REQUESTS:
816 parsed = parseSetDisplayRequests(length);
817 break;
818 case IComposerClient::Command::SET_PRESENT_FENCE:
819 parsed = parseSetPresentFence(length);
820 break;
821 case IComposerClient::Command::SET_RELEASE_FENCES:
822 parsed = parseSetReleaseFences(length);
823 break;
824 default:
825 parsed = false;
826 break;
827 }
828
829 endCommand();
830
831 if (!parsed) {
832 ALOGE("failed to parse command 0x%x length %" PRIu16,
833 command, length);
834 break;
835 }
836 }
837
838 return isEmpty() ? Error::NONE : Error::NO_RESOURCES;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800839}
840
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800841bool CommandReader::parseSelectDisplay(uint16_t length)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800842{
Daniel Nicoara3c9cbd42017-01-17 12:04:06 -0500843 if (length != CommandWriterBase::kSelectDisplayLength) {
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800844 return false;
845 }
Chia-I Wuaab99f52016-10-05 12:59:58 +0800846
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800847 mCurrentReturnData = &mReturnData[read64()];
848
849 return true;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800850}
851
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800852bool CommandReader::parseSetError(uint16_t length)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800853{
Daniel Nicoara3c9cbd42017-01-17 12:04:06 -0500854 if (length != CommandWriterBase::kSetErrorLength) {
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800855 return false;
856 }
857
858 auto location = read();
859 auto error = static_cast<Error>(readSigned());
860
861 mErrors.emplace_back(CommandError{location, error});
862
863 return true;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800864}
865
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800866bool CommandReader::parseSetChangedCompositionTypes(uint16_t length)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800867{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800868 // (layer id, composition type) pairs
869 if (length % 3 != 0 || !mCurrentReturnData) {
870 return false;
871 }
872
873 uint32_t count = length / 3;
874 mCurrentReturnData->changedLayers.reserve(count);
875 mCurrentReturnData->compositionTypes.reserve(count);
876 while (count > 0) {
877 auto layer = read64();
878 auto type = static_cast<IComposerClient::Composition>(readSigned());
879
880 mCurrentReturnData->changedLayers.push_back(layer);
881 mCurrentReturnData->compositionTypes.push_back(type);
882
883 count--;
884 }
885
886 return true;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800887}
888
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800889bool CommandReader::parseSetDisplayRequests(uint16_t length)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800890{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800891 // display requests followed by (layer id, layer requests) pairs
892 if (length % 3 != 1 || !mCurrentReturnData) {
893 return false;
894 }
895
896 mCurrentReturnData->displayRequests = read();
897
898 uint32_t count = (length - 1) / 3;
899 mCurrentReturnData->requestedLayers.reserve(count);
900 mCurrentReturnData->requestMasks.reserve(count);
901 while (count > 0) {
902 auto layer = read64();
903 auto layerRequestMask = read();
904
905 mCurrentReturnData->requestedLayers.push_back(layer);
906 mCurrentReturnData->requestMasks.push_back(layerRequestMask);
907
908 count--;
909 }
910
911 return true;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800912}
913
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800914bool CommandReader::parseSetPresentFence(uint16_t length)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800915{
Daniel Nicoara3c9cbd42017-01-17 12:04:06 -0500916 if (length != CommandWriterBase::kSetPresentFenceLength ||
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800917 !mCurrentReturnData) {
918 return false;
919 }
920
921 if (mCurrentReturnData->presentFence >= 0) {
922 close(mCurrentReturnData->presentFence);
923 }
924 mCurrentReturnData->presentFence = readFence();
925
926 return true;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800927}
928
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800929bool CommandReader::parseSetReleaseFences(uint16_t length)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800930{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800931 // (layer id, release fence index) pairs
932 if (length % 3 != 0 || !mCurrentReturnData) {
933 return false;
934 }
935
936 uint32_t count = length / 3;
937 mCurrentReturnData->releasedLayers.reserve(count);
938 mCurrentReturnData->releaseFences.reserve(count);
939 while (count > 0) {
940 auto layer = read64();
941 auto fence = readFence();
942
943 mCurrentReturnData->releasedLayers.push_back(layer);
944 mCurrentReturnData->releaseFences.push_back(fence);
945
946 count--;
947 }
948
949 return true;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800950}
951
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800952void CommandReader::resetData()
Chia-I Wuaab99f52016-10-05 12:59:58 +0800953{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800954 mErrors.clear();
955
956 for (auto& data : mReturnData) {
957 if (data.second.presentFence >= 0) {
958 close(data.second.presentFence);
959 }
960 for (auto fence : data.second.releaseFences) {
961 if (fence >= 0) {
962 close(fence);
963 }
964 }
965 }
966
967 mReturnData.clear();
968 mCurrentReturnData = nullptr;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800969}
970
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800971std::vector<CommandReader::CommandError> CommandReader::takeErrors()
Chia-I Wuaab99f52016-10-05 12:59:58 +0800972{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800973 return std::move(mErrors);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800974}
975
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800976bool CommandReader::hasChanges(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800977 uint32_t* outNumChangedCompositionTypes,
978 uint32_t* outNumLayerRequestMasks) const
Chia-I Wuaab99f52016-10-05 12:59:58 +0800979{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800980 auto found = mReturnData.find(display);
981 if (found == mReturnData.end()) {
Chia-I Wu67e376d2016-12-19 11:36:22 +0800982 *outNumChangedCompositionTypes = 0;
983 *outNumLayerRequestMasks = 0;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800984 return false;
985 }
986
987 const ReturnData& data = found->second;
988
Chia-I Wu67e376d2016-12-19 11:36:22 +0800989 *outNumChangedCompositionTypes = data.compositionTypes.size();
990 *outNumLayerRequestMasks = data.requestMasks.size();
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800991
992 return !(data.compositionTypes.empty() && data.requestMasks.empty());
Chia-I Wuaab99f52016-10-05 12:59:58 +0800993}
994
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800995void CommandReader::takeChangedCompositionTypes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800996 std::vector<Layer>* outLayers,
997 std::vector<IComposerClient::Composition>* outTypes)
Chia-I Wuaab99f52016-10-05 12:59:58 +0800998{
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800999 auto found = mReturnData.find(display);
1000 if (found == mReturnData.end()) {
Chia-I Wu67e376d2016-12-19 11:36:22 +08001001 outLayers->clear();
1002 outTypes->clear();
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001003 return;
1004 }
1005
1006 ReturnData& data = found->second;
1007
Chia-I Wu67e376d2016-12-19 11:36:22 +08001008 *outLayers = std::move(data.changedLayers);
1009 *outTypes = std::move(data.compositionTypes);
Chia-I Wuaab99f52016-10-05 12:59:58 +08001010}
1011
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001012void CommandReader::takeDisplayRequests(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +08001013 uint32_t* outDisplayRequestMask, std::vector<Layer>* outLayers,
1014 std::vector<uint32_t>* outLayerRequestMasks)
Chia-I Wuaab99f52016-10-05 12:59:58 +08001015{
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001016 auto found = mReturnData.find(display);
1017 if (found == mReturnData.end()) {
Chia-I Wu67e376d2016-12-19 11:36:22 +08001018 *outDisplayRequestMask = 0;
1019 outLayers->clear();
1020 outLayerRequestMasks->clear();
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001021 return;
1022 }
Chia-I Wuaab99f52016-10-05 12:59:58 +08001023
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001024 ReturnData& data = found->second;
1025
Chia-I Wu67e376d2016-12-19 11:36:22 +08001026 *outDisplayRequestMask = data.displayRequests;
1027 *outLayers = std::move(data.requestedLayers);
1028 *outLayerRequestMasks = std::move(data.requestMasks);
Chia-I Wuaab99f52016-10-05 12:59:58 +08001029}
1030
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001031void CommandReader::takeReleaseFences(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +08001032 std::vector<Layer>* outLayers, std::vector<int>* outReleaseFences)
Chia-I Wuaab99f52016-10-05 12:59:58 +08001033{
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001034 auto found = mReturnData.find(display);
1035 if (found == mReturnData.end()) {
Chia-I Wu67e376d2016-12-19 11:36:22 +08001036 outLayers->clear();
1037 outReleaseFences->clear();
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001038 return;
1039 }
1040
1041 ReturnData& data = found->second;
1042
Chia-I Wu67e376d2016-12-19 11:36:22 +08001043 *outLayers = std::move(data.releasedLayers);
1044 *outReleaseFences = std::move(data.releaseFences);
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001045}
1046
Chia-I Wu67e376d2016-12-19 11:36:22 +08001047void CommandReader::takePresentFence(Display display, int* outPresentFence)
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001048{
1049 auto found = mReturnData.find(display);
1050 if (found == mReturnData.end()) {
Chia-I Wu67e376d2016-12-19 11:36:22 +08001051 *outPresentFence = -1;
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001052 return;
1053 }
1054
1055 ReturnData& data = found->second;
1056
Chia-I Wu67e376d2016-12-19 11:36:22 +08001057 *outPresentFence = data.presentFence;
Chia-I Wucd8d7f02016-11-16 11:02:31 +08001058 data.presentFence = -1;
Chia-I Wuaab99f52016-10-05 12:59:58 +08001059}
1060
1061} // namespace Hwc2
1062
1063} // namespace android