blob: b45389ad8210b5c10584c3fbf935a5e630e31a91 [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 Wubb61a722016-10-24 15:40:20 +080020#include <mutex>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070021#include <memory>
Chia-I Wubb61a722016-10-24 15:40:20 +080022#include <unordered_set>
23#include <vector>
24
Chia-I Wu7f8d3962016-09-28 21:04:23 +080025#include <android/hardware/graphics/composer/2.1/IComposer.h>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070026#define HWC2_INCLUDE_STRINGIFICATION
27#define HWC2_USE_CPP11
Chia-I Wubb61a722016-10-24 15:40:20 +080028#include <hardware/hwcomposer2.h>
Fabien Sanglard0d55a212017-03-16 16:56:46 -070029#undef HWC2_INCLUDE_STRINGIFICATION
30#undef HWC2_USE_CPP11
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050031#include "ComposerBase.h"
32
Chia-I Wu7f8d3962016-09-28 21:04:23 +080033namespace android {
Fabien Sanglard0d55a212017-03-16 16:56:46 -070034 class HWC2On1Adapter;
35}
36
37namespace android {
Chia-I Wu7f8d3962016-09-28 21:04:23 +080038namespace hardware {
39namespace graphics {
40namespace composer {
41namespace V2_1 {
42namespace implementation {
43
Chia-I Wubb61a722016-10-24 15:40:20 +080044using android::hardware::graphics::common::V1_0::PixelFormat;
45using android::hardware::graphics::common::V1_0::Transform;
46using android::hardware::graphics::common::V1_0::Dataspace;
47using android::hardware::graphics::common::V1_0::ColorMode;
48using android::hardware::graphics::common::V1_0::ColorTransform;
49using android::hardware::graphics::common::V1_0::Hdr;
50
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050051class ComposerClient;
Chia-I Wubb61a722016-10-24 15:40:20 +080052
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050053class HwcHal : public IComposer, public ComposerBase {
Chia-I Wubb61a722016-10-24 15:40:20 +080054public:
55 HwcHal(const hw_module_t* module);
56 virtual ~HwcHal();
57
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050058 bool hasCapability(Capability capability) const;
59
Chia-I Wubb61a722016-10-24 15:40:20 +080060 // IComposer interface
61 Return<void> getCapabilities(getCapabilities_cb hidl_cb) override;
62 Return<void> dumpDebugInfo(dumpDebugInfo_cb hidl_cb) override;
63 Return<void> createClient(createClient_cb hidl_cb) override;
64
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050065 // ComposerBase interface
66 void removeClient() override;
67 void enableCallback(bool enable) override;
68 uint32_t getMaxVirtualDisplayCount() override;
Chia-I Wubb61a722016-10-24 15:40:20 +080069 Error createVirtualDisplay(uint32_t width, uint32_t height,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050070 PixelFormat* format, Display* outDisplay) override;
71 Error destroyVirtualDisplay(Display display) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080072
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050073 Error createLayer(Display display, Layer* outLayer) override;
74 Error destroyLayer(Display display, Layer layer) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080075
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050076 Error getActiveConfig(Display display, Config* outConfig) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080077 Error getClientTargetSupport(Display display,
78 uint32_t width, uint32_t height,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050079 PixelFormat format, Dataspace dataspace) override;
80 Error getColorModes(Display display,
81 hidl_vec<ColorMode>* outModes) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080082 Error getDisplayAttribute(Display display, Config config,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050083 IComposerClient::Attribute attribute, int32_t* outValue) override;
84 Error getDisplayConfigs(Display display,
85 hidl_vec<Config>* outConfigs) override;
86 Error getDisplayName(Display display, hidl_string* outName) override;
Chia-I Wue1768352016-12-19 12:56:54 +080087 Error getDisplayType(Display display,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050088 IComposerClient::DisplayType* outType) override;
89 Error getDozeSupport(Display display, bool* outSupport) override;
Chia-I Wue1768352016-12-19 12:56:54 +080090 Error getHdrCapabilities(Display display, hidl_vec<Hdr>* outTypes,
91 float* outMaxLuminance, float* outMaxAverageLuminance,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050092 float* outMinLuminance) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080093
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050094 Error setActiveConfig(Display display, Config config) override;
95 Error setColorMode(Display display, ColorMode mode) override;
96 Error setPowerMode(Display display,
97 IComposerClient::PowerMode mode) override;
98 Error setVsyncEnabled(Display display,
99 IComposerClient::Vsync enabled) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800100
101 Error setColorTransform(Display display, const float* matrix,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500102 int32_t hint) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800103 Error setClientTarget(Display display, buffer_handle_t target,
104 int32_t acquireFence, int32_t dataspace,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500105 const std::vector<hwc_rect_t>& damage) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800106 Error setOutputBuffer(Display display, buffer_handle_t buffer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500107 int32_t releaseFence) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800108 Error validateDisplay(Display display,
Chia-I Wue1768352016-12-19 12:56:54 +0800109 std::vector<Layer>* outChangedLayers,
110 std::vector<IComposerClient::Composition>* outCompositionTypes,
111 uint32_t* outDisplayRequestMask,
112 std::vector<Layer>* outRequestedLayers,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500113 std::vector<uint32_t>* outRequestMasks) override;
114 Error acceptDisplayChanges(Display display) override;
Chia-I Wue1768352016-12-19 12:56:54 +0800115 Error presentDisplay(Display display, int32_t* outPresentFence,
116 std::vector<Layer>* outLayers,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500117 std::vector<int32_t>* outReleaseFences) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800118
119 Error setLayerCursorPosition(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500120 int32_t x, int32_t y) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800121 Error setLayerBuffer(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500122 buffer_handle_t buffer, int32_t acquireFence) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800123 Error setLayerSurfaceDamage(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500124 const std::vector<hwc_rect_t>& damage) override;
125 Error setLayerBlendMode(Display display, Layer layer,
126 int32_t mode) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800127 Error setLayerColor(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500128 IComposerClient::Color color) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800129 Error setLayerCompositionType(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500130 int32_t type) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800131 Error setLayerDataspace(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500132 int32_t dataspace) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800133 Error setLayerDisplayFrame(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500134 const hwc_rect_t& frame) override;
135 Error setLayerPlaneAlpha(Display display, Layer layer,
136 float alpha) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800137 Error setLayerSidebandStream(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500138 buffer_handle_t stream) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800139 Error setLayerSourceCrop(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500140 const hwc_frect_t& crop) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800141 Error setLayerTransform(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500142 int32_t transform) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800143 Error setLayerVisibleRegion(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500144 const std::vector<hwc_rect_t>& visible) override;
145 Error setLayerZOrder(Display display, Layer layer, uint32_t z) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800146
147private:
148 void initCapabilities();
149
150 template<typename T>
Chia-I Wue1768352016-12-19 12:56:54 +0800151 void initDispatch(hwc2_function_descriptor_t desc, T* outPfn);
Chia-I Wubb61a722016-10-24 15:40:20 +0800152 void initDispatch();
153
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500154 sp<ComposerClient> getClient();
Chia-I Wubb61a722016-10-24 15:40:20 +0800155
156 static void hotplugHook(hwc2_callback_data_t callbackData,
157 hwc2_display_t display, int32_t connected);
158 static void refreshHook(hwc2_callback_data_t callbackData,
159 hwc2_display_t display);
160 static void vsyncHook(hwc2_callback_data_t callbackData,
161 hwc2_display_t display, int64_t timestamp);
162
163 hwc2_device_t* mDevice;
164
165 std::unordered_set<Capability> mCapabilities;
166
167 struct {
168 HWC2_PFN_ACCEPT_DISPLAY_CHANGES acceptDisplayChanges;
169 HWC2_PFN_CREATE_LAYER createLayer;
170 HWC2_PFN_CREATE_VIRTUAL_DISPLAY createVirtualDisplay;
171 HWC2_PFN_DESTROY_LAYER destroyLayer;
172 HWC2_PFN_DESTROY_VIRTUAL_DISPLAY destroyVirtualDisplay;
173 HWC2_PFN_DUMP dump;
174 HWC2_PFN_GET_ACTIVE_CONFIG getActiveConfig;
175 HWC2_PFN_GET_CHANGED_COMPOSITION_TYPES getChangedCompositionTypes;
176 HWC2_PFN_GET_CLIENT_TARGET_SUPPORT getClientTargetSupport;
177 HWC2_PFN_GET_COLOR_MODES getColorModes;
178 HWC2_PFN_GET_DISPLAY_ATTRIBUTE getDisplayAttribute;
179 HWC2_PFN_GET_DISPLAY_CONFIGS getDisplayConfigs;
180 HWC2_PFN_GET_DISPLAY_NAME getDisplayName;
181 HWC2_PFN_GET_DISPLAY_REQUESTS getDisplayRequests;
182 HWC2_PFN_GET_DISPLAY_TYPE getDisplayType;
183 HWC2_PFN_GET_DOZE_SUPPORT getDozeSupport;
184 HWC2_PFN_GET_HDR_CAPABILITIES getHdrCapabilities;
185 HWC2_PFN_GET_MAX_VIRTUAL_DISPLAY_COUNT getMaxVirtualDisplayCount;
186 HWC2_PFN_GET_RELEASE_FENCES getReleaseFences;
187 HWC2_PFN_PRESENT_DISPLAY presentDisplay;
188 HWC2_PFN_REGISTER_CALLBACK registerCallback;
189 HWC2_PFN_SET_ACTIVE_CONFIG setActiveConfig;
190 HWC2_PFN_SET_CLIENT_TARGET setClientTarget;
191 HWC2_PFN_SET_COLOR_MODE setColorMode;
192 HWC2_PFN_SET_COLOR_TRANSFORM setColorTransform;
193 HWC2_PFN_SET_CURSOR_POSITION setCursorPosition;
194 HWC2_PFN_SET_LAYER_BLEND_MODE setLayerBlendMode;
195 HWC2_PFN_SET_LAYER_BUFFER setLayerBuffer;
196 HWC2_PFN_SET_LAYER_COLOR setLayerColor;
197 HWC2_PFN_SET_LAYER_COMPOSITION_TYPE setLayerCompositionType;
198 HWC2_PFN_SET_LAYER_DATASPACE setLayerDataspace;
199 HWC2_PFN_SET_LAYER_DISPLAY_FRAME setLayerDisplayFrame;
200 HWC2_PFN_SET_LAYER_PLANE_ALPHA setLayerPlaneAlpha;
201 HWC2_PFN_SET_LAYER_SIDEBAND_STREAM setLayerSidebandStream;
202 HWC2_PFN_SET_LAYER_SOURCE_CROP setLayerSourceCrop;
203 HWC2_PFN_SET_LAYER_SURFACE_DAMAGE setLayerSurfaceDamage;
204 HWC2_PFN_SET_LAYER_TRANSFORM setLayerTransform;
205 HWC2_PFN_SET_LAYER_VISIBLE_REGION setLayerVisibleRegion;
206 HWC2_PFN_SET_LAYER_Z_ORDER setLayerZOrder;
207 HWC2_PFN_SET_OUTPUT_BUFFER setOutputBuffer;
208 HWC2_PFN_SET_POWER_MODE setPowerMode;
209 HWC2_PFN_SET_VSYNC_ENABLED setVsyncEnabled;
210 HWC2_PFN_VALIDATE_DISPLAY validateDisplay;
211 } mDispatch;
212
213 std::mutex mClientMutex;
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500214 wp<ComposerClient> mClient;
Fabien Sanglard0d55a212017-03-16 16:56:46 -0700215
216 // If the HWC implementation version is < 2.0, use an adapter to interface
217 // between HWC 2.0 <-> HWC 1.X.
218 std::unique_ptr<HWC2On1Adapter> mAdapter;
Chia-I Wubb61a722016-10-24 15:40:20 +0800219};
220
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800221extern "C" IComposer* HIDL_FETCH_IComposer(const char* name);
222
223} // namespace implementation
224} // namespace V2_1
225} // namespace composer
226} // namespace graphics
227} // namespace hardware
228} // namespace android
229
230#endif // ANDROID_HARDWARE_GRAPHICS_COMPOSER_V2_1_HWC_H