blob: 32c6b0b19bee65a9b0c8bee7824fe793b127c567 [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;
Chia-I Wu16e8ed22017-10-19 09:49:03 -070037 class HWC2OnFbAdapter;
Fabien Sanglard0d55a212017-03-16 16:56:46 -070038}
39
40namespace android {
Chia-I Wu7f8d3962016-09-28 21:04:23 +080041namespace hardware {
42namespace graphics {
43namespace composer {
44namespace V2_1 {
45namespace implementation {
46
Chia-I Wubb61a722016-10-24 15:40:20 +080047using android::hardware::graphics::common::V1_0::PixelFormat;
48using android::hardware::graphics::common::V1_0::Transform;
49using android::hardware::graphics::common::V1_0::Dataspace;
50using android::hardware::graphics::common::V1_0::ColorMode;
51using android::hardware::graphics::common::V1_0::ColorTransform;
52using android::hardware::graphics::common::V1_0::Hdr;
53
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050054class ComposerClient;
Chia-I Wubb61a722016-10-24 15:40:20 +080055
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050056class HwcHal : public IComposer, public ComposerBase {
Chia-I Wubb61a722016-10-24 15:40:20 +080057public:
58 HwcHal(const hw_module_t* module);
59 virtual ~HwcHal();
60
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050061 bool hasCapability(Capability capability) const;
62
Chia-I Wubb61a722016-10-24 15:40:20 +080063 // IComposer interface
64 Return<void> getCapabilities(getCapabilities_cb hidl_cb) override;
65 Return<void> dumpDebugInfo(dumpDebugInfo_cb hidl_cb) override;
66 Return<void> createClient(createClient_cb hidl_cb) override;
67
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050068 // ComposerBase interface
69 void removeClient() override;
70 void enableCallback(bool enable) override;
71 uint32_t getMaxVirtualDisplayCount() override;
Chia-I Wubb61a722016-10-24 15:40:20 +080072 Error createVirtualDisplay(uint32_t width, uint32_t height,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050073 PixelFormat* format, Display* outDisplay) override;
74 Error destroyVirtualDisplay(Display display) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080075
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050076 Error createLayer(Display display, Layer* outLayer) override;
77 Error destroyLayer(Display display, Layer layer) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080078
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050079 Error getActiveConfig(Display display, Config* outConfig) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080080 Error getClientTargetSupport(Display display,
81 uint32_t width, uint32_t height,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050082 PixelFormat format, Dataspace dataspace) override;
83 Error getColorModes(Display display,
84 hidl_vec<ColorMode>* outModes) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080085 Error getDisplayAttribute(Display display, Config config,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050086 IComposerClient::Attribute attribute, int32_t* outValue) override;
87 Error getDisplayConfigs(Display display,
88 hidl_vec<Config>* outConfigs) override;
89 Error getDisplayName(Display display, hidl_string* outName) override;
Chia-I Wue1768352016-12-19 12:56:54 +080090 Error getDisplayType(Display display,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050091 IComposerClient::DisplayType* outType) override;
92 Error getDozeSupport(Display display, bool* outSupport) override;
Chia-I Wue1768352016-12-19 12:56:54 +080093 Error getHdrCapabilities(Display display, hidl_vec<Hdr>* outTypes,
94 float* outMaxLuminance, float* outMaxAverageLuminance,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050095 float* outMinLuminance) override;
Chia-I Wubb61a722016-10-24 15:40:20 +080096
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -050097 Error setActiveConfig(Display display, Config config) override;
98 Error setColorMode(Display display, ColorMode mode) override;
99 Error setPowerMode(Display display,
100 IComposerClient::PowerMode mode) override;
101 Error setVsyncEnabled(Display display,
102 IComposerClient::Vsync enabled) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800103
104 Error setColorTransform(Display display, const float* matrix,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500105 int32_t hint) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800106 Error setClientTarget(Display display, buffer_handle_t target,
107 int32_t acquireFence, int32_t dataspace,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500108 const std::vector<hwc_rect_t>& damage) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800109 Error setOutputBuffer(Display display, buffer_handle_t buffer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500110 int32_t releaseFence) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800111 Error validateDisplay(Display display,
Chia-I Wue1768352016-12-19 12:56:54 +0800112 std::vector<Layer>* outChangedLayers,
113 std::vector<IComposerClient::Composition>* outCompositionTypes,
114 uint32_t* outDisplayRequestMask,
115 std::vector<Layer>* outRequestedLayers,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500116 std::vector<uint32_t>* outRequestMasks) override;
117 Error acceptDisplayChanges(Display display) override;
Chia-I Wue1768352016-12-19 12:56:54 +0800118 Error presentDisplay(Display display, int32_t* outPresentFence,
119 std::vector<Layer>* outLayers,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500120 std::vector<int32_t>* outReleaseFences) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800121
122 Error setLayerCursorPosition(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500123 int32_t x, int32_t y) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800124 Error setLayerBuffer(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500125 buffer_handle_t buffer, int32_t acquireFence) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800126 Error setLayerSurfaceDamage(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500127 const std::vector<hwc_rect_t>& damage) override;
128 Error setLayerBlendMode(Display display, Layer layer,
129 int32_t mode) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800130 Error setLayerColor(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500131 IComposerClient::Color color) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800132 Error setLayerCompositionType(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500133 int32_t type) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800134 Error setLayerDataspace(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500135 int32_t dataspace) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800136 Error setLayerDisplayFrame(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500137 const hwc_rect_t& frame) override;
138 Error setLayerPlaneAlpha(Display display, Layer layer,
139 float alpha) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800140 Error setLayerSidebandStream(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500141 buffer_handle_t stream) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800142 Error setLayerSourceCrop(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500143 const hwc_frect_t& crop) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800144 Error setLayerTransform(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500145 int32_t transform) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800146 Error setLayerVisibleRegion(Display display, Layer layer,
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500147 const std::vector<hwc_rect_t>& visible) override;
148 Error setLayerZOrder(Display display, Layer layer, uint32_t z) override;
Chia-I Wubb61a722016-10-24 15:40:20 +0800149
150private:
Chia-I Wu16e8ed22017-10-19 09:49:03 -0700151 uint32_t initWithHwc(const hw_module_t* module);
152 uint32_t initWithFb(const hw_module_t* module);
153
Chia-I Wubb61a722016-10-24 15:40:20 +0800154 void initCapabilities();
155
156 template<typename T>
Chia-I Wue1768352016-12-19 12:56:54 +0800157 void initDispatch(hwc2_function_descriptor_t desc, T* outPfn);
Chia-I Wubb61a722016-10-24 15:40:20 +0800158 void initDispatch();
159
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500160 sp<ComposerClient> getClient();
Chia-I Wubb61a722016-10-24 15:40:20 +0800161
162 static void hotplugHook(hwc2_callback_data_t callbackData,
163 hwc2_display_t display, int32_t connected);
164 static void refreshHook(hwc2_callback_data_t callbackData,
165 hwc2_display_t display);
166 static void vsyncHook(hwc2_callback_data_t callbackData,
167 hwc2_display_t display, int64_t timestamp);
168
169 hwc2_device_t* mDevice;
170
171 std::unordered_set<Capability> mCapabilities;
172
173 struct {
174 HWC2_PFN_ACCEPT_DISPLAY_CHANGES acceptDisplayChanges;
175 HWC2_PFN_CREATE_LAYER createLayer;
176 HWC2_PFN_CREATE_VIRTUAL_DISPLAY createVirtualDisplay;
177 HWC2_PFN_DESTROY_LAYER destroyLayer;
178 HWC2_PFN_DESTROY_VIRTUAL_DISPLAY destroyVirtualDisplay;
179 HWC2_PFN_DUMP dump;
180 HWC2_PFN_GET_ACTIVE_CONFIG getActiveConfig;
181 HWC2_PFN_GET_CHANGED_COMPOSITION_TYPES getChangedCompositionTypes;
182 HWC2_PFN_GET_CLIENT_TARGET_SUPPORT getClientTargetSupport;
183 HWC2_PFN_GET_COLOR_MODES getColorModes;
184 HWC2_PFN_GET_DISPLAY_ATTRIBUTE getDisplayAttribute;
185 HWC2_PFN_GET_DISPLAY_CONFIGS getDisplayConfigs;
186 HWC2_PFN_GET_DISPLAY_NAME getDisplayName;
187 HWC2_PFN_GET_DISPLAY_REQUESTS getDisplayRequests;
188 HWC2_PFN_GET_DISPLAY_TYPE getDisplayType;
189 HWC2_PFN_GET_DOZE_SUPPORT getDozeSupport;
190 HWC2_PFN_GET_HDR_CAPABILITIES getHdrCapabilities;
191 HWC2_PFN_GET_MAX_VIRTUAL_DISPLAY_COUNT getMaxVirtualDisplayCount;
192 HWC2_PFN_GET_RELEASE_FENCES getReleaseFences;
193 HWC2_PFN_PRESENT_DISPLAY presentDisplay;
194 HWC2_PFN_REGISTER_CALLBACK registerCallback;
195 HWC2_PFN_SET_ACTIVE_CONFIG setActiveConfig;
196 HWC2_PFN_SET_CLIENT_TARGET setClientTarget;
197 HWC2_PFN_SET_COLOR_MODE setColorMode;
198 HWC2_PFN_SET_COLOR_TRANSFORM setColorTransform;
199 HWC2_PFN_SET_CURSOR_POSITION setCursorPosition;
200 HWC2_PFN_SET_LAYER_BLEND_MODE setLayerBlendMode;
201 HWC2_PFN_SET_LAYER_BUFFER setLayerBuffer;
202 HWC2_PFN_SET_LAYER_COLOR setLayerColor;
203 HWC2_PFN_SET_LAYER_COMPOSITION_TYPE setLayerCompositionType;
204 HWC2_PFN_SET_LAYER_DATASPACE setLayerDataspace;
205 HWC2_PFN_SET_LAYER_DISPLAY_FRAME setLayerDisplayFrame;
206 HWC2_PFN_SET_LAYER_PLANE_ALPHA setLayerPlaneAlpha;
207 HWC2_PFN_SET_LAYER_SIDEBAND_STREAM setLayerSidebandStream;
208 HWC2_PFN_SET_LAYER_SOURCE_CROP setLayerSourceCrop;
209 HWC2_PFN_SET_LAYER_SURFACE_DAMAGE setLayerSurfaceDamage;
210 HWC2_PFN_SET_LAYER_TRANSFORM setLayerTransform;
211 HWC2_PFN_SET_LAYER_VISIBLE_REGION setLayerVisibleRegion;
212 HWC2_PFN_SET_LAYER_Z_ORDER setLayerZOrder;
213 HWC2_PFN_SET_OUTPUT_BUFFER setOutputBuffer;
214 HWC2_PFN_SET_POWER_MODE setPowerMode;
215 HWC2_PFN_SET_VSYNC_ENABLED setVsyncEnabled;
216 HWC2_PFN_VALIDATE_DISPLAY validateDisplay;
217 } mDispatch;
218
219 std::mutex mClientMutex;
Steven Thomasbc67a6a2017-07-07 12:34:20 -0700220 std::condition_variable mClientDestroyedWait;
Daniel Nicoara0a60e4b2017-01-09 12:51:06 -0500221 wp<ComposerClient> mClient;
Fabien Sanglard0d55a212017-03-16 16:56:46 -0700222
Chia-I Wu8101b242017-10-06 12:29:14 -0700223 std::atomic<bool> mMustValidateDisplay;
224
Fabien Sanglard0d55a212017-03-16 16:56:46 -0700225 // If the HWC implementation version is < 2.0, use an adapter to interface
226 // between HWC 2.0 <-> HWC 1.X.
227 std::unique_ptr<HWC2On1Adapter> mAdapter;
Chia-I Wu16e8ed22017-10-19 09:49:03 -0700228
229 // If there is no HWC implementation, use an adapter to interface between
230 // HWC 2.0 <-> FB HAL.
231 std::unique_ptr<HWC2OnFbAdapter> mFbAdapter;
Chia-I Wubb61a722016-10-24 15:40:20 +0800232};
233
Chia-I Wu7f8d3962016-09-28 21:04:23 +0800234extern "C" IComposer* HIDL_FETCH_IComposer(const char* name);
235
236} // namespace implementation
237} // namespace V2_1
238} // namespace composer
239} // namespace graphics
240} // namespace hardware
241} // namespace android
242
243#endif // ANDROID_HARDWARE_GRAPHICS_COMPOSER_V2_1_HWC_H