blob: cf6a72a197478cae226e95c2faba810bf4d626a4 [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#ifndef ANDROID_HARDWARE_GRAPHICS_COMPOSER_V2_1_HWC_H
18#define ANDROID_HARDWARE_GRAPHICS_COMPOSER_V2_1_HWC_H
19
Chia-I Wu8101b242017-10-06 12:29:14 -070020#include <atomic>
Steven Thomasbc67a6a2017-07-07 12:34:20 -070021#include <condition_variable>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070022#include <memory>
Steven Thomasbc67a6a2017-07-07 12:34:20 -070023#include <mutex>
Chia-I Wubb61a722016-10-24 15:40:20 +080024#include <unordered_set>
25#include <vector>
26
Chia-I Wu7f8d3962016-09-28 21:04:23 +080027#include <android/hardware/graphics/composer/2.1/IComposer.h>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070028#define HWC2_INCLUDE_STRINGIFICATION
29#define HWC2_USE_CPP11
Chia-I Wubb61a722016-10-24 15:40:20 +080030#include <hardware/hwcomposer2.h>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070031#undef HWC2_INCLUDE_STRINGIFICATION
32#undef HWC2_USE_CPP11
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050033#include "ComposerBase.h"
34
Chia-I Wu7f8d3962016-09-28 21:04:23 +080035namespace android {
Fabien Sanglard0d55a212017-03-16 16:56:46 -070036 class HWC2On1Adapter;
37}
38
39namespace android {
Chia-I Wu7f8d3962016-09-28 21:04:23 +080040namespace hardware {
41namespace graphics {
42namespace composer {
43namespace V2_1 {
44namespace implementation {
45
Chia-I Wubb61a722016-10-24 15:40:20 +080046using android::hardware::graphics::common::V1_0::PixelFormat;
47using android::hardware::graphics::common::V1_0::Transform;
48using android::hardware::graphics::common::V1_0::Dataspace;
49using android::hardware::graphics::common::V1_0::ColorMode;
50using android::hardware::graphics::common::V1_0::ColorTransform;
51using android::hardware::graphics::common::V1_0::Hdr;
52
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050053class ComposerClient;
Chia-I Wubb61a722016-10-24 15:40:20 +080054
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050055class HwcHal : public IComposer, public ComposerBase {
Chia-I Wubb61a722016-10-24 15:40:20 +080056public:
57 HwcHal(const hw_module_t* module);
58 virtual ~HwcHal();
59
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050060 bool hasCapability(Capability capability) const;
61
Chia-I Wubb61a722016-10-24 15:40:20 +080062 // IComposer interface
63 Return<void> getCapabilities(getCapabilities_cb hidl_cb) override;
64 Return<void> dumpDebugInfo(dumpDebugInfo_cb hidl_cb) override;
65 Return<void> createClient(createClient_cb hidl_cb) override;
66
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050067 // ComposerBase interface
68 void removeClient() override;
69 void enableCallback(bool enable) override;
70 uint32_t getMaxVirtualDisplayCount() override;
Chia-I Wubb61a722016-10-24 15:40:20 +080071 Error createVirtualDisplay(uint32_t width, uint32_t height,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050072 PixelFormat* format, Display* outDisplay) override;
73 Error destroyVirtualDisplay(Display display) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080074
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050075 Error createLayer(Display display, Layer* outLayer) override;
76 Error destroyLayer(Display display, Layer layer) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080077
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050078 Error getActiveConfig(Display display, Config* outConfig) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080079 Error getClientTargetSupport(Display display,
80 uint32_t width, uint32_t height,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050081 PixelFormat format, Dataspace dataspace) override;
82 Error getColorModes(Display display,
83 hidl_vec<ColorMode>* outModes) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080084 Error getDisplayAttribute(Display display, Config config,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050085 IComposerClient::Attribute attribute, int32_t* outValue) override;
86 Error getDisplayConfigs(Display display,
87 hidl_vec<Config>* outConfigs) override;
88 Error getDisplayName(Display display, hidl_string* outName) override;
Chia-I Wue1768352016-12-19 12:56:54 +080089 Error getDisplayType(Display display,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050090 IComposerClient::DisplayType* outType) override;
91 Error getDozeSupport(Display display, bool* outSupport) override;
Chia-I Wue1768352016-12-19 12:56:54 +080092 Error getHdrCapabilities(Display display, hidl_vec<Hdr>* outTypes,
93 float* outMaxLuminance, float* outMaxAverageLuminance,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050094 float* outMinLuminance) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080095
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050096 Error setActiveConfig(Display display, Config config) override;
97 Error setColorMode(Display display, ColorMode mode) override;
98 Error setPowerMode(Display display,
99 IComposerClient::PowerMode mode) override;
100 Error setVsyncEnabled(Display display,
101 IComposerClient::Vsync enabled) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800102
103 Error setColorTransform(Display display, const float* matrix,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500104 int32_t hint) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800105 Error setClientTarget(Display display, buffer_handle_t target,
106 int32_t acquireFence, int32_t dataspace,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500107 const std::vector<hwc_rect_t>& damage) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800108 Error setOutputBuffer(Display display, buffer_handle_t buffer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500109 int32_t releaseFence) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800110 Error validateDisplay(Display display,
Chia-I Wue1768352016-12-19 12:56:54 +0800111 std::vector<Layer>* outChangedLayers,
112 std::vector<IComposerClient::Composition>* outCompositionTypes,
113 uint32_t* outDisplayRequestMask,
114 std::vector<Layer>* outRequestedLayers,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500115 std::vector<uint32_t>* outRequestMasks) override;
116 Error acceptDisplayChanges(Display display) override;
Chia-I Wue1768352016-12-19 12:56:54 +0800117 Error presentDisplay(Display display, int32_t* outPresentFence,
118 std::vector<Layer>* outLayers,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500119 std::vector<int32_t>* outReleaseFences) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800120
121 Error setLayerCursorPosition(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500122 int32_t x, int32_t y) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800123 Error setLayerBuffer(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500124 buffer_handle_t buffer, int32_t acquireFence) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800125 Error setLayerSurfaceDamage(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500126 const std::vector<hwc_rect_t>& damage) override;
127 Error setLayerBlendMode(Display display, Layer layer,
128 int32_t mode) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800129 Error setLayerColor(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500130 IComposerClient::Color color) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800131 Error setLayerCompositionType(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500132 int32_t type) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800133 Error setLayerDataspace(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500134 int32_t dataspace) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800135 Error setLayerDisplayFrame(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500136 const hwc_rect_t& frame) override;
137 Error setLayerPlaneAlpha(Display display, Layer layer,
138 float alpha) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800139 Error setLayerSidebandStream(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500140 buffer_handle_t stream) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800141 Error setLayerSourceCrop(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500142 const hwc_frect_t& crop) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800143 Error setLayerTransform(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500144 int32_t transform) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800145 Error setLayerVisibleRegion(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500146 const std::vector<hwc_rect_t>& visible) override;
147 Error setLayerZOrder(Display display, Layer layer, uint32_t z) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800148
149private:
150 void initCapabilities();
151
152 template<typename T>
Chia-I Wue1768352016-12-19 12:56:54 +0800153 void initDispatch(hwc2_function_descriptor_t desc, T* outPfn);
Chia-I Wubb61a722016-10-24 15:40:20 +0800154 void initDispatch();
155
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500156 sp<ComposerClient> getClient();
Chia-I Wubb61a722016-10-24 15:40:20 +0800157
158 static void hotplugHook(hwc2_callback_data_t callbackData,
159 hwc2_display_t display, int32_t connected);
160 static void refreshHook(hwc2_callback_data_t callbackData,
161 hwc2_display_t display);
162 static void vsyncHook(hwc2_callback_data_t callbackData,
163 hwc2_display_t display, int64_t timestamp);
164
165 hwc2_device_t* mDevice;
166
167 std::unordered_set<Capability> mCapabilities;
168
169 struct {
170 HWC2_PFN_ACCEPT_DISPLAY_CHANGES acceptDisplayChanges;
171 HWC2_PFN_CREATE_LAYER createLayer;
172 HWC2_PFN_CREATE_VIRTUAL_DISPLAY createVirtualDisplay;
173 HWC2_PFN_DESTROY_LAYER destroyLayer;
174 HWC2_PFN_DESTROY_VIRTUAL_DISPLAY destroyVirtualDisplay;
175 HWC2_PFN_DUMP dump;
176 HWC2_PFN_GET_ACTIVE_CONFIG getActiveConfig;
177 HWC2_PFN_GET_CHANGED_COMPOSITION_TYPES getChangedCompositionTypes;
178 HWC2_PFN_GET_CLIENT_TARGET_SUPPORT getClientTargetSupport;
179 HWC2_PFN_GET_COLOR_MODES getColorModes;
180 HWC2_PFN_GET_DISPLAY_ATTRIBUTE getDisplayAttribute;
181 HWC2_PFN_GET_DISPLAY_CONFIGS getDisplayConfigs;
182 HWC2_PFN_GET_DISPLAY_NAME getDisplayName;
183 HWC2_PFN_GET_DISPLAY_REQUESTS getDisplayRequests;
184 HWC2_PFN_GET_DISPLAY_TYPE getDisplayType;
185 HWC2_PFN_GET_DOZE_SUPPORT getDozeSupport;
186 HWC2_PFN_GET_HDR_CAPABILITIES getHdrCapabilities;
187 HWC2_PFN_GET_MAX_VIRTUAL_DISPLAY_COUNT getMaxVirtualDisplayCount;
188 HWC2_PFN_GET_RELEASE_FENCES getReleaseFences;
189 HWC2_PFN_PRESENT_DISPLAY presentDisplay;
190 HWC2_PFN_REGISTER_CALLBACK registerCallback;
191 HWC2_PFN_SET_ACTIVE_CONFIG setActiveConfig;
192 HWC2_PFN_SET_CLIENT_TARGET setClientTarget;
193 HWC2_PFN_SET_COLOR_MODE setColorMode;
194 HWC2_PFN_SET_COLOR_TRANSFORM setColorTransform;
195 HWC2_PFN_SET_CURSOR_POSITION setCursorPosition;
196 HWC2_PFN_SET_LAYER_BLEND_MODE setLayerBlendMode;
197 HWC2_PFN_SET_LAYER_BUFFER setLayerBuffer;
198 HWC2_PFN_SET_LAYER_COLOR setLayerColor;
199 HWC2_PFN_SET_LAYER_COMPOSITION_TYPE setLayerCompositionType;
200 HWC2_PFN_SET_LAYER_DATASPACE setLayerDataspace;
201 HWC2_PFN_SET_LAYER_DISPLAY_FRAME setLayerDisplayFrame;
202 HWC2_PFN_SET_LAYER_PLANE_ALPHA setLayerPlaneAlpha;
203 HWC2_PFN_SET_LAYER_SIDEBAND_STREAM setLayerSidebandStream;
204 HWC2_PFN_SET_LAYER_SOURCE_CROP setLayerSourceCrop;
205 HWC2_PFN_SET_LAYER_SURFACE_DAMAGE setLayerSurfaceDamage;
206 HWC2_PFN_SET_LAYER_TRANSFORM setLayerTransform;
207 HWC2_PFN_SET_LAYER_VISIBLE_REGION setLayerVisibleRegion;
208 HWC2_PFN_SET_LAYER_Z_ORDER setLayerZOrder;
209 HWC2_PFN_SET_OUTPUT_BUFFER setOutputBuffer;
210 HWC2_PFN_SET_POWER_MODE setPowerMode;
211 HWC2_PFN_SET_VSYNC_ENABLED setVsyncEnabled;
212 HWC2_PFN_VALIDATE_DISPLAY validateDisplay;
213 } mDispatch;
214
215 std::mutex mClientMutex;
Steven Thomasbc67a6a2017-07-07 12:34:20 -0700216 std::condition_variable mClientDestroyedWait;
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500217 wp<ComposerClient> mClient;
Fabien Sanglard0d55a212017-03-16 16:56:46 -0700218
Chia-I Wu8101b242017-10-06 12:29:14 -0700219 std::atomic<bool> mMustValidateDisplay;
220
Fabien Sanglard0d55a212017-03-16 16:56:46 -0700221 // If the HWC implementation version is < 2.0, use an adapter to interface
222 // between HWC 2.0 <-> HWC 1.X.
223 std::unique_ptr<HWC2On1Adapter> mAdapter;
Chia-I Wubb61a722016-10-24 15:40:20 +0800224};
225
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800226extern "C" IComposer* HIDL_FETCH_IComposer(const char* name);
227
228} // namespace implementation
229} // namespace V2_1
230} // namespace composer
231} // namespace graphics
232} // namespace hardware
233} // namespace android
234
235#endif // ANDROID_HARDWARE_GRAPHICS_COMPOSER_V2_1_HWC_H