blob: fdb4af88c24eca23fdc209277bccfb7ff22e0bf0 [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
Chia-I Wu7f8d3962016-09-28 21:04:23 +080033namespace android {
34namespace hardware {
35namespace graphics {
36namespace composer {
37namespace V2_1 {
38namespace implementation {
39
Chia-I Wu7f8d3962016-09-28 21:04:23 +080040HwcHal::HwcHal(const hw_module_t* module)
Chia-I Wu8101b242017-10-06 12:29:14 -070041 : mDevice(nullptr), mDispatch(), mMustValidateDisplay(true), mAdapter() {
Chia-I Wu16e8ed22017-10-19 09:49:03 -070042 uint32_t majorVersion;
43 if (module->id && strcmp(module->id, GRALLOC_HARDWARE_MODULE_ID) == 0) {
44 majorVersion = initWithFb(module);
45 } else {
46 majorVersion = initWithHwc(module);
47 }
48
49 initCapabilities();
50 if (majorVersion >= 2 &&
51 hasCapability(Capability::PRESENT_FENCE_IS_NOT_RELIABLE)) {
52 ALOGE("Present fence must be reliable from HWC2 on.");
53 abort();
54 }
55
56 initDispatch();
57}
58
59HwcHal::~HwcHal()
60{
61 hwc2_close(mDevice);
62}
63
64uint32_t HwcHal::initWithHwc(const hw_module_t* module)
65{
Fabien Sanglard0d55a212017-03-16 16:56:46 -070066 // Determine what kind of module is available (HWC2 vs HWC1.X).
67 hw_device_t* device = nullptr;
68 int error = module->methods->open(module, HWC_HARDWARE_COMPOSER, &device);
69 if (error != 0) {
70 ALOGE("Failed to open HWC device (%s), aborting", strerror(-error));
71 abort();
72 }
73 uint32_t majorVersion = (device->version >> 24) & 0xF;
74
75 // If we don't have a HWC2, we need to wrap whatever we have in an adapter.
76 if (majorVersion != 2) {
77 uint32_t minorVersion = device->version & HARDWARE_API_VERSION_2_MAJ_MIN_MASK;
78 minorVersion = (minorVersion >> 16) & 0xF;
79 ALOGI("Found HWC implementation v%d.%d", majorVersion, minorVersion);
80 if (minorVersion < 1) {
81 ALOGE("Cannot adapt to HWC version %d.%d. Minimum supported is 1.1",
82 majorVersion, minorVersion);
83 abort();
84 }
85 mAdapter = std::make_unique<HWC2On1Adapter>(
86 reinterpret_cast<hwc_composer_device_1*>(device));
87
88 // Place the adapter in front of the device module.
89 mDevice = mAdapter.get();
90 } else {
91 mDevice = reinterpret_cast<hwc2_device_t*>(device);
Chia-I Wu7f8d3962016-09-28 21:04:23 +080092 }
93
Chia-I Wu16e8ed22017-10-19 09:49:03 -070094 return majorVersion;
95}
96
97uint32_t HwcHal::initWithFb(const hw_module_t* module)
98{
99 framebuffer_device_t* fb_device;
100 int error = framebuffer_open(module, &fb_device);
101 if (error != 0) {
102 ALOGE("Failed to open FB device (%s), aborting", strerror(-error));
Brian Anderson9af5d942017-04-04 16:16:41 -0700103 abort();
104 }
105
Chia-I Wu16e8ed22017-10-19 09:49:03 -0700106 mFbAdapter = std::make_unique<HWC2OnFbAdapter>(fb_device);
107 mDevice = mFbAdapter.get();
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800108
Chia-I Wu16e8ed22017-10-19 09:49:03 -0700109 return 0;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800110}
111
112void HwcHal::initCapabilities()
113{
114 uint32_t count = 0;
115 mDevice->getCapabilities(mDevice, &count, nullptr);
116
117 std::vector<Capability> caps(count);
118 mDevice->getCapabilities(mDevice, &count, reinterpret_cast<
119 std::underlying_type<Capability>::type*>(caps.data()));
120 caps.resize(count);
121
122 mCapabilities.insert(caps.cbegin(), caps.cend());
123}
124
125template<typename T>
Chia-I Wue1768352016-12-19 12:56:54 +0800126void HwcHal::initDispatch(hwc2_function_descriptor_t desc, T* outPfn)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800127{
128 auto pfn = mDevice->getFunction(mDevice, desc);
129 if (!pfn) {
130 LOG_ALWAYS_FATAL("failed to get hwcomposer2 function %d", desc);
131 }
132
Chia-I Wue1768352016-12-19 12:56:54 +0800133 *outPfn = reinterpret_cast<T>(pfn);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800134}
135
136void HwcHal::initDispatch()
137{
Chia-I Wue1768352016-12-19 12:56:54 +0800138 initDispatch(HWC2_FUNCTION_ACCEPT_DISPLAY_CHANGES,
139 &mDispatch.acceptDisplayChanges);
140 initDispatch(HWC2_FUNCTION_CREATE_LAYER, &mDispatch.createLayer);
141 initDispatch(HWC2_FUNCTION_CREATE_VIRTUAL_DISPLAY,
142 &mDispatch.createVirtualDisplay);
143 initDispatch(HWC2_FUNCTION_DESTROY_LAYER, &mDispatch.destroyLayer);
144 initDispatch(HWC2_FUNCTION_DESTROY_VIRTUAL_DISPLAY,
145 &mDispatch.destroyVirtualDisplay);
146 initDispatch(HWC2_FUNCTION_DUMP, &mDispatch.dump);
147 initDispatch(HWC2_FUNCTION_GET_ACTIVE_CONFIG, &mDispatch.getActiveConfig);
148 initDispatch(HWC2_FUNCTION_GET_CHANGED_COMPOSITION_TYPES,
149 &mDispatch.getChangedCompositionTypes);
150 initDispatch(HWC2_FUNCTION_GET_CLIENT_TARGET_SUPPORT,
151 &mDispatch.getClientTargetSupport);
152 initDispatch(HWC2_FUNCTION_GET_COLOR_MODES, &mDispatch.getColorModes);
153 initDispatch(HWC2_FUNCTION_GET_DISPLAY_ATTRIBUTE,
154 &mDispatch.getDisplayAttribute);
155 initDispatch(HWC2_FUNCTION_GET_DISPLAY_CONFIGS,
156 &mDispatch.getDisplayConfigs);
157 initDispatch(HWC2_FUNCTION_GET_DISPLAY_NAME, &mDispatch.getDisplayName);
158 initDispatch(HWC2_FUNCTION_GET_DISPLAY_REQUESTS,
159 &mDispatch.getDisplayRequests);
160 initDispatch(HWC2_FUNCTION_GET_DISPLAY_TYPE, &mDispatch.getDisplayType);
161 initDispatch(HWC2_FUNCTION_GET_DOZE_SUPPORT, &mDispatch.getDozeSupport);
162 initDispatch(HWC2_FUNCTION_GET_HDR_CAPABILITIES,
163 &mDispatch.getHdrCapabilities);
164 initDispatch(HWC2_FUNCTION_GET_MAX_VIRTUAL_DISPLAY_COUNT,
165 &mDispatch.getMaxVirtualDisplayCount);
166 initDispatch(HWC2_FUNCTION_GET_RELEASE_FENCES,
167 &mDispatch.getReleaseFences);
168 initDispatch(HWC2_FUNCTION_PRESENT_DISPLAY, &mDispatch.presentDisplay);
169 initDispatch(HWC2_FUNCTION_REGISTER_CALLBACK,
170 &mDispatch.registerCallback);
171 initDispatch(HWC2_FUNCTION_SET_ACTIVE_CONFIG, &mDispatch.setActiveConfig);
172 initDispatch(HWC2_FUNCTION_SET_CLIENT_TARGET, &mDispatch.setClientTarget);
173 initDispatch(HWC2_FUNCTION_SET_COLOR_MODE, &mDispatch.setColorMode);
174 initDispatch(HWC2_FUNCTION_SET_COLOR_TRANSFORM,
175 &mDispatch.setColorTransform);
176 initDispatch(HWC2_FUNCTION_SET_CURSOR_POSITION,
177 &mDispatch.setCursorPosition);
178 initDispatch(HWC2_FUNCTION_SET_LAYER_BLEND_MODE,
179 &mDispatch.setLayerBlendMode);
180 initDispatch(HWC2_FUNCTION_SET_LAYER_BUFFER, &mDispatch.setLayerBuffer);
181 initDispatch(HWC2_FUNCTION_SET_LAYER_COLOR, &mDispatch.setLayerColor);
182 initDispatch(HWC2_FUNCTION_SET_LAYER_COMPOSITION_TYPE,
183 &mDispatch.setLayerCompositionType);
184 initDispatch(HWC2_FUNCTION_SET_LAYER_DATASPACE,
185 &mDispatch.setLayerDataspace);
186 initDispatch(HWC2_FUNCTION_SET_LAYER_DISPLAY_FRAME,
187 &mDispatch.setLayerDisplayFrame);
188 initDispatch(HWC2_FUNCTION_SET_LAYER_PLANE_ALPHA,
189 &mDispatch.setLayerPlaneAlpha);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800190
191 if (hasCapability(Capability::SIDEBAND_STREAM)) {
Chia-I Wue1768352016-12-19 12:56:54 +0800192 initDispatch(HWC2_FUNCTION_SET_LAYER_SIDEBAND_STREAM,
193 &mDispatch.setLayerSidebandStream);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800194 }
195
Chia-I Wue1768352016-12-19 12:56:54 +0800196 initDispatch(HWC2_FUNCTION_SET_LAYER_SOURCE_CROP,
197 &mDispatch.setLayerSourceCrop);
198 initDispatch(HWC2_FUNCTION_SET_LAYER_SURFACE_DAMAGE,
199 &mDispatch.setLayerSurfaceDamage);
200 initDispatch(HWC2_FUNCTION_SET_LAYER_TRANSFORM,
201 &mDispatch.setLayerTransform);
202 initDispatch(HWC2_FUNCTION_SET_LAYER_VISIBLE_REGION,
203 &mDispatch.setLayerVisibleRegion);
204 initDispatch(HWC2_FUNCTION_SET_LAYER_Z_ORDER, &mDispatch.setLayerZOrder);
205 initDispatch(HWC2_FUNCTION_SET_OUTPUT_BUFFER, &mDispatch.setOutputBuffer);
206 initDispatch(HWC2_FUNCTION_SET_POWER_MODE, &mDispatch.setPowerMode);
207 initDispatch(HWC2_FUNCTION_SET_VSYNC_ENABLED, &mDispatch.setVsyncEnabled);
208 initDispatch(HWC2_FUNCTION_VALIDATE_DISPLAY, &mDispatch.validateDisplay);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800209}
210
211bool HwcHal::hasCapability(Capability capability) const
212{
213 return (mCapabilities.count(capability) > 0);
214}
215
216Return<void> HwcHal::getCapabilities(getCapabilities_cb hidl_cb)
217{
218 std::vector<Capability> caps(
219 mCapabilities.cbegin(), mCapabilities.cend());
220
221 hidl_vec<Capability> caps_reply;
222 caps_reply.setToExternal(caps.data(), caps.size());
223 hidl_cb(caps_reply);
224
225 return Void();
226}
227
228Return<void> HwcHal::dumpDebugInfo(dumpDebugInfo_cb hidl_cb)
229{
Chia-I Wue1768352016-12-19 12:56:54 +0800230 uint32_t len = 0;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800231 mDispatch.dump(mDevice, &len, nullptr);
232
233 std::vector<char> buf(len + 1);
234 mDispatch.dump(mDevice, &len, buf.data());
235 buf.resize(len + 1);
236 buf[len] = '\0';
237
238 hidl_string buf_reply;
239 buf_reply.setToExternal(buf.data(), len);
240 hidl_cb(buf_reply);
241
242 return Void();
243}
244
Chia-I Wubb61a722016-10-24 15:40:20 +0800245Return<void> HwcHal::createClient(createClient_cb hidl_cb)
246{
247 Error err = Error::NONE;
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500248 sp<ComposerClient> client;
Chia-I Wubb61a722016-10-24 15:40:20 +0800249
250 {
Steven Thomasbc67a6a2017-07-07 12:34:20 -0700251 std::unique_lock<std::mutex> lock(mClientMutex);
252
253 if (mClient != nullptr) {
254 // In surface flinger we delete a composer client on one thread and
255 // then create a new client on another thread. Although surface
256 // flinger ensures the calls are made in that sequence (destroy and
257 // then create), sometimes the calls land in the composer service
258 // inverted (create and then destroy). Wait for a brief period to
259 // see if the existing client is destroyed.
260 ALOGI("HwcHal::createClient: Client already exists. Waiting for"
261 " it to be destroyed.");
262 mClientDestroyedWait.wait_for(lock, 1s,
263 [this] { return mClient == nullptr; });
264 std::string doneMsg = mClient == nullptr ?
265 "Existing client was destroyed." :
266 "Existing client was never destroyed!";
267 ALOGI("HwcHal::createClient: Done waiting. %s", doneMsg.c_str());
268 }
Chia-I Wubb61a722016-10-24 15:40:20 +0800269
270 // only one client is allowed
271 if (mClient == nullptr) {
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500272 client = new ComposerClient(*this);
273 client->initialize();
Chia-I Wubb61a722016-10-24 15:40:20 +0800274 mClient = client;
275 } else {
276 err = Error::NO_RESOURCES;
277 }
278 }
279
280 hidl_cb(err, client);
281
282 return Void();
283}
284
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500285sp<ComposerClient> HwcHal::getClient()
Chia-I Wubb61a722016-10-24 15:40:20 +0800286{
287 std::lock_guard<std::mutex> lock(mClientMutex);
288 return (mClient != nullptr) ? mClient.promote() : nullptr;
289}
290
291void HwcHal::removeClient()
292{
293 std::lock_guard<std::mutex> lock(mClientMutex);
294 mClient = nullptr;
Steven Thomasbc67a6a2017-07-07 12:34:20 -0700295 mClientDestroyedWait.notify_all();
Chia-I Wubb61a722016-10-24 15:40:20 +0800296}
297
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800298void HwcHal::hotplugHook(hwc2_callback_data_t callbackData,
299 hwc2_display_t display, int32_t connected)
300{
301 auto hal = reinterpret_cast<HwcHal*>(callbackData);
Chia-I Wubb61a722016-10-24 15:40:20 +0800302 auto client = hal->getClient();
303 if (client != nullptr) {
304 client->onHotplug(display,
305 static_cast<IComposerCallback::Connection>(connected));
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800306 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800307}
308
309void HwcHal::refreshHook(hwc2_callback_data_t callbackData,
310 hwc2_display_t display)
311{
312 auto hal = reinterpret_cast<HwcHal*>(callbackData);
Chia-I Wu8101b242017-10-06 12:29:14 -0700313 hal->mMustValidateDisplay = true;
314
Chia-I Wubb61a722016-10-24 15:40:20 +0800315 auto client = hal->getClient();
316 if (client != nullptr) {
317 client->onRefresh(display);
318 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800319}
320
321void HwcHal::vsyncHook(hwc2_callback_data_t callbackData,
322 hwc2_display_t display, int64_t timestamp)
323{
324 auto hal = reinterpret_cast<HwcHal*>(callbackData);
Chia-I Wubb61a722016-10-24 15:40:20 +0800325 auto client = hal->getClient();
326 if (client != nullptr) {
327 client->onVsync(display, timestamp);
328 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800329}
330
Chia-I Wubb61a722016-10-24 15:40:20 +0800331void HwcHal::enableCallback(bool enable)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800332{
Chia-I Wubb61a722016-10-24 15:40:20 +0800333 if (enable) {
Chia-I Wu8101b242017-10-06 12:29:14 -0700334 mMustValidateDisplay = true;
335
Chia-I Wubb61a722016-10-24 15:40:20 +0800336 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_HOTPLUG, this,
337 reinterpret_cast<hwc2_function_pointer_t>(hotplugHook));
338 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_REFRESH, this,
339 reinterpret_cast<hwc2_function_pointer_t>(refreshHook));
340 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_VSYNC, this,
341 reinterpret_cast<hwc2_function_pointer_t>(vsyncHook));
342 } else {
343 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_HOTPLUG, this,
344 nullptr);
345 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_REFRESH, this,
346 nullptr);
347 mDispatch.registerCallback(mDevice, HWC2_CALLBACK_VSYNC, this,
348 nullptr);
349 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800350}
351
Chia-I Wubb61a722016-10-24 15:40:20 +0800352uint32_t HwcHal::getMaxVirtualDisplayCount()
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800353{
354 return mDispatch.getMaxVirtualDisplayCount(mDevice);
355}
356
Chia-I Wubb61a722016-10-24 15:40:20 +0800357Error HwcHal::createVirtualDisplay(uint32_t width, uint32_t height,
Chia-I Wue1768352016-12-19 12:56:54 +0800358 PixelFormat* format, Display* outDisplay)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800359{
Chia-I Wue1768352016-12-19 12:56:54 +0800360 int32_t hwc_format = static_cast<int32_t>(*format);
Chia-I Wubb61a722016-10-24 15:40:20 +0800361 int32_t err = mDispatch.createVirtualDisplay(mDevice, width, height,
Chia-I Wue1768352016-12-19 12:56:54 +0800362 &hwc_format, outDisplay);
363 *format = static_cast<PixelFormat>(hwc_format);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800364
Chia-I Wubb61a722016-10-24 15:40:20 +0800365 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800366}
367
Chia-I Wubb61a722016-10-24 15:40:20 +0800368Error HwcHal::destroyVirtualDisplay(Display display)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800369{
Chia-I Wubb61a722016-10-24 15:40:20 +0800370 int32_t err = mDispatch.destroyVirtualDisplay(mDevice, display);
371 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800372}
373
Chia-I Wue1768352016-12-19 12:56:54 +0800374Error HwcHal::createLayer(Display display, Layer* outLayer)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800375{
Chia-I Wue1768352016-12-19 12:56:54 +0800376 int32_t err = mDispatch.createLayer(mDevice, display, outLayer);
Chia-I Wubb61a722016-10-24 15:40:20 +0800377 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800378}
379
Chia-I Wubb61a722016-10-24 15:40:20 +0800380Error HwcHal::destroyLayer(Display display, Layer layer)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800381{
Chia-I Wubb61a722016-10-24 15:40:20 +0800382 int32_t err = mDispatch.destroyLayer(mDevice, display, layer);
383 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800384}
385
Chia-I Wue1768352016-12-19 12:56:54 +0800386Error HwcHal::getActiveConfig(Display display, Config* outConfig)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800387{
Chia-I Wue1768352016-12-19 12:56:54 +0800388 int32_t err = mDispatch.getActiveConfig(mDevice, display, outConfig);
Chia-I Wubb61a722016-10-24 15:40:20 +0800389 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800390}
391
Chia-I Wubb61a722016-10-24 15:40:20 +0800392Error HwcHal::getClientTargetSupport(Display display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800393 uint32_t width, uint32_t height,
394 PixelFormat format, Dataspace dataspace)
395{
Chia-I Wubb61a722016-10-24 15:40:20 +0800396 int32_t err = mDispatch.getClientTargetSupport(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800397 width, height, static_cast<int32_t>(format),
398 static_cast<int32_t>(dataspace));
Chia-I Wubb61a722016-10-24 15:40:20 +0800399 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800400}
401
Chia-I Wue1768352016-12-19 12:56:54 +0800402Error HwcHal::getColorModes(Display display, hidl_vec<ColorMode>* outModes)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800403{
404 uint32_t count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800405 int32_t err = mDispatch.getColorModes(mDevice, display, &count, nullptr);
406 if (err != HWC2_ERROR_NONE) {
407 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800408 }
409
Chia-I Wue1768352016-12-19 12:56:54 +0800410 outModes->resize(count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800411 err = mDispatch.getColorModes(mDevice, display, &count,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800412 reinterpret_cast<std::underlying_type<ColorMode>::type*>(
Chia-I Wue1768352016-12-19 12:56:54 +0800413 outModes->data()));
Chia-I Wubb61a722016-10-24 15:40:20 +0800414 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800415 *outModes = hidl_vec<ColorMode>();
Chia-I Wubb61a722016-10-24 15:40:20 +0800416 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800417 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800418
Chia-I Wubb61a722016-10-24 15:40:20 +0800419 return Error::NONE;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800420}
421
Chia-I Wubb61a722016-10-24 15:40:20 +0800422Error HwcHal::getDisplayAttribute(Display display, Config config,
Chia-I Wue1768352016-12-19 12:56:54 +0800423 IComposerClient::Attribute attribute, int32_t* outValue)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800424{
Chia-I Wubb61a722016-10-24 15:40:20 +0800425 int32_t err = mDispatch.getDisplayAttribute(mDevice, display, config,
Chia-I Wue1768352016-12-19 12:56:54 +0800426 static_cast<int32_t>(attribute), outValue);
Chia-I Wubb61a722016-10-24 15:40:20 +0800427 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800428}
429
Chia-I Wue1768352016-12-19 12:56:54 +0800430Error HwcHal::getDisplayConfigs(Display display, hidl_vec<Config>* outConfigs)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800431{
432 uint32_t count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800433 int32_t err = mDispatch.getDisplayConfigs(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800434 &count, nullptr);
Chia-I Wubb61a722016-10-24 15:40:20 +0800435 if (err != HWC2_ERROR_NONE) {
436 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800437 }
438
Chia-I Wue1768352016-12-19 12:56:54 +0800439 outConfigs->resize(count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800440 err = mDispatch.getDisplayConfigs(mDevice, display,
Chia-I Wue1768352016-12-19 12:56:54 +0800441 &count, outConfigs->data());
Chia-I Wubb61a722016-10-24 15:40:20 +0800442 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800443 *outConfigs = hidl_vec<Config>();
Chia-I Wubb61a722016-10-24 15:40:20 +0800444 return static_cast<Error>(err);
445 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800446
Chia-I Wubb61a722016-10-24 15:40:20 +0800447 return Error::NONE;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800448}
449
Chia-I Wue1768352016-12-19 12:56:54 +0800450Error HwcHal::getDisplayName(Display display, hidl_string* outName)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800451{
452 uint32_t count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800453 int32_t err = mDispatch.getDisplayName(mDevice, display, &count, nullptr);
454 if (err != HWC2_ERROR_NONE) {
455 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800456 }
457
Chia-I Wubb61a722016-10-24 15:40:20 +0800458 std::vector<char> buf(count + 1);
459 err = mDispatch.getDisplayName(mDevice, display, &count, buf.data());
460 if (err != HWC2_ERROR_NONE) {
461 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800462 }
Chia-I Wubb61a722016-10-24 15:40:20 +0800463 buf.resize(count + 1);
464 buf[count] = '\0';
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800465
Chia-I Wue1768352016-12-19 12:56:54 +0800466 *outName = buf.data();
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800467
Chia-I Wubb61a722016-10-24 15:40:20 +0800468 return Error::NONE;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800469}
470
Chia-I Wue1768352016-12-19 12:56:54 +0800471Error HwcHal::getDisplayType(Display display,
472 IComposerClient::DisplayType* outType)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800473{
Chia-I Wubb61a722016-10-24 15:40:20 +0800474 int32_t hwc_type = HWC2_DISPLAY_TYPE_INVALID;
475 int32_t err = mDispatch.getDisplayType(mDevice, display, &hwc_type);
Chia-I Wue1768352016-12-19 12:56:54 +0800476 *outType = static_cast<IComposerClient::DisplayType>(hwc_type);
Chia-I Wubb61a722016-10-24 15:40:20 +0800477
478 return static_cast<Error>(err);
479}
480
Chia-I Wue1768352016-12-19 12:56:54 +0800481Error HwcHal::getDozeSupport(Display display, bool* outSupport)
Chia-I Wubb61a722016-10-24 15:40:20 +0800482{
483 int32_t hwc_support = 0;
484 int32_t err = mDispatch.getDozeSupport(mDevice, display, &hwc_support);
Chia-I Wue1768352016-12-19 12:56:54 +0800485 *outSupport = hwc_support;
Chia-I Wubb61a722016-10-24 15:40:20 +0800486
487 return static_cast<Error>(err);
488}
489
Chia-I Wue1768352016-12-19 12:56:54 +0800490Error HwcHal::getHdrCapabilities(Display display, hidl_vec<Hdr>* outTypes,
491 float* outMaxLuminance, float* outMaxAverageLuminance,
492 float* outMinLuminance)
Chia-I Wubb61a722016-10-24 15:40:20 +0800493{
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800494 uint32_t count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800495 int32_t err = mDispatch.getHdrCapabilities(mDevice, display, &count,
Chia-I Wue1768352016-12-19 12:56:54 +0800496 nullptr, outMaxLuminance, outMaxAverageLuminance,
497 outMinLuminance);
Chia-I Wubb61a722016-10-24 15:40:20 +0800498 if (err != HWC2_ERROR_NONE) {
499 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800500 }
501
Chia-I Wue1768352016-12-19 12:56:54 +0800502 outTypes->resize(count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800503 err = mDispatch.getHdrCapabilities(mDevice, display, &count,
Chia-I Wue1768352016-12-19 12:56:54 +0800504 reinterpret_cast<std::underlying_type<Hdr>::type*>(
505 outTypes->data()), outMaxLuminance,
506 outMaxAverageLuminance, outMinLuminance);
Chia-I Wubb61a722016-10-24 15:40:20 +0800507 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800508 *outTypes = hidl_vec<Hdr>();
Chia-I Wubb61a722016-10-24 15:40:20 +0800509 return static_cast<Error>(err);
510 }
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800511
Chia-I Wubb61a722016-10-24 15:40:20 +0800512 return Error::NONE;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800513}
514
Chia-I Wubb61a722016-10-24 15:40:20 +0800515Error HwcHal::setActiveConfig(Display display, Config config)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800516{
Chia-I Wubb61a722016-10-24 15:40:20 +0800517 int32_t err = mDispatch.setActiveConfig(mDevice, display, config);
518 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800519}
520
Chia-I Wubb61a722016-10-24 15:40:20 +0800521Error HwcHal::setColorMode(Display display, ColorMode mode)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800522{
Chia-I Wubb61a722016-10-24 15:40:20 +0800523 int32_t err = mDispatch.setColorMode(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800524 static_cast<int32_t>(mode));
Chia-I Wubb61a722016-10-24 15:40:20 +0800525 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800526}
527
Chia-I Wubb61a722016-10-24 15:40:20 +0800528Error HwcHal::setPowerMode(Display display, IComposerClient::PowerMode mode)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800529{
Chia-I Wubb61a722016-10-24 15:40:20 +0800530 int32_t err = mDispatch.setPowerMode(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800531 static_cast<int32_t>(mode));
Chia-I Wubb61a722016-10-24 15:40:20 +0800532 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800533}
534
Chia-I Wubb61a722016-10-24 15:40:20 +0800535Error HwcHal::setVsyncEnabled(Display display, IComposerClient::Vsync enabled)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800536{
Chia-I Wubb61a722016-10-24 15:40:20 +0800537 int32_t err = mDispatch.setVsyncEnabled(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800538 static_cast<int32_t>(enabled));
Chia-I Wubb61a722016-10-24 15:40:20 +0800539 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800540}
541
Chia-I Wubb61a722016-10-24 15:40:20 +0800542Error HwcHal::setColorTransform(Display display, const float* matrix,
543 int32_t hint)
544{
545 int32_t err = mDispatch.setColorTransform(mDevice, display, matrix, hint);
546 return static_cast<Error>(err);
547}
548
549Error HwcHal::setClientTarget(Display display, buffer_handle_t target,
550 int32_t acquireFence, int32_t dataspace,
551 const std::vector<hwc_rect_t>& damage)
552{
553 hwc_region region = { damage.size(), damage.data() };
554 int32_t err = mDispatch.setClientTarget(mDevice, display, target,
555 acquireFence, dataspace, region);
556 return static_cast<Error>(err);
557}
558
559Error HwcHal::setOutputBuffer(Display display, buffer_handle_t buffer,
560 int32_t releaseFence)
561{
562 int32_t err = mDispatch.setOutputBuffer(mDevice, display, buffer,
563 releaseFence);
564 // unlike in setClientTarget, releaseFence is owned by us
565 if (err == HWC2_ERROR_NONE && releaseFence >= 0) {
566 close(releaseFence);
567 }
568
569 return static_cast<Error>(err);
570}
571
572Error HwcHal::validateDisplay(Display display,
Chia-I Wue1768352016-12-19 12:56:54 +0800573 std::vector<Layer>* outChangedLayers,
574 std::vector<IComposerClient::Composition>* outCompositionTypes,
575 uint32_t* outDisplayRequestMask,
576 std::vector<Layer>* outRequestedLayers,
577 std::vector<uint32_t>* outRequestMasks)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800578{
579 uint32_t types_count = 0;
580 uint32_t reqs_count = 0;
Chia-I Wubb61a722016-10-24 15:40:20 +0800581 int32_t err = mDispatch.validateDisplay(mDevice, display,
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800582 &types_count, &reqs_count);
Chia-I Wu8101b242017-10-06 12:29:14 -0700583 mMustValidateDisplay = false;
584
Chia-I Wubb61a722016-10-24 15:40:20 +0800585 if (err != HWC2_ERROR_NONE && err != HWC2_ERROR_HAS_CHANGES) {
586 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800587 }
588
Chia-I Wubb61a722016-10-24 15:40:20 +0800589 err = mDispatch.getChangedCompositionTypes(mDevice, display,
590 &types_count, nullptr, nullptr);
591 if (err != HWC2_ERROR_NONE) {
592 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800593 }
594
Chia-I Wue1768352016-12-19 12:56:54 +0800595 outChangedLayers->resize(types_count);
596 outCompositionTypes->resize(types_count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800597 err = mDispatch.getChangedCompositionTypes(mDevice, display,
Chia-I Wue1768352016-12-19 12:56:54 +0800598 &types_count, outChangedLayers->data(),
Chia-I Wubb61a722016-10-24 15:40:20 +0800599 reinterpret_cast<
600 std::underlying_type<IComposerClient::Composition>::type*>(
Chia-I Wue1768352016-12-19 12:56:54 +0800601 outCompositionTypes->data()));
Chia-I Wubb61a722016-10-24 15:40:20 +0800602 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800603 outChangedLayers->clear();
604 outCompositionTypes->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800605 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800606 }
607
Chia-I Wubb61a722016-10-24 15:40:20 +0800608 int32_t display_reqs = 0;
609 err = mDispatch.getDisplayRequests(mDevice, display, &display_reqs,
610 &reqs_count, nullptr, nullptr);
611 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800612 outChangedLayers->clear();
613 outCompositionTypes->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800614 return static_cast<Error>(err);
615 }
616
Chia-I Wue1768352016-12-19 12:56:54 +0800617 outRequestedLayers->resize(reqs_count);
618 outRequestMasks->resize(reqs_count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800619 err = mDispatch.getDisplayRequests(mDevice, display, &display_reqs,
Chia-I Wue1768352016-12-19 12:56:54 +0800620 &reqs_count, outRequestedLayers->data(),
621 reinterpret_cast<int32_t*>(outRequestMasks->data()));
Chia-I Wubb61a722016-10-24 15:40:20 +0800622 if (err != HWC2_ERROR_NONE) {
Chia-I Wue1768352016-12-19 12:56:54 +0800623 outChangedLayers->clear();
624 outCompositionTypes->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800625
Chia-I Wue1768352016-12-19 12:56:54 +0800626 outRequestedLayers->clear();
627 outRequestMasks->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800628 return static_cast<Error>(err);
629 }
630
Chia-I Wue1768352016-12-19 12:56:54 +0800631 *outDisplayRequestMask = display_reqs;
Chia-I Wubb61a722016-10-24 15:40:20 +0800632
633 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800634}
635
Chia-I Wubb61a722016-10-24 15:40:20 +0800636Error HwcHal::acceptDisplayChanges(Display display)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800637{
Chia-I Wubb61a722016-10-24 15:40:20 +0800638 int32_t err = mDispatch.acceptDisplayChanges(mDevice, display);
639 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800640}
641
Chia-I Wue1768352016-12-19 12:56:54 +0800642Error HwcHal::presentDisplay(Display display, int32_t* outPresentFence,
643 std::vector<Layer>* outLayers, std::vector<int32_t>* outReleaseFences)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800644{
Chia-I Wu8101b242017-10-06 12:29:14 -0700645 if (mMustValidateDisplay) {
646 return Error::NOT_VALIDATED;
647 }
648
Chia-I Wue1768352016-12-19 12:56:54 +0800649 *outPresentFence = -1;
650 int32_t err = mDispatch.presentDisplay(mDevice, display, outPresentFence);
Chia-I Wubb61a722016-10-24 15:40:20 +0800651 if (err != HWC2_ERROR_NONE) {
652 return static_cast<Error>(err);
653 }
654
655 uint32_t count = 0;
656 err = mDispatch.getReleaseFences(mDevice, display, &count,
657 nullptr, nullptr);
658 if (err != HWC2_ERROR_NONE) {
659 ALOGW("failed to get release fences");
660 return Error::NONE;
661 }
662
Chia-I Wue1768352016-12-19 12:56:54 +0800663 outLayers->resize(count);
664 outReleaseFences->resize(count);
Chia-I Wubb61a722016-10-24 15:40:20 +0800665 err = mDispatch.getReleaseFences(mDevice, display, &count,
Chia-I Wue1768352016-12-19 12:56:54 +0800666 outLayers->data(), outReleaseFences->data());
Chia-I Wubb61a722016-10-24 15:40:20 +0800667 if (err != HWC2_ERROR_NONE) {
668 ALOGW("failed to get release fences");
Chia-I Wue1768352016-12-19 12:56:54 +0800669 outLayers->clear();
670 outReleaseFences->clear();
Chia-I Wubb61a722016-10-24 15:40:20 +0800671 return Error::NONE;
672 }
673
674 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800675}
676
Chia-I Wubb61a722016-10-24 15:40:20 +0800677Error HwcHal::setLayerCursorPosition(Display display, Layer layer,
678 int32_t x, int32_t y)
679{
680 int32_t err = mDispatch.setCursorPosition(mDevice, display, layer, x, y);
681 return static_cast<Error>(err);
682}
683
684Error HwcHal::setLayerBuffer(Display display, Layer layer,
685 buffer_handle_t buffer, int32_t acquireFence)
686{
687 int32_t err = mDispatch.setLayerBuffer(mDevice, display, layer,
688 buffer, acquireFence);
689 return static_cast<Error>(err);
690}
691
692Error HwcHal::setLayerSurfaceDamage(Display display, Layer layer,
693 const std::vector<hwc_rect_t>& damage)
694{
695 hwc_region region = { damage.size(), damage.data() };
696 int32_t err = mDispatch.setLayerSurfaceDamage(mDevice, display, layer,
697 region);
698 return static_cast<Error>(err);
699}
700
701Error HwcHal::setLayerBlendMode(Display display, Layer layer, int32_t mode)
702{
703 int32_t err = mDispatch.setLayerBlendMode(mDevice, display, layer, mode);
704 return static_cast<Error>(err);
705}
706
707Error HwcHal::setLayerColor(Display display, Layer layer,
708 IComposerClient::Color color)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800709{
710 hwc_color_t hwc_color{color.r, color.g, color.b, color.a};
Chia-I Wubb61a722016-10-24 15:40:20 +0800711 int32_t err = mDispatch.setLayerColor(mDevice, display, layer, hwc_color);
712 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800713}
714
Chia-I Wubb61a722016-10-24 15:40:20 +0800715Error HwcHal::setLayerCompositionType(Display display, Layer layer,
716 int32_t type)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800717{
Chia-I Wubb61a722016-10-24 15:40:20 +0800718 int32_t err = mDispatch.setLayerCompositionType(mDevice, display, layer,
719 type);
720 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800721}
722
Chia-I Wubb61a722016-10-24 15:40:20 +0800723Error HwcHal::setLayerDataspace(Display display, Layer layer,
724 int32_t dataspace)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800725{
Chia-I Wubb61a722016-10-24 15:40:20 +0800726 int32_t err = mDispatch.setLayerDataspace(mDevice, display, layer,
727 dataspace);
728 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800729}
730
Chia-I Wubb61a722016-10-24 15:40:20 +0800731Error HwcHal::setLayerDisplayFrame(Display display, Layer layer,
732 const hwc_rect_t& frame)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800733{
Chia-I Wubb61a722016-10-24 15:40:20 +0800734 int32_t err = mDispatch.setLayerDisplayFrame(mDevice, display, layer,
735 frame);
736 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800737}
738
Chia-I Wubb61a722016-10-24 15:40:20 +0800739Error HwcHal::setLayerPlaneAlpha(Display display, Layer layer, float alpha)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800740{
Chia-I Wubb61a722016-10-24 15:40:20 +0800741 int32_t err = mDispatch.setLayerPlaneAlpha(mDevice, display, layer,
742 alpha);
743 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800744}
745
Chia-I Wubb61a722016-10-24 15:40:20 +0800746Error HwcHal::setLayerSidebandStream(Display display, Layer layer,
747 buffer_handle_t stream)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800748{
Chia-I Wubb61a722016-10-24 15:40:20 +0800749 int32_t err = mDispatch.setLayerSidebandStream(mDevice, display, layer,
750 stream);
751 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800752}
753
Chia-I Wubb61a722016-10-24 15:40:20 +0800754Error HwcHal::setLayerSourceCrop(Display display, Layer layer,
755 const hwc_frect_t& crop)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800756{
Chia-I Wubb61a722016-10-24 15:40:20 +0800757 int32_t err = mDispatch.setLayerSourceCrop(mDevice, display, layer, crop);
758 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800759}
760
Chia-I Wubb61a722016-10-24 15:40:20 +0800761Error HwcHal::setLayerTransform(Display display, Layer layer,
762 int32_t transform)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800763{
Chia-I Wubb61a722016-10-24 15:40:20 +0800764 int32_t err = mDispatch.setLayerTransform(mDevice, display, layer,
765 transform);
766 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800767}
768
Chia-I Wubb61a722016-10-24 15:40:20 +0800769Error HwcHal::setLayerVisibleRegion(Display display, Layer layer,
770 const std::vector<hwc_rect_t>& visible)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800771{
Chia-I Wubb61a722016-10-24 15:40:20 +0800772 hwc_region_t region = { visible.size(), visible.data() };
773 int32_t err = mDispatch.setLayerVisibleRegion(mDevice, display, layer,
774 region);
775 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800776}
777
Chia-I Wubb61a722016-10-24 15:40:20 +0800778Error HwcHal::setLayerZOrder(Display display, Layer layer, uint32_t z)
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800779{
Chia-I Wubb61a722016-10-24 15:40:20 +0800780 int32_t err = mDispatch.setLayerZOrder(mDevice, display, layer, z);
781 return static_cast<Error>(err);
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800782}
783
784IComposer* HIDL_FETCH_IComposer(const char*)
785{
Chia-I Wue1768352016-12-19 12:56:54 +0800786 const hw_module_t* module = nullptr;
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800787 int err = hw_get_module(HWC_HARDWARE_MODULE_ID, &module);
788 if (err) {
Chia-I Wu16e8ed22017-10-19 09:49:03 -0700789 ALOGI("falling back to FB HAL");
790 err = hw_get_module(GRALLOC_HARDWARE_MODULE_ID, &module);
791 }
792 if (err) {
793 ALOGE("failed to get hwcomposer or fb module");
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800794 return nullptr;
795 }
796
797 return new HwcHal(module);
798}
799
800} // namespace implementation
801} // namespace V2_1
802} // namespace composer
803} // namespace graphics
804} // namespace hardware
805} // namespace android