blob: 756132759cbe81bcf02ea4ba1a0f040e39c8298a [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
Steven Thomasbc67a6a2017-07-07 12:34:20 -070020#include <condition_variable>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070021#include <memory>
Steven Thomasbc67a6a2017-07-07 12:34:20 -070022#include <mutex>
Chia-I Wubb61a722016-10-24 15:40:20 +080023#include <unordered_set>
24#include <vector>
25
Chia-I Wu7f8d3962016-09-28 21:04:23 +080026#include <android/hardware/graphics/composer/2.1/IComposer.h>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070027#define HWC2_INCLUDE_STRINGIFICATION
28#define HWC2_USE_CPP11
Chia-I Wubb61a722016-10-24 15:40:20 +080029#include <hardware/hwcomposer2.h>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070030#undef HWC2_INCLUDE_STRINGIFICATION
31#undef HWC2_USE_CPP11
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050032#include "ComposerBase.h"
33
Chia-I Wu7f8d3962016-09-28 21:04:23 +080034namespace android {
Fabien Sanglard0d55a212017-03-16 16:56:46 -070035 class HWC2On1Adapter;
36}
37
38namespace android {
Chia-I Wu7f8d3962016-09-28 21:04:23 +080039namespace hardware {
40namespace graphics {
41namespace composer {
42namespace V2_1 {
43namespace implementation {
44
Chia-I Wubb61a722016-10-24 15:40:20 +080045using android::hardware::graphics::common::V1_0::PixelFormat;
46using android::hardware::graphics::common::V1_0::Transform;
47using android::hardware::graphics::common::V1_0::Dataspace;
48using android::hardware::graphics::common::V1_0::ColorMode;
49using android::hardware::graphics::common::V1_0::ColorTransform;
50using android::hardware::graphics::common::V1_0::Hdr;
51
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050052class ComposerClient;
Chia-I Wubb61a722016-10-24 15:40:20 +080053
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050054class HwcHal : public IComposer, public ComposerBase {
Chia-I Wubb61a722016-10-24 15:40:20 +080055public:
56 HwcHal(const hw_module_t* module);
57 virtual ~HwcHal();
58
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050059 bool hasCapability(Capability capability) const;
60
Chia-I Wubb61a722016-10-24 15:40:20 +080061 // IComposer interface
62 Return<void> getCapabilities(getCapabilities_cb hidl_cb) override;
63 Return<void> dumpDebugInfo(dumpDebugInfo_cb hidl_cb) override;
64 Return<void> createClient(createClient_cb hidl_cb) override;
65
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050066 // ComposerBase interface
67 void removeClient() override;
68 void enableCallback(bool enable) override;
69 uint32_t getMaxVirtualDisplayCount() override;
Chia-I Wubb61a722016-10-24 15:40:20 +080070 Error createVirtualDisplay(uint32_t width, uint32_t height,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050071 PixelFormat* format, Display* outDisplay) override;
72 Error destroyVirtualDisplay(Display display) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080073
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050074 Error createLayer(Display display, Layer* outLayer) override;
75 Error destroyLayer(Display display, Layer layer) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080076
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050077 Error getActiveConfig(Display display, Config* outConfig) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080078 Error getClientTargetSupport(Display display,
79 uint32_t width, uint32_t height,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050080 PixelFormat format, Dataspace dataspace) override;
81 Error getColorModes(Display display,
82 hidl_vec<ColorMode>* outModes) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080083 Error getDisplayAttribute(Display display, Config config,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050084 IComposerClient::Attribute attribute, int32_t* outValue) override;
85 Error getDisplayConfigs(Display display,
86 hidl_vec<Config>* outConfigs) override;
87 Error getDisplayName(Display display, hidl_string* outName) override;
Chia-I Wue1768352016-12-19 12:56:54 +080088 Error getDisplayType(Display display,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050089 IComposerClient::DisplayType* outType) override;
90 Error getDozeSupport(Display display, bool* outSupport) override;
Chia-I Wue1768352016-12-19 12:56:54 +080091 Error getHdrCapabilities(Display display, hidl_vec<Hdr>* outTypes,
92 float* outMaxLuminance, float* outMaxAverageLuminance,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050093 float* outMinLuminance) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080094
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050095 Error setActiveConfig(Display display, Config config) override;
96 Error setColorMode(Display display, ColorMode mode) override;
97 Error setPowerMode(Display display,
98 IComposerClient::PowerMode mode) override;
99 Error setVsyncEnabled(Display display,
100 IComposerClient::Vsync enabled) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800101
102 Error setColorTransform(Display display, const float* matrix,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500103 int32_t hint) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800104 Error setClientTarget(Display display, buffer_handle_t target,
105 int32_t acquireFence, int32_t dataspace,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500106 const std::vector<hwc_rect_t>& damage) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800107 Error setOutputBuffer(Display display, buffer_handle_t buffer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500108 int32_t releaseFence) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800109 Error validateDisplay(Display display,
Chia-I Wue1768352016-12-19 12:56:54 +0800110 std::vector<Layer>* outChangedLayers,
111 std::vector<IComposerClient::Composition>* outCompositionTypes,
112 uint32_t* outDisplayRequestMask,
113 std::vector<Layer>* outRequestedLayers,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500114 std::vector<uint32_t>* outRequestMasks) override;
115 Error acceptDisplayChanges(Display display) override;
Chia-I Wue1768352016-12-19 12:56:54 +0800116 Error presentDisplay(Display display, int32_t* outPresentFence,
117 std::vector<Layer>* outLayers,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500118 std::vector<int32_t>* outReleaseFences) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800119
120 Error setLayerCursorPosition(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500121 int32_t x, int32_t y) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800122 Error setLayerBuffer(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500123 buffer_handle_t buffer, int32_t acquireFence) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800124 Error setLayerSurfaceDamage(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500125 const std::vector<hwc_rect_t>& damage) override;
126 Error setLayerBlendMode(Display display, Layer layer,
127 int32_t mode) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800128 Error setLayerColor(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500129 IComposerClient::Color color) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800130 Error setLayerCompositionType(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500131 int32_t type) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800132 Error setLayerDataspace(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500133 int32_t dataspace) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800134 Error setLayerDisplayFrame(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500135 const hwc_rect_t& frame) override;
136 Error setLayerPlaneAlpha(Display display, Layer layer,
137 float alpha) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800138 Error setLayerSidebandStream(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500139 buffer_handle_t stream) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800140 Error setLayerSourceCrop(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500141 const hwc_frect_t& crop) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800142 Error setLayerTransform(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500143 int32_t transform) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800144 Error setLayerVisibleRegion(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500145 const std::vector<hwc_rect_t>& visible) override;
146 Error setLayerZOrder(Display display, Layer layer, uint32_t z) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800147
148private:
149 void initCapabilities();
150
151 template<typename T>
Chia-I Wue1768352016-12-19 12:56:54 +0800152 void initDispatch(hwc2_function_descriptor_t desc, T* outPfn);
Chia-I Wubb61a722016-10-24 15:40:20 +0800153 void initDispatch();
154
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500155 sp<ComposerClient> getClient();
Chia-I Wubb61a722016-10-24 15:40:20 +0800156
157 static void hotplugHook(hwc2_callback_data_t callbackData,
158 hwc2_display_t display, int32_t connected);
159 static void refreshHook(hwc2_callback_data_t callbackData,
160 hwc2_display_t display);
161 static void vsyncHook(hwc2_callback_data_t callbackData,
162 hwc2_display_t display, int64_t timestamp);
163
164 hwc2_device_t* mDevice;
165
166 std::unordered_set<Capability> mCapabilities;
167
168 struct {
169 HWC2_PFN_ACCEPT_DISPLAY_CHANGES acceptDisplayChanges;
170 HWC2_PFN_CREATE_LAYER createLayer;
171 HWC2_PFN_CREATE_VIRTUAL_DISPLAY createVirtualDisplay;
172 HWC2_PFN_DESTROY_LAYER destroyLayer;
173 HWC2_PFN_DESTROY_VIRTUAL_DISPLAY destroyVirtualDisplay;
174 HWC2_PFN_DUMP dump;
175 HWC2_PFN_GET_ACTIVE_CONFIG getActiveConfig;
176 HWC2_PFN_GET_CHANGED_COMPOSITION_TYPES getChangedCompositionTypes;
177 HWC2_PFN_GET_CLIENT_TARGET_SUPPORT getClientTargetSupport;
178 HWC2_PFN_GET_COLOR_MODES getColorModes;
179 HWC2_PFN_GET_DISPLAY_ATTRIBUTE getDisplayAttribute;
180 HWC2_PFN_GET_DISPLAY_CONFIGS getDisplayConfigs;
181 HWC2_PFN_GET_DISPLAY_NAME getDisplayName;
182 HWC2_PFN_GET_DISPLAY_REQUESTS getDisplayRequests;
183 HWC2_PFN_GET_DISPLAY_TYPE getDisplayType;
184 HWC2_PFN_GET_DOZE_SUPPORT getDozeSupport;
185 HWC2_PFN_GET_HDR_CAPABILITIES getHdrCapabilities;
186 HWC2_PFN_GET_MAX_VIRTUAL_DISPLAY_COUNT getMaxVirtualDisplayCount;
187 HWC2_PFN_GET_RELEASE_FENCES getReleaseFences;
188 HWC2_PFN_PRESENT_DISPLAY presentDisplay;
189 HWC2_PFN_REGISTER_CALLBACK registerCallback;
190 HWC2_PFN_SET_ACTIVE_CONFIG setActiveConfig;
191 HWC2_PFN_SET_CLIENT_TARGET setClientTarget;
192 HWC2_PFN_SET_COLOR_MODE setColorMode;
193 HWC2_PFN_SET_COLOR_TRANSFORM setColorTransform;
194 HWC2_PFN_SET_CURSOR_POSITION setCursorPosition;
195 HWC2_PFN_SET_LAYER_BLEND_MODE setLayerBlendMode;
196 HWC2_PFN_SET_LAYER_BUFFER setLayerBuffer;
197 HWC2_PFN_SET_LAYER_COLOR setLayerColor;
198 HWC2_PFN_SET_LAYER_COMPOSITION_TYPE setLayerCompositionType;
199 HWC2_PFN_SET_LAYER_DATASPACE setLayerDataspace;
200 HWC2_PFN_SET_LAYER_DISPLAY_FRAME setLayerDisplayFrame;
201 HWC2_PFN_SET_LAYER_PLANE_ALPHA setLayerPlaneAlpha;
202 HWC2_PFN_SET_LAYER_SIDEBAND_STREAM setLayerSidebandStream;
203 HWC2_PFN_SET_LAYER_SOURCE_CROP setLayerSourceCrop;
204 HWC2_PFN_SET_LAYER_SURFACE_DAMAGE setLayerSurfaceDamage;
205 HWC2_PFN_SET_LAYER_TRANSFORM setLayerTransform;
206 HWC2_PFN_SET_LAYER_VISIBLE_REGION setLayerVisibleRegion;
207 HWC2_PFN_SET_LAYER_Z_ORDER setLayerZOrder;
208 HWC2_PFN_SET_OUTPUT_BUFFER setOutputBuffer;
209 HWC2_PFN_SET_POWER_MODE setPowerMode;
210 HWC2_PFN_SET_VSYNC_ENABLED setVsyncEnabled;
211 HWC2_PFN_VALIDATE_DISPLAY validateDisplay;
212 } mDispatch;
213
214 std::mutex mClientMutex;
Steven Thomasbc67a6a2017-07-07 12:34:20 -0700215 std::condition_variable mClientDestroyedWait;
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500216 wp<ComposerClient> mClient;
Fabien Sanglard0d55a212017-03-16 16:56:46 -0700217
218 // If the HWC implementation version is < 2.0, use an adapter to interface
219 // between HWC 2.0 <-> HWC 1.X.
220 std::unique_ptr<HWC2On1Adapter> mAdapter;
Chia-I Wubb61a722016-10-24 15:40:20 +0800221};
222
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800223extern "C" IComposer* HIDL_FETCH_IComposer(const char* name);
224
225} // namespace implementation
226} // namespace V2_1
227} // namespace composer
228} // namespace graphics
229} // namespace hardware
230} // namespace android
231
232#endif // ANDROID_HARDWARE_GRAPHICS_COMPOSER_V2_1_HWC_H