blob: 1ede705bf64e453775d81f53b4eaa6217c69c397 [file] [log] [blame]
Chia-I Wuaab99f52016-10-05 12:59:58 +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_SF_COMPOSER_HAL_H
18#define ANDROID_SF_COMPOSER_HAL_H
19
Chia-I Wucd8d7f02016-11-16 11:02:31 +080020#include <memory>
Chia-I Wuaab99f52016-10-05 12:59:58 +080021#include <string>
Chia-I Wucd8d7f02016-11-16 11:02:31 +080022#include <unordered_map>
23#include <utility>
Chia-I Wuaab99f52016-10-05 12:59:58 +080024#include <vector>
25
26#include <android/hardware/graphics/composer/2.1/IComposer.h>
27#include <utils/StrongPointer.h>
Chia-I Wucd8d7f02016-11-16 11:02:31 +080028#include <IComposerCommandBuffer.h>
29#include <MessageQueue.h>
Chia-I Wuaab99f52016-10-05 12:59:58 +080030
31namespace android {
32
33namespace Hwc2 {
34
Chia-I Wu5901fda2016-11-17 10:26:37 +080035using android::hardware::graphics::common::V1_0::ColorMode;
36using android::hardware::graphics::common::V1_0::ColorTransform;
37using android::hardware::graphics::common::V1_0::Dataspace;
38using android::hardware::graphics::common::V1_0::Hdr;
39using android::hardware::graphics::common::V1_0::PixelFormat;
40using android::hardware::graphics::common::V1_0::Transform;
Chia-I Wuaab99f52016-10-05 12:59:58 +080041
42using android::hardware::graphics::composer::V2_1::IComposer;
43using android::hardware::graphics::composer::V2_1::IComposerCallback;
Chia-I Wucd8d7f02016-11-16 11:02:31 +080044using android::hardware::graphics::composer::V2_1::IComposerClient;
Chia-I Wuaab99f52016-10-05 12:59:58 +080045using android::hardware::graphics::composer::V2_1::Error;
46using android::hardware::graphics::composer::V2_1::Display;
47using android::hardware::graphics::composer::V2_1::Layer;
48using android::hardware::graphics::composer::V2_1::Config;
49
Daniel Nicoara3c9cbd42017-01-17 12:04:06 -050050using android::hardware::graphics::composer::V2_1::CommandWriterBase;
Chia-I Wucd8d7f02016-11-16 11:02:31 +080051using android::hardware::graphics::composer::V2_1::CommandReaderBase;
52
53using android::hardware::kSynchronizedReadWrite;
54using android::hardware::MessageQueue;
55using android::hardware::MQDescriptorSync;
56using android::hardware::hidl_vec;
57using android::hardware::hidl_handle;
58
59class CommandReader : public CommandReaderBase {
60public:
61 ~CommandReader();
62
63 // Parse and execute commands from the command queue. The commands are
64 // actually return values from the server and will be saved in ReturnData.
65 Error parse();
66
67 // Get and clear saved errors.
68 struct CommandError {
69 uint32_t location;
70 Error error;
71 };
72 std::vector<CommandError> takeErrors();
73
Chia-I Wu67e376d2016-12-19 11:36:22 +080074 bool hasChanges(Display display, uint32_t* outNumChangedCompositionTypes,
75 uint32_t* outNumLayerRequestMasks) const;
Chia-I Wucd8d7f02016-11-16 11:02:31 +080076
77 // Get and clear saved changed composition types.
78 void takeChangedCompositionTypes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +080079 std::vector<Layer>* outLayers,
80 std::vector<IComposerClient::Composition>* outTypes);
Chia-I Wucd8d7f02016-11-16 11:02:31 +080081
82 // Get and clear saved display requests.
83 void takeDisplayRequests(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +080084 uint32_t* outDisplayRequestMask, std::vector<Layer>* outLayers,
85 std::vector<uint32_t>* outLayerRequestMasks);
Chia-I Wucd8d7f02016-11-16 11:02:31 +080086
87 // Get and clear saved release fences.
Chia-I Wu67e376d2016-12-19 11:36:22 +080088 void takeReleaseFences(Display display, std::vector<Layer>* outLayers,
89 std::vector<int>* outReleaseFences);
Chia-I Wucd8d7f02016-11-16 11:02:31 +080090
91 // Get and clear saved present fence.
Chia-I Wu67e376d2016-12-19 11:36:22 +080092 void takePresentFence(Display display, int* outPresentFence);
Chia-I Wucd8d7f02016-11-16 11:02:31 +080093
94private:
95 void resetData();
96
97 bool parseSelectDisplay(uint16_t length);
98 bool parseSetError(uint16_t length);
99 bool parseSetChangedCompositionTypes(uint16_t length);
100 bool parseSetDisplayRequests(uint16_t length);
101 bool parseSetPresentFence(uint16_t length);
102 bool parseSetReleaseFences(uint16_t length);
103
104 struct ReturnData {
105 uint32_t displayRequests = 0;
106
107 std::vector<Layer> changedLayers;
108 std::vector<IComposerClient::Composition> compositionTypes;
109
110 std::vector<Layer> requestedLayers;
111 std::vector<uint32_t> requestMasks;
112
113 int presentFence = -1;
114
115 std::vector<Layer> releasedLayers;
116 std::vector<int> releaseFences;
117 };
118
119 std::vector<CommandError> mErrors;
120 std::unordered_map<Display, ReturnData> mReturnData;
121
122 // When SELECT_DISPLAY is parsed, this is updated to point to the
123 // display's return data in mReturnData. We use it to avoid repeated
124 // map lookups.
125 ReturnData* mCurrentReturnData;
126};
127
Chia-I Wuaab99f52016-10-05 12:59:58 +0800128// Composer is a wrapper to IComposer, a proxy to server-side composer.
129class Composer {
130public:
131 Composer();
132
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800133 std::vector<IComposer::Capability> getCapabilities();
134 std::string dumpDebugInfo();
Chia-I Wuaab99f52016-10-05 12:59:58 +0800135
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800136 void registerCallback(const sp<IComposerCallback>& callback);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800137
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800138 uint32_t getMaxVirtualDisplayCount();
Chia-I Wuaab99f52016-10-05 12:59:58 +0800139 Error createVirtualDisplay(uint32_t width, uint32_t height,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800140 PixelFormat* format, Display* outDisplay);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800141 Error destroyVirtualDisplay(Display display);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800142
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800143 Error acceptDisplayChanges(Display display);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800144
Chia-I Wu67e376d2016-12-19 11:36:22 +0800145 Error createLayer(Display display, Layer* outLayer);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800146 Error destroyLayer(Display display, Layer layer);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800147
Chia-I Wu67e376d2016-12-19 11:36:22 +0800148 Error getActiveConfig(Display display, Config* outConfig);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800149 Error getChangedCompositionTypes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800150 std::vector<Layer>* outLayers,
151 std::vector<IComposerClient::Composition>* outTypes);
152 Error getColorModes(Display display, std::vector<ColorMode>* outModes);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800153 Error getDisplayAttribute(Display display, Config config,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800154 IComposerClient::Attribute attribute, int32_t* outValue);
155 Error getDisplayConfigs(Display display, std::vector<Config>* outConfigs);
156 Error getDisplayName(Display display, std::string* outName);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800157
Chia-I Wu67e376d2016-12-19 11:36:22 +0800158 Error getDisplayRequests(Display display, uint32_t* outDisplayRequestMask,
159 std::vector<Layer>* outLayers,
160 std::vector<uint32_t>* outLayerRequestMasks);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800161
Chia-I Wu67e376d2016-12-19 11:36:22 +0800162 Error getDisplayType(Display display,
163 IComposerClient::DisplayType* outType);
164 Error getDozeSupport(Display display, bool* outSupport);
165 Error getHdrCapabilities(Display display, std::vector<Hdr>* outTypes,
166 float* outMaxLuminance, float* outMaxAverageLuminance,
167 float* outMinLuminance);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800168
Chia-I Wu67e376d2016-12-19 11:36:22 +0800169 Error getReleaseFences(Display display, std::vector<Layer>* outLayers,
170 std::vector<int>* outReleaseFences);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800171
Chia-I Wu67e376d2016-12-19 11:36:22 +0800172 Error presentDisplay(Display display, int* outPresentFence);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800173
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800174 Error setActiveConfig(Display display, Config config);
Chia-I Wu06d63de2017-01-04 14:58:51 +0800175
176 /*
177 * The composer caches client targets internally. When target is nullptr,
178 * the composer uses slot to look up the client target from its cache.
179 * When target is not nullptr, the cache is updated with the new target.
180 */
181 Error setClientTarget(Display display, uint32_t slot,
182 const native_handle_t* target,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800183 int acquireFence, Dataspace dataspace,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800184 const std::vector<IComposerClient::Rect>& damage);
185 Error setColorMode(Display display, ColorMode mode);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800186 Error setColorTransform(Display display, const float* matrix,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800187 ColorTransform hint);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800188 Error setOutputBuffer(Display display, const native_handle_t* buffer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800189 int releaseFence);
190 Error setPowerMode(Display display, IComposerClient::PowerMode mode);
191 Error setVsyncEnabled(Display display, IComposerClient::Vsync enabled);
192
193 Error setClientTargetSlotCount(Display display);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800194
Chia-I Wu67e376d2016-12-19 11:36:22 +0800195 Error validateDisplay(Display display, uint32_t* outNumTypes,
196 uint32_t* outNumRequests);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800197
198 Error setCursorPosition(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800199 int32_t x, int32_t y);
Chia-I Wu06d63de2017-01-04 14:58:51 +0800200 /* see setClientTarget for the purpose of slot */
201 Error setLayerBuffer(Display display, Layer layer, uint32_t slot,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800202 const native_handle_t* buffer, int acquireFence);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800203 Error setLayerSurfaceDamage(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800204 const std::vector<IComposerClient::Rect>& damage);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800205 Error setLayerBlendMode(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800206 IComposerClient::BlendMode mode);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800207 Error setLayerColor(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800208 const IComposerClient::Color& color);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800209 Error setLayerCompositionType(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800210 IComposerClient::Composition type);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800211 Error setLayerDataspace(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800212 Dataspace dataspace);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800213 Error setLayerDisplayFrame(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800214 const IComposerClient::Rect& frame);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800215 Error setLayerPlaneAlpha(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800216 float alpha);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800217 Error setLayerSidebandStream(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800218 const native_handle_t* stream);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800219 Error setLayerSourceCrop(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800220 const IComposerClient::FRect& crop);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800221 Error setLayerTransform(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800222 Transform transform);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800223 Error setLayerVisibleRegion(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800224 const std::vector<IComposerClient::Rect>& visible);
225 Error setLayerZOrder(Display display, Layer layer, uint32_t z);
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500226 Error setLayerInfo(Display display, Layer layer, uint32_t type,
227 uint32_t appId);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800228private:
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500229 class CommandWriter : public CommandWriterBase {
230 public:
231 CommandWriter(uint32_t initialMaxSize);
232 ~CommandWriter() override;
233
234 void setLayerInfo(uint32_t type, uint32_t appId);
235 };
236
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800237 // Many public functions above simply write a command into the command
238 // queue to batch the calls. validateDisplay and presentDisplay will call
239 // this function to execute the command queue.
240 Error execute();
241
242 sp<IComposer> mComposer;
243 sp<IComposerClient> mClient;
244
245 // 64KiB minus a small space for metadata such as read/write pointers
246 static constexpr size_t kWriterInitialSize =
247 64 * 1024 / sizeof(uint32_t) - 16;
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500248 CommandWriter mWriter;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800249 CommandReader mReader;
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500250
251 bool mIsInVrMode = false;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800252};
253
254} // namespace Hwc2
255
256} // namespace android
257
258#endif // ANDROID_SF_COMPOSER_HAL_H