blob: 80ec1cdc3f352d3e59f5d3ce267111e5fb49f918 [file] [log] [blame]
Chia-I Wu7f8d3962016-09-28 21:04:23 +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#define LOG_TAG "HwcPassthrough"
18
Fabien Sanglard9b117a42017-03-21 09:39:35 -070019#include "Hwc.h"
Chia-I Wu7f8d3962016-09-28 21:04:23 +080020
Steven Thomasbc67a6a2017-07-07 12:34:20 -070021#include <chrono>
Fabien Sanglard9b117a42017-03-21 09:39:35 -070022#include <type_traits>
Chia-I Wu7f8d3962016-09-28 21:04:23 +080023#include <log/log.h>
24
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050025#include "ComposerClient.h"
Chia-I Wu16e8ed22017-10-19 09:49:03 -070026#include "hardware/fb.h"
Fabien Sanglard0d55a212017-03-16 16:56:46 -070027#include "hardware/hwcomposer.h"
28#include "hwc2on1adapter/HWC2On1Adapter.h"
Chia-I Wu16e8ed22017-10-19 09:49:03 -070029#include "hwc2onfbadapter/HWC2OnFbAdapter.h"
Chia-I Wu7f8d3962016-09-28 21:04:23 +080030
Steven Thomasbc67a6a2017-07-07 12:34:20 -070031using namespace std::chrono_literals;
32
Steven Thomas4492a302017-07-07 12:34:20 -070033using namespace std::chrono_literals;
34
Chia-I Wu7f8d3962016-09-28 21:04:23 +080035namespace android {
36namespace hardware {
37namespace graphics {
38namespace composer {
39namespace V2_1 {
40namespace implementation {
41
Chia-I Wu7f8d3962016-09-28 21:04:23 +080042HwcHal::HwcHal(const hw_module_t* module)
Chia-I Wu8101b242017-10-06 12:29:14 -070043 : mDevice(nullptr), mDispatch(), mMustValidateDisplay(true), mAdapter() {
Chia-I Wu16e8ed22017-10-19 09:49:03 -070044 uint32_t majorVersion;
45 if (module->id && strcmp(module->id, GRALLOC_HARDWARE_MODULE_ID) == 0) {
46 majorVersion = initWithFb(module);
47 } else {
48 majorVersion = initWithHwc(module);
49 }
50
51 initCapabilities();
52 if (majorVersion >= 2 &&
53 hasCapability(Capability::PRESENT_FENCE_IS_NOT_RELIABLE)) {
54 ALOGE("Present fence must be reliable from HWC2 on.");
55 abort();
56 }
57
58 initDispatch();
59}
60
61HwcHal::~HwcHal()
62{
63 hwc2_close(mDevice);
64}
65
66uint32_t HwcHal::initWithHwc(const hw_module_t* module)
67{
Fabien Sanglard0d55a212017-03-16 16:56:46 -070068 // Determine what kind of module is available (HWC2 vs HWC1.X).
69 hw_device_t* device = nullptr;
70 int error = module->methods->open(module, HWC_HARDWARE_COMPOSER, &device);
71 if (error != 0) {
72 ALOGE("Failed to open HWC device (%s), aborting", strerror(-error));
73 abort();
74 }
75 uint32_t majorVersion = (device->version >> 24) & 0xF;
76
77 // If we don't have a HWC2, we need to wrap whatever we have in an adapter.
78 if (majorVersion != 2) {
79 uint32_t minorVersion = device->version & HARDWARE_API_VERSION_2_MAJ_MIN_MASK;
80 minorVersion = (minorVersion >> 16) & 0xF;
81 ALOGI("Found HWC implementation v%d.%d", majorVersion, minorVersion);
82 if (minorVersion < 1) {
83 ALOGE("Cannot adapt to HWC version %d.%d. Minimum supported is 1.1",
84 majorVersion, minorVersion);
85 abort();
86 }
87 mAdapter = std::make_unique<HWC2On1Adapter>(
88 reinterpret_cast<hwc_composer_device_1*>(device));
89
90 // Place the adapter in front of the device module.
91 mDevice = mAdapter.get();
92 } else {
93 mDevice = reinterpret_cast<hwc2_device_t*>(device);
Chia-I Wu7f8d3962016-09-28 21:04:23 +080094 }
95
Chia-I Wu16e8ed22017-10-19 09:49:03 -070096 return majorVersion;
97}
98
99uint32_t HwcHal::initWithFb(const hw_module_t* module)
100{
101 framebuffer_device_t* fb_device;
102 int error = framebuffer_open(module, &fb_device);
103 if (error != 0) {
104 ALOGE("Failed to open FB device (%s), aborting", strerror(-error));
Brian Anderson9af5d942017-04-04 16:16:41 -0700105 abort();
106 }
107
Chia-I Wu16e8ed22017-10-19 09:49:03 -0700108 mFbAdapter = std::make_unique<HWC2OnFbAdapter>(fb_device);
109 mDevice = mFbAdapter.get();
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800110
Chia-I Wu16e8ed22017-10-19 09:49:03 -0700111 return 0;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800112}
113
114void HwcHal::initCapabilities()
115{
116 uint32_t count = 0;
117 mDevice->getCapabilities(mDevice, &count, nullptr);
118
119 std::vector<Capability> caps(count);
120 mDevice->getCapabilities(mDevice, &count, reinterpret_cast<
121 std::underlying_type<Capability>::type*>(caps.data()));
122 caps.resize(count);
123
124 mCapabilities.insert(caps.cbegin(), caps.cend());
125}
126
127template<typename T>
Chia-I Wue1768352016-12-19 12:56:54 +0800128void HwcHal::initDispatch(hwc2_function_descriptor_t desc, T* outPfn)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800129{
130 auto pfn = mDevice->getFunction(mDevice, desc);
131 if (!pfn) {
132 LOG_ALWAYS_FATAL("failed to get hwcomposer2 function %d", desc);
133 }
134
Chia-I Wue1768352016-12-19 12:56:54 +0800135 *outPfn = reinterpret_cast<T>(pfn);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800136}
137
138void HwcHal::initDispatch()
139{
Chia-I Wue1768352016-12-19 12:56:54 +0800140 initDispatch(HWC2_FUNCTION_ACCEPT_DISPLAY_CHANGES,
141 &mDispatch.acceptDisplayChanges);
142 initDispatch(HWC2_FUNCTION_CREATE_LAYER, &mDispatch.createLayer);
143 initDispatch(HWC2_FUNCTION_CREATE_VIRTUAL_DISPLAY,
144 &mDispatch.createVirtualDisplay);
145 initDispatch(HWC2_FUNCTION_DESTROY_LAYER, &mDispatch.destroyLayer);
146 initDispatch(HWC2_FUNCTION_DESTROY_VIRTUAL_DISPLAY,
147 &mDispatch.destroyVirtualDisplay);
148 initDispatch(HWC2_FUNCTION_DUMP, &mDispatch.dump);
149 initDispatch(HWC2_FUNCTION_GET_ACTIVE_CONFIG, &mDispatch.getActiveConfig);
150 initDispatch(HWC2_FUNCTION_GET_CHANGED_COMPOSITION_TYPES,
151 &mDispatch.getChangedCompositionTypes);
152 initDispatch(HWC2_FUNCTION_GET_CLIENT_TARGET_SUPPORT,
153 &mDispatch.getClientTargetSupport);
154 initDispatch(HWC2_FUNCTION_GET_COLOR_MODES, &mDispatch.getColorModes);
155 initDispatch(HWC2_FUNCTION_GET_DISPLAY_ATTRIBUTE,
156 &mDispatch.getDisplayAttribute);
157 initDispatch(HWC2_FUNCTION_GET_DISPLAY_CONFIGS,
158 &mDispatch.getDisplayConfigs);
159 initDispatch(HWC2_FUNCTION_GET_DISPLAY_NAME, &mDispatch.getDisplayName);
160 initDispatch(HWC2_FUNCTION_GET_DISPLAY_REQUESTS,
161 &mDispatch.getDisplayRequests);
162 initDispatch(HWC2_FUNCTION_GET_DISPLAY_TYPE, &mDispatch.getDisplayType);
163 initDispatch(HWC2_FUNCTION_GET_DOZE_SUPPORT, &mDispatch.getDozeSupport);
164 initDispatch(HWC2_FUNCTION_GET_HDR_CAPABILITIES,
165 &mDispatch.getHdrCapabilities);
166 initDispatch(HWC2_FUNCTION_GET_MAX_VIRTUAL_DISPLAY_COUNT,
167 &mDispatch.getMaxVirtualDisplayCount);
168 initDispatch(HWC2_FUNCTION_GET_RELEASE_FENCES,
169 &mDispatch.getReleaseFences);
170 initDispatch(HWC2_FUNCTION_PRESENT_DISPLAY, &mDispatch.presentDisplay);
171 initDispatch(HWC2_FUNCTION_REGISTER_CALLBACK,
172 &mDispatch.registerCallback);
173 initDispatch(HWC2_FUNCTION_SET_ACTIVE_CONFIG, &mDispatch.setActiveConfig);
174 initDispatch(HWC2_FUNCTION_SET_CLIENT_TARGET, &mDispatch.setClientTarget);
175 initDispatch(HWC2_FUNCTION_SET_COLOR_MODE, &mDispatch.setColorMode);
176 initDispatch(HWC2_FUNCTION_SET_COLOR_TRANSFORM,
177 &mDispatch.setColorTransform);
178 initDispatch(HWC2_FUNCTION_SET_CURSOR_POSITION,
179 &mDispatch.setCursorPosition);
180 initDispatch(HWC2_FUNCTION_SET_LAYER_BLEND_MODE,
181 &mDispatch.setLayerBlendMode);
182 initDispatch(HWC2_FUNCTION_SET_LAYER_BUFFER, &mDispatch.setLayerBuffer);
183 initDispatch(HWC2_FUNCTION_SET_LAYER_COLOR, &mDispatch.setLayerColor);
184 initDispatch(HWC2_FUNCTION_SET_LAYER_COMPOSITION_TYPE,
185 &mDispatch.setLayerCompositionType);
186 initDispatch(HWC2_FUNCTION_SET_LAYER_DATASPACE,
187 &mDispatch.setLayerDataspace);
188 initDispatch(HWC2_FUNCTION_SET_LAYER_DISPLAY_FRAME,
189 &mDispatch.setLayerDisplayFrame);
190 initDispatch(HWC2_FUNCTION_SET_LAYER_PLANE_ALPHA,
191 &mDispatch.setLayerPlaneAlpha);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800192
193 if (hasCapability(Capability::SIDEBAND_STREAM)) {
Chia-I Wue1768352016-12-19 12:56:54 +0800194 initDispatch(HWC2_FUNCTION_SET_LAYER_SIDEBAND_STREAM,
195 &mDispatch.setLayerSidebandStream);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800196 }
197
Chia-I Wue1768352016-12-19 12:56:54 +0800198 initDispatch(HWC2_FUNCTION_SET_LAYER_SOURCE_CROP,
199 &mDispatch.setLayerSourceCrop);
200 initDispatch(HWC2_FUNCTION_SET_LAYER_SURFACE_DAMAGE,
201 &mDispatch.setLayerSurfaceDamage);
202 initDispatch(HWC2_FUNCTION_SET_LAYER_TRANSFORM,
203 &mDispatch.setLayerTransform);
204 initDispatch(HWC2_FUNCTION_SET_LAYER_VISIBLE_REGION,
205 &mDispatch.setLayerVisibleRegion);
206 initDispatch(HWC2_FUNCTION_SET_LAYER_Z_ORDER, &mDispatch.setLayerZOrder);
207 initDispatch(HWC2_FUNCTION_SET_OUTPUT_BUFFER, &mDispatch.setOutputBuffer);
208 initDispatch(HWC2_FUNCTION_SET_POWER_MODE, &mDispatch.setPowerMode);
209 initDispatch(HWC2_FUNCTION_SET_VSYNC_ENABLED, &mDispatch.setVsyncEnabled);
210 initDispatch(HWC2_FUNCTION_VALIDATE_DISPLAY, &mDispatch.validateDisplay);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800211}
212
213bool HwcHal::hasCapability(Capability capability) const
214{
215 return (mCapabilities.count(capability) > 0);
216}
217
218Return<void> HwcHal::getCapabilities(getCapabilities_cb hidl_cb)
219{
220 std::vector<Capability> caps(
221 mCapabilities.cbegin(), mCapabilities.cend());
222
223 hidl_vec<Capability> caps_reply;
224 caps_reply.setToExternal(caps.data(), caps.size());
225 hidl_cb(caps_reply);
226
227 return Void();
228}
229
230Return<void> HwcHal::dumpDebugInfo(dumpDebugInfo_cb hidl_cb)
231{
Chia-I Wue1768352016-12-19 12:56:54 +0800232 uint32_t len = 0;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800233 mDispatch.dump(mDevice, &len, nullptr);
234
235 std::vector<char> buf(len + 1);
236 mDispatch.dump(mDevice, &len, buf.data());
237 buf.resize(len + 1);
238 buf[len] = '\0';
239
240 hidl_string buf_reply;
241 buf_reply.setToExternal(buf.data(), len);
242 hidl_cb(buf_reply);
243
244 return Void();
245}
246
Chia-I Wubb61a722016-10-24 15:40:20 +0800247Return<void> HwcHal::createClient(createClient_cb hidl_cb)
248{
249 Error err = Error::NONE;
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500250 sp<ComposerClient> client;
Chia-I Wubb61a722016-10-24 15:40:20 +0800251
252 {
Steven Thomasbc67a6a2017-07-07 12:34:20 -0700253 std::unique_lock<std::mutex> lock(mClientMutex);
254
255 if (mClient != nullptr) {
256 // In surface flinger we delete a composer client on one thread and
257 // then create a new client on another thread. Although surface
258 // flinger ensures the calls are made in that sequence (destroy and
259 // then create), sometimes the calls land in the composer service
260 // inverted (create and then destroy). Wait for a brief period to
261 // see if the existing client is destroyed.
262 ALOGI("HwcHal::createClient: Client already exists. Waiting for"
263 " it to be destroyed.");
264 mClientDestroyedWait.wait_for(lock, 1s,
265 [this] { return mClient == nullptr; });
266 std::string doneMsg = mClient == nullptr ?
267 "Existing client was destroyed." :
268 "Existing client was never destroyed!";
269 ALOGI("HwcHal::createClient: Done waiting. %s", doneMsg.c_str());
270 }
Chia-I Wubb61a722016-10-24 15:40:20 +0800271
272 // only one client is allowed
273 if (mClient == nullptr) {
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500274 client = new ComposerClient(*this);
275 client->initialize();
Chia-I Wubb61a722016-10-24 15:40:20 +0800276 mClient = client;
277 } else {
278 err = Error::NO_RESOURCES;
279 }
280 }
281
282 hidl_cb(err, client);
283
284 return Void();
285}
286
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500287sp<ComposerClient> HwcHal::getClient()
Chia-I Wubb61a722016-10-24 15:40:20 +0800288{
289 std::lock_guard<std::mutex> lock(mClientMutex);
290 return (mClient != nullptr) ? mClient.promote() : nullptr;
291}
292
293void HwcHal::removeClient()
294{
295 std::lock_guard<std::mutex> lock(mClientMutex);
296 mClient = nullptr;
Steven Thomasbc67a6a2017-07-07 12:34:20 -0700297 mClientDestroyedWait.notify_all();
Chia-I Wubb61a722016-10-24 15:40:20 +0800298}
299
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800300void HwcHal::hotplugHook(hwc2_callback_data_t callbackData,
301 hwc2_display_t display, int32_t connected)
302{
303 auto hal = reinterpret_cast<HwcHal*>(callbackData);
Chia-I Wubb61a722016-10-24 15:40:20 +0800304 auto client = hal->getClient();
305 if (client != nullptr) {
306 client->onHotplug(display,
307 static_cast<IComposerCallback::Connection>(connected));
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800308 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800309}
310
311void HwcHal::refreshHook(hwc2_callback_data_t callbackData,
312 hwc2_display_t display)
313{
314 auto hal = reinterpret_cast<HwcHal*>(callbackData);
Chia-I Wu8101b242017-10-06 12:29:14 -0700315 hal->mMustValidateDisplay = true;
316
Chia-I Wubb61a722016-10-24 15:40:20 +0800317 auto client = hal->getClient();
318 if (client != nullptr) {
319 client->onRefresh(display);
320 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800321}
322
323void HwcHal::vsyncHook(hwc2_callback_data_t callbackData,
324 hwc2_display_t display, int64_t timestamp)
325{
326 auto hal = reinterpret_cast<HwcHal*>(callbackData);
Chia-I Wubb61a722016-10-24 15:40:20 +0800327 auto client = hal->getClient();
328 if (client != nullptr) {
329 client->onVsync(display, timestamp);
330 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800331}
332
Chia-I Wubb61a722016-10-24 15:40:20 +0800333void HwcHal::enableCallback(bool enable)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800334{
Chia-I Wubb61a722016-10-24 15:40:20 +0800335 if (enable) {
Chia-I Wu8101b242017-10-06 12:29:14 -0700336 mMustValidateDisplay = true;
337
Chia-I Wubb61a722016-10-24 15:40:20 +0800338 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_HOTPLUG, this,
339 reinterpret_cast<hwc2_function_pointer_t>(hotplugHook));
340 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_REFRESH, this,
341 reinterpret_cast<hwc2_function_pointer_t>(refreshHook));
342 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_VSYNC, this,
343 reinterpret_cast<hwc2_function_pointer_t>(vsyncHook));
344 } else {
345 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_HOTPLUG, this,
346 nullptr);
347 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_REFRESH, this,
348 nullptr);
349 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_VSYNC, this,
350 nullptr);
351 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800352}
353
Chia-I Wubb61a722016-10-24 15:40:20 +0800354uint32_t HwcHal::getMaxVirtualDisplayCount()
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800355{
356 return mDispatch.getMaxVirtualDisplayCount(mDevice);
357}
358
Chia-I Wubb61a722016-10-24 15:40:20 +0800359Error HwcHal::createVirtualDisplay(uint32_t width, uint32_t height,
Chia-I Wue1768352016-12-19 12:56:54 +0800360 PixelFormat* format, Display* outDisplay)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800361{
Chia-I Wue1768352016-12-19 12:56:54 +0800362 int32_t hwc_format = static_cast<int32_t>(*format);
Chia-I Wubb61a722016-10-24 15:40:20 +0800363 int32_t err = mDispatch.createVirtualDisplay(mDevice, width, height,
Chia-I Wue1768352016-12-19 12:56:54 +0800364 &hwc_format, outDisplay);
365 *format = static_cast<PixelFormat>(hwc_format);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800366
Chia-I Wubb61a722016-10-24 15:40:20 +0800367 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800368}
369
Chia-I Wubb61a722016-10-24 15:40:20 +0800370Error HwcHal::destroyVirtualDisplay(Display display)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800371{
Chia-I Wubb61a722016-10-24 15:40:20 +0800372 int32_t err = mDispatch.destroyVirtualDisplay(mDevice, display);
373 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800374}
375
Chia-I Wue1768352016-12-19 12:56:54 +0800376Error HwcHal::createLayer(Display display, Layer* outLayer)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800377{
Chia-I Wue1768352016-12-19 12:56:54 +0800378 int32_t err = mDispatch.createLayer(mDevice, display, outLayer);
Chia-I Wubb61a722016-10-24 15:40:20 +0800379 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800380}
381
Chia-I Wubb61a722016-10-24 15:40:20 +0800382Error HwcHal::destroyLayer(Display display, Layer layer)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800383{
Chia-I Wubb61a722016-10-24 15:40:20 +0800384 int32_t err = mDispatch.destroyLayer(mDevice, display, layer);
385 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800386}
387
Chia-I Wue1768352016-12-19 12:56:54 +0800388Error HwcHal::getActiveConfig(Display display, Config* outConfig)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800389{
Chia-I Wue1768352016-12-19 12:56:54 +0800390 int32_t err = mDispatch.getActiveConfig(mDevice, display, outConfig);
Chia-I Wubb61a722016-10-24 15:40:20 +0800391 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800392}
393
Chia-I Wubb61a722016-10-24 15:40:20 +0800394Error HwcHal::getClientTargetSupport(Display display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800395 uint32_t width, uint32_t height,
396 PixelFormat format, Dataspace dataspace)
397{
Chia-I Wubb61a722016-10-24 15:40:20 +0800398 int32_t err = mDispatch.getClientTargetSupport(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800399 width, height, static_cast<int32_t>(format),
400 static_cast<int32_t>(dataspace));
Chia-I Wubb61a722016-10-24 15:40:20 +0800401 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800402}
403
Chia-I Wue1768352016-12-19 12:56:54 +0800404Error HwcHal::getColorModes(Display display, hidl_vec<ColorMode>* outModes)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800405{
406 uint32_t count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800407 int32_t err = mDispatch.getColorModes(mDevice, display, &count, nullptr);
408 if (err != HWC2_ERROR_NONE) {
409 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800410 }
411
Chia-I Wue1768352016-12-19 12:56:54 +0800412 outModes->resize(count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800413 err = mDispatch.getColorModes(mDevice, display, &count,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800414 reinterpret_cast<std::underlying_type<ColorMode>::type*>(
Chia-I Wue1768352016-12-19 12:56:54 +0800415 outModes->data()));
Chia-I Wubb61a722016-10-24 15:40:20 +0800416 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800417 *outModes = hidl_vec<ColorMode>();
Chia-I Wubb61a722016-10-24 15:40:20 +0800418 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800419 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800420
Chia-I Wubb61a722016-10-24 15:40:20 +0800421 return Error::NONE;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800422}
423
Chia-I Wubb61a722016-10-24 15:40:20 +0800424Error HwcHal::getDisplayAttribute(Display display, Config config,
Chia-I Wue1768352016-12-19 12:56:54 +0800425 IComposerClient::Attribute attribute, int32_t* outValue)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800426{
Chia-I Wubb61a722016-10-24 15:40:20 +0800427 int32_t err = mDispatch.getDisplayAttribute(mDevice, display, config,
Chia-I Wue1768352016-12-19 12:56:54 +0800428 static_cast<int32_t>(attribute), outValue);
Chia-I Wubb61a722016-10-24 15:40:20 +0800429 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800430}
431
Chia-I Wue1768352016-12-19 12:56:54 +0800432Error HwcHal::getDisplayConfigs(Display display, hidl_vec<Config>* outConfigs)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800433{
434 uint32_t count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800435 int32_t err = mDispatch.getDisplayConfigs(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800436 &count, nullptr);
Chia-I Wubb61a722016-10-24 15:40:20 +0800437 if (err != HWC2_ERROR_NONE) {
438 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800439 }
440
Chia-I Wue1768352016-12-19 12:56:54 +0800441 outConfigs->resize(count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800442 err = mDispatch.getDisplayConfigs(mDevice, display,
Chia-I Wue1768352016-12-19 12:56:54 +0800443 &count, outConfigs->data());
Chia-I Wubb61a722016-10-24 15:40:20 +0800444 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800445 *outConfigs = hidl_vec<Config>();
Chia-I Wubb61a722016-10-24 15:40:20 +0800446 return static_cast<Error>(err);
447 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800448
Chia-I Wubb61a722016-10-24 15:40:20 +0800449 return Error::NONE;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800450}
451
Chia-I Wue1768352016-12-19 12:56:54 +0800452Error HwcHal::getDisplayName(Display display, hidl_string* outName)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800453{
454 uint32_t count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800455 int32_t err = mDispatch.getDisplayName(mDevice, display, &count, nullptr);
456 if (err != HWC2_ERROR_NONE) {
457 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800458 }
459
Chia-I Wubb61a722016-10-24 15:40:20 +0800460 std::vector<char> buf(count + 1);
461 err = mDispatch.getDisplayName(mDevice, display, &count, buf.data());
462 if (err != HWC2_ERROR_NONE) {
463 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800464 }
Chia-I Wubb61a722016-10-24 15:40:20 +0800465 buf.resize(count + 1);
466 buf[count] = '\0';
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800467
Chia-I Wue1768352016-12-19 12:56:54 +0800468 *outName = buf.data();
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800469
Chia-I Wubb61a722016-10-24 15:40:20 +0800470 return Error::NONE;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800471}
472
Chia-I Wue1768352016-12-19 12:56:54 +0800473Error HwcHal::getDisplayType(Display display,
474 IComposerClient::DisplayType* outType)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800475{
Chia-I Wubb61a722016-10-24 15:40:20 +0800476 int32_t hwc_type = HWC2_DISPLAY_TYPE_INVALID;
477 int32_t err = mDispatch.getDisplayType(mDevice, display, &hwc_type);
Chia-I Wue1768352016-12-19 12:56:54 +0800478 *outType = static_cast<IComposerClient::DisplayType>(hwc_type);
Chia-I Wubb61a722016-10-24 15:40:20 +0800479
480 return static_cast<Error>(err);
481}
482
Chia-I Wue1768352016-12-19 12:56:54 +0800483Error HwcHal::getDozeSupport(Display display, bool* outSupport)
Chia-I Wubb61a722016-10-24 15:40:20 +0800484{
485 int32_t hwc_support = 0;
486 int32_t err = mDispatch.getDozeSupport(mDevice, display, &hwc_support);
Chia-I Wue1768352016-12-19 12:56:54 +0800487 *outSupport = hwc_support;
Chia-I Wubb61a722016-10-24 15:40:20 +0800488
489 return static_cast<Error>(err);
490}
491
Chia-I Wue1768352016-12-19 12:56:54 +0800492Error HwcHal::getHdrCapabilities(Display display, hidl_vec<Hdr>* outTypes,
493 float* outMaxLuminance, float* outMaxAverageLuminance,
494 float* outMinLuminance)
Chia-I Wubb61a722016-10-24 15:40:20 +0800495{
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800496 uint32_t count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800497 int32_t err = mDispatch.getHdrCapabilities(mDevice, display, &count,
Chia-I Wue1768352016-12-19 12:56:54 +0800498 nullptr, outMaxLuminance, outMaxAverageLuminance,
499 outMinLuminance);
Chia-I Wubb61a722016-10-24 15:40:20 +0800500 if (err != HWC2_ERROR_NONE) {
501 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800502 }
503
Chia-I Wue1768352016-12-19 12:56:54 +0800504 outTypes->resize(count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800505 err = mDispatch.getHdrCapabilities(mDevice, display, &count,
Chia-I Wue1768352016-12-19 12:56:54 +0800506 reinterpret_cast<std::underlying_type<Hdr>::type*>(
507 outTypes->data()), outMaxLuminance,
508 outMaxAverageLuminance, outMinLuminance);
Chia-I Wubb61a722016-10-24 15:40:20 +0800509 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800510 *outTypes = hidl_vec<Hdr>();
Chia-I Wubb61a722016-10-24 15:40:20 +0800511 return static_cast<Error>(err);
512 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800513
Chia-I Wubb61a722016-10-24 15:40:20 +0800514 return Error::NONE;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800515}
516
Chia-I Wubb61a722016-10-24 15:40:20 +0800517Error HwcHal::setActiveConfig(Display display, Config config)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800518{
Chia-I Wubb61a722016-10-24 15:40:20 +0800519 int32_t err = mDispatch.setActiveConfig(mDevice, display, config);
520 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800521}
522
Chia-I Wubb61a722016-10-24 15:40:20 +0800523Error HwcHal::setColorMode(Display display, ColorMode mode)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800524{
Chia-I Wubb61a722016-10-24 15:40:20 +0800525 int32_t err = mDispatch.setColorMode(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800526 static_cast<int32_t>(mode));
Chia-I Wubb61a722016-10-24 15:40:20 +0800527 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800528}
529
Chia-I Wubb61a722016-10-24 15:40:20 +0800530Error HwcHal::setPowerMode(Display display, IComposerClient::PowerMode mode)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800531{
Chia-I Wubb61a722016-10-24 15:40:20 +0800532 int32_t err = mDispatch.setPowerMode(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800533 static_cast<int32_t>(mode));
Chia-I Wubb61a722016-10-24 15:40:20 +0800534 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800535}
536
Chia-I Wubb61a722016-10-24 15:40:20 +0800537Error HwcHal::setVsyncEnabled(Display display, IComposerClient::Vsync enabled)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800538{
Chia-I Wubb61a722016-10-24 15:40:20 +0800539 int32_t err = mDispatch.setVsyncEnabled(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800540 static_cast<int32_t>(enabled));
Chia-I Wubb61a722016-10-24 15:40:20 +0800541 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800542}
543
Chia-I Wubb61a722016-10-24 15:40:20 +0800544Error HwcHal::setColorTransform(Display display, const float* matrix,
545 int32_t hint)
546{
547 int32_t err = mDispatch.setColorTransform(mDevice, display, matrix, hint);
548 return static_cast<Error>(err);
549}
550
551Error HwcHal::setClientTarget(Display display, buffer_handle_t target,
552 int32_t acquireFence, int32_t dataspace,
553 const std::vector<hwc_rect_t>& damage)
554{
555 hwc_region region = { damage.size(), damage.data() };
556 int32_t err = mDispatch.setClientTarget(mDevice, display, target,
557 acquireFence, dataspace, region);
558 return static_cast<Error>(err);
559}
560
561Error HwcHal::setOutputBuffer(Display display, buffer_handle_t buffer,
562 int32_t releaseFence)
563{
564 int32_t err = mDispatch.setOutputBuffer(mDevice, display, buffer,
565 releaseFence);
566 // unlike in setClientTarget, releaseFence is owned by us
567 if (err == HWC2_ERROR_NONE && releaseFence >= 0) {
568 close(releaseFence);
569 }
570
571 return static_cast<Error>(err);
572}
573
574Error HwcHal::validateDisplay(Display display,
Chia-I Wue1768352016-12-19 12:56:54 +0800575 std::vector<Layer>* outChangedLayers,
576 std::vector<IComposerClient::Composition>* outCompositionTypes,
577 uint32_t* outDisplayRequestMask,
578 std::vector<Layer>* outRequestedLayers,
579 std::vector<uint32_t>* outRequestMasks)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800580{
581 uint32_t types_count = 0;
582 uint32_t reqs_count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800583 int32_t err = mDispatch.validateDisplay(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800584 &types_count, &reqs_count);
Chia-I Wu8101b242017-10-06 12:29:14 -0700585 mMustValidateDisplay = false;
586
Chia-I Wubb61a722016-10-24 15:40:20 +0800587 if (err != HWC2_ERROR_NONE && err != HWC2_ERROR_HAS_CHANGES) {
588 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800589 }
590
Chia-I Wubb61a722016-10-24 15:40:20 +0800591 err = mDispatch.getChangedCompositionTypes(mDevice, display,
592 &types_count, nullptr, nullptr);
593 if (err != HWC2_ERROR_NONE) {
594 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800595 }
596
Chia-I Wue1768352016-12-19 12:56:54 +0800597 outChangedLayers->resize(types_count);
598 outCompositionTypes->resize(types_count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800599 err = mDispatch.getChangedCompositionTypes(mDevice, display,
Chia-I Wue1768352016-12-19 12:56:54 +0800600 &types_count, outChangedLayers->data(),
Chia-I Wubb61a722016-10-24 15:40:20 +0800601 reinterpret_cast<
602 std::underlying_type<IComposerClient::Composition>::type*>(
Chia-I Wue1768352016-12-19 12:56:54 +0800603 outCompositionTypes->data()));
Chia-I Wubb61a722016-10-24 15:40:20 +0800604 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800605 outChangedLayers->clear();
606 outCompositionTypes->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800607 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800608 }
609
Chia-I Wubb61a722016-10-24 15:40:20 +0800610 int32_t display_reqs = 0;
611 err = mDispatch.getDisplayRequests(mDevice, display, &display_reqs,
612 &reqs_count, nullptr, nullptr);
613 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800614 outChangedLayers->clear();
615 outCompositionTypes->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800616 return static_cast<Error>(err);
617 }
618
Chia-I Wue1768352016-12-19 12:56:54 +0800619 outRequestedLayers->resize(reqs_count);
620 outRequestMasks->resize(reqs_count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800621 err = mDispatch.getDisplayRequests(mDevice, display, &display_reqs,
Chia-I Wue1768352016-12-19 12:56:54 +0800622 &reqs_count, outRequestedLayers->data(),
623 reinterpret_cast<int32_t*>(outRequestMasks->data()));
Chia-I Wubb61a722016-10-24 15:40:20 +0800624 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800625 outChangedLayers->clear();
626 outCompositionTypes->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800627
Chia-I Wue1768352016-12-19 12:56:54 +0800628 outRequestedLayers->clear();
629 outRequestMasks->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800630 return static_cast<Error>(err);
631 }
632
Chia-I Wue1768352016-12-19 12:56:54 +0800633 *outDisplayRequestMask = display_reqs;
Chia-I Wubb61a722016-10-24 15:40:20 +0800634
635 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800636}
637
Chia-I Wubb61a722016-10-24 15:40:20 +0800638Error HwcHal::acceptDisplayChanges(Display display)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800639{
Chia-I Wubb61a722016-10-24 15:40:20 +0800640 int32_t err = mDispatch.acceptDisplayChanges(mDevice, display);
641 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800642}
643
Chia-I Wue1768352016-12-19 12:56:54 +0800644Error HwcHal::presentDisplay(Display display, int32_t* outPresentFence,
645 std::vector<Layer>* outLayers, std::vector<int32_t>* outReleaseFences)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800646{
Chia-I Wu8101b242017-10-06 12:29:14 -0700647 if (mMustValidateDisplay) {
648 return Error::NOT_VALIDATED;
649 }
650
Chia-I Wue1768352016-12-19 12:56:54 +0800651 *outPresentFence = -1;
652 int32_t err = mDispatch.presentDisplay(mDevice, display, outPresentFence);
Chia-I Wubb61a722016-10-24 15:40:20 +0800653 if (err != HWC2_ERROR_NONE) {
654 return static_cast<Error>(err);
655 }
656
657 uint32_t count = 0;
658 err = mDispatch.getReleaseFences(mDevice, display, &count,
659 nullptr, nullptr);
660 if (err != HWC2_ERROR_NONE) {
661 ALOGW("failed to get release fences");
662 return Error::NONE;
663 }
664
Chia-I Wue1768352016-12-19 12:56:54 +0800665 outLayers->resize(count);
666 outReleaseFences->resize(count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800667 err = mDispatch.getReleaseFences(mDevice, display, &count,
Chia-I Wue1768352016-12-19 12:56:54 +0800668 outLayers->data(), outReleaseFences->data());
Chia-I Wubb61a722016-10-24 15:40:20 +0800669 if (err != HWC2_ERROR_NONE) {
670 ALOGW("failed to get release fences");
Chia-I Wue1768352016-12-19 12:56:54 +0800671 outLayers->clear();
672 outReleaseFences->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800673 return Error::NONE;
674 }
675
676 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800677}
678
Chia-I Wubb61a722016-10-24 15:40:20 +0800679Error HwcHal::setLayerCursorPosition(Display display, Layer layer,
680 int32_t x, int32_t y)
681{
682 int32_t err = mDispatch.setCursorPosition(mDevice, display, layer, x, y);
683 return static_cast<Error>(err);
684}
685
686Error HwcHal::setLayerBuffer(Display display, Layer layer,
687 buffer_handle_t buffer, int32_t acquireFence)
688{
689 int32_t err = mDispatch.setLayerBuffer(mDevice, display, layer,
690 buffer, acquireFence);
691 return static_cast<Error>(err);
692}
693
694Error HwcHal::setLayerSurfaceDamage(Display display, Layer layer,
695 const std::vector<hwc_rect_t>& damage)
696{
697 hwc_region region = { damage.size(), damage.data() };
698 int32_t err = mDispatch.setLayerSurfaceDamage(mDevice, display, layer,
699 region);
700 return static_cast<Error>(err);
701}
702
703Error HwcHal::setLayerBlendMode(Display display, Layer layer, int32_t mode)
704{
705 int32_t err = mDispatch.setLayerBlendMode(mDevice, display, layer, mode);
706 return static_cast<Error>(err);
707}
708
709Error HwcHal::setLayerColor(Display display, Layer layer,
710 IComposerClient::Color color)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800711{
712 hwc_color_t hwc_color{color.r, color.g, color.b, color.a};
Chia-I Wubb61a722016-10-24 15:40:20 +0800713 int32_t err = mDispatch.setLayerColor(mDevice, display, layer, hwc_color);
714 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800715}
716
Chia-I Wubb61a722016-10-24 15:40:20 +0800717Error HwcHal::setLayerCompositionType(Display display, Layer layer,
718 int32_t type)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800719{
Chia-I Wubb61a722016-10-24 15:40:20 +0800720 int32_t err = mDispatch.setLayerCompositionType(mDevice, display, layer,
721 type);
722 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800723}
724
Chia-I Wubb61a722016-10-24 15:40:20 +0800725Error HwcHal::setLayerDataspace(Display display, Layer layer,
726 int32_t dataspace)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800727{
Chia-I Wubb61a722016-10-24 15:40:20 +0800728 int32_t err = mDispatch.setLayerDataspace(mDevice, display, layer,
729 dataspace);
730 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800731}
732
Chia-I Wubb61a722016-10-24 15:40:20 +0800733Error HwcHal::setLayerDisplayFrame(Display display, Layer layer,
734 const hwc_rect_t& frame)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800735{
Chia-I Wubb61a722016-10-24 15:40:20 +0800736 int32_t err = mDispatch.setLayerDisplayFrame(mDevice, display, layer,
737 frame);
738 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800739}
740
Chia-I Wubb61a722016-10-24 15:40:20 +0800741Error HwcHal::setLayerPlaneAlpha(Display display, Layer layer, float alpha)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800742{
Chia-I Wubb61a722016-10-24 15:40:20 +0800743 int32_t err = mDispatch.setLayerPlaneAlpha(mDevice, display, layer,
744 alpha);
745 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800746}
747
Chia-I Wubb61a722016-10-24 15:40:20 +0800748Error HwcHal::setLayerSidebandStream(Display display, Layer layer,
749 buffer_handle_t stream)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800750{
Chia-I Wubb61a722016-10-24 15:40:20 +0800751 int32_t err = mDispatch.setLayerSidebandStream(mDevice, display, layer,
752 stream);
753 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800754}
755
Chia-I Wubb61a722016-10-24 15:40:20 +0800756Error HwcHal::setLayerSourceCrop(Display display, Layer layer,
757 const hwc_frect_t& crop)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800758{
Chia-I Wubb61a722016-10-24 15:40:20 +0800759 int32_t err = mDispatch.setLayerSourceCrop(mDevice, display, layer, crop);
760 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800761}
762
Chia-I Wubb61a722016-10-24 15:40:20 +0800763Error HwcHal::setLayerTransform(Display display, Layer layer,
764 int32_t transform)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800765{
Chia-I Wubb61a722016-10-24 15:40:20 +0800766 int32_t err = mDispatch.setLayerTransform(mDevice, display, layer,
767 transform);
768 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800769}
770
Chia-I Wubb61a722016-10-24 15:40:20 +0800771Error HwcHal::setLayerVisibleRegion(Display display, Layer layer,
772 const std::vector<hwc_rect_t>& visible)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800773{
Chia-I Wubb61a722016-10-24 15:40:20 +0800774 hwc_region_t region = { visible.size(), visible.data() };
775 int32_t err = mDispatch.setLayerVisibleRegion(mDevice, display, layer,
776 region);
777 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800778}
779
Chia-I Wubb61a722016-10-24 15:40:20 +0800780Error HwcHal::setLayerZOrder(Display display, Layer layer, uint32_t z)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800781{
Chia-I Wubb61a722016-10-24 15:40:20 +0800782 int32_t err = mDispatch.setLayerZOrder(mDevice, display, layer, z);
783 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800784}
785
786IComposer* HIDL_FETCH_IComposer(const char*)
787{
Chia-I Wue1768352016-12-19 12:56:54 +0800788 const hw_module_t* module = nullptr;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800789 int err = hw_get_module(HWC_HARDWARE_MODULE_ID, &module);
790 if (err) {
Chia-I Wu16e8ed22017-10-19 09:49:03 -0700791 ALOGI("falling back to FB HAL");
792 err = hw_get_module(GRALLOC_HARDWARE_MODULE_ID, &module);
793 }
794 if (err) {
795 ALOGE("failed to get hwcomposer or fb module");
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800796 return nullptr;
797 }
798
799 return new HwcHal(module);
800}
801
802} // namespace implementation
803} // namespace V2_1
804} // namespace composer
805} // namespace graphics
806} // namespace hardware
807} // namespace android