blob: 104ca608e6697dd54e7c6ab5669c8ad819396b10 [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
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -040026#include <android/frameworks/vr/composer/1.0/IVrComposerClient.h>
Chia-I Wuaab99f52016-10-05 12:59:58 +080027#include <android/hardware/graphics/composer/2.1/IComposer.h>
28#include <utils/StrongPointer.h>
Chia-I Wucd8d7f02016-11-16 11:02:31 +080029#include <IComposerCommandBuffer.h>
Chia-I Wuaab99f52016-10-05 12:59:58 +080030
31namespace android {
32
33namespace Hwc2 {
34
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -040035using android::frameworks::vr::composer::V1_0::IVrComposerClient;
36
Chia-I Wu5901fda2016-11-17 10:26:37 +080037using android::hardware::graphics::common::V1_0::ColorMode;
38using android::hardware::graphics::common::V1_0::ColorTransform;
39using android::hardware::graphics::common::V1_0::Dataspace;
40using android::hardware::graphics::common::V1_0::Hdr;
41using android::hardware::graphics::common::V1_0::PixelFormat;
42using android::hardware::graphics::common::V1_0::Transform;
Chia-I Wuaab99f52016-10-05 12:59:58 +080043
44using android::hardware::graphics::composer::V2_1::IComposer;
45using android::hardware::graphics::composer::V2_1::IComposerCallback;
Chia-I Wucd8d7f02016-11-16 11:02:31 +080046using android::hardware::graphics::composer::V2_1::IComposerClient;
Chia-I Wuaab99f52016-10-05 12:59:58 +080047using android::hardware::graphics::composer::V2_1::Error;
48using android::hardware::graphics::composer::V2_1::Display;
49using android::hardware::graphics::composer::V2_1::Layer;
50using android::hardware::graphics::composer::V2_1::Config;
51
Daniel Nicoara3c9cbd42017-01-17 12:04:06 -050052using android::hardware::graphics::composer::V2_1::CommandWriterBase;
Chia-I Wucd8d7f02016-11-16 11:02:31 +080053using android::hardware::graphics::composer::V2_1::CommandReaderBase;
54
55using android::hardware::kSynchronizedReadWrite;
56using android::hardware::MessageQueue;
57using android::hardware::MQDescriptorSync;
58using android::hardware::hidl_vec;
59using android::hardware::hidl_handle;
60
61class CommandReader : public CommandReaderBase {
62public:
63 ~CommandReader();
64
65 // Parse and execute commands from the command queue. The commands are
66 // actually return values from the server and will be saved in ReturnData.
67 Error parse();
68
69 // Get and clear saved errors.
70 struct CommandError {
71 uint32_t location;
72 Error error;
73 };
74 std::vector<CommandError> takeErrors();
75
Chia-I Wu67e376d2016-12-19 11:36:22 +080076 bool hasChanges(Display display, uint32_t* outNumChangedCompositionTypes,
77 uint32_t* outNumLayerRequestMasks) const;
Chia-I Wucd8d7f02016-11-16 11:02:31 +080078
79 // Get and clear saved changed composition types.
80 void takeChangedCompositionTypes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +080081 std::vector<Layer>* outLayers,
82 std::vector<IComposerClient::Composition>* outTypes);
Chia-I Wucd8d7f02016-11-16 11:02:31 +080083
84 // Get and clear saved display requests.
85 void takeDisplayRequests(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +080086 uint32_t* outDisplayRequestMask, std::vector<Layer>* outLayers,
87 std::vector<uint32_t>* outLayerRequestMasks);
Chia-I Wucd8d7f02016-11-16 11:02:31 +080088
89 // Get and clear saved release fences.
Chia-I Wu67e376d2016-12-19 11:36:22 +080090 void takeReleaseFences(Display display, std::vector<Layer>* outLayers,
91 std::vector<int>* outReleaseFences);
Chia-I Wucd8d7f02016-11-16 11:02:31 +080092
93 // Get and clear saved present fence.
Chia-I Wu67e376d2016-12-19 11:36:22 +080094 void takePresentFence(Display display, int* outPresentFence);
Chia-I Wucd8d7f02016-11-16 11:02:31 +080095
Fabien Sanglard249c0ae2017-06-19 19:22:36 -070096 // Get what stage succeeded during PresentOrValidate: Present or Validate
97 void takePresentOrValidateStage(Display display, uint32_t * state);
98
Chia-I Wucd8d7f02016-11-16 11:02:31 +080099private:
100 void resetData();
101
102 bool parseSelectDisplay(uint16_t length);
103 bool parseSetError(uint16_t length);
104 bool parseSetChangedCompositionTypes(uint16_t length);
105 bool parseSetDisplayRequests(uint16_t length);
106 bool parseSetPresentFence(uint16_t length);
107 bool parseSetReleaseFences(uint16_t length);
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700108 bool parseSetPresentOrValidateDisplayResult(uint16_t length);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800109
110 struct ReturnData {
111 uint32_t displayRequests = 0;
112
113 std::vector<Layer> changedLayers;
114 std::vector<IComposerClient::Composition> compositionTypes;
115
116 std::vector<Layer> requestedLayers;
117 std::vector<uint32_t> requestMasks;
118
119 int presentFence = -1;
120
121 std::vector<Layer> releasedLayers;
122 std::vector<int> releaseFences;
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700123
124 uint32_t presentOrValidateState;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800125 };
126
127 std::vector<CommandError> mErrors;
128 std::unordered_map<Display, ReturnData> mReturnData;
129
130 // When SELECT_DISPLAY is parsed, this is updated to point to the
131 // display's return data in mReturnData. We use it to avoid repeated
132 // map lookups.
133 ReturnData* mCurrentReturnData;
134};
135
Chia-I Wuaab99f52016-10-05 12:59:58 +0800136// Composer is a wrapper to IComposer, a proxy to server-side composer.
137class Composer {
138public:
Kalle Raitaa099a242017-01-11 11:17:29 -0800139 Composer(const std::string& serviceName);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800140
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800141 std::vector<IComposer::Capability> getCapabilities();
142 std::string dumpDebugInfo();
Chia-I Wuaab99f52016-10-05 12:59:58 +0800143
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800144 void registerCallback(const sp<IComposerCallback>& callback);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800145
Steven Thomas94e35b92017-07-26 18:48:28 -0700146 // Returns true if the connected composer service is running in a remote
147 // process, false otherwise. This will return false if the service is
148 // configured in passthrough mode, for example.
149 bool isRemote();
150
Steven Thomas0af4b9f2017-04-26 14:34:01 -0700151 // Reset all pending commands in the command buffer. Useful if you want to
152 // skip a frame but have already queued some commands.
153 void resetCommands();
154
Chia-I Wuae5a6b82017-10-10 09:09:22 -0700155 // Explicitly flush all pending commands in the command buffer.
156 Error executeCommands();
157
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800158 uint32_t getMaxVirtualDisplayCount();
Hendrik Wagenaar87670ff2017-02-01 12:10:46 -0800159 bool isUsingVrComposer() const { return mIsUsingVrComposer; }
Chia-I Wuaab99f52016-10-05 12:59:58 +0800160 Error createVirtualDisplay(uint32_t width, uint32_t height,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800161 PixelFormat* format, Display* outDisplay);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800162 Error destroyVirtualDisplay(Display display);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800163
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800164 Error acceptDisplayChanges(Display display);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800165
Chia-I Wu67e376d2016-12-19 11:36:22 +0800166 Error createLayer(Display display, Layer* outLayer);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800167 Error destroyLayer(Display display, Layer layer);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800168
Chia-I Wu67e376d2016-12-19 11:36:22 +0800169 Error getActiveConfig(Display display, Config* outConfig);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800170 Error getChangedCompositionTypes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800171 std::vector<Layer>* outLayers,
172 std::vector<IComposerClient::Composition>* outTypes);
173 Error getColorModes(Display display, std::vector<ColorMode>* outModes);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800174 Error getDisplayAttribute(Display display, Config config,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800175 IComposerClient::Attribute attribute, int32_t* outValue);
176 Error getDisplayConfigs(Display display, std::vector<Config>* outConfigs);
177 Error getDisplayName(Display display, std::string* outName);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800178
Chia-I Wu67e376d2016-12-19 11:36:22 +0800179 Error getDisplayRequests(Display display, uint32_t* outDisplayRequestMask,
180 std::vector<Layer>* outLayers,
181 std::vector<uint32_t>* outLayerRequestMasks);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800182
Chia-I Wu67e376d2016-12-19 11:36:22 +0800183 Error getDisplayType(Display display,
184 IComposerClient::DisplayType* outType);
185 Error getDozeSupport(Display display, bool* outSupport);
186 Error getHdrCapabilities(Display display, std::vector<Hdr>* outTypes,
187 float* outMaxLuminance, float* outMaxAverageLuminance,
188 float* outMinLuminance);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800189
Chia-I Wu67e376d2016-12-19 11:36:22 +0800190 Error getReleaseFences(Display display, std::vector<Layer>* outLayers,
191 std::vector<int>* outReleaseFences);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800192
Chia-I Wu67e376d2016-12-19 11:36:22 +0800193 Error presentDisplay(Display display, int* outPresentFence);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800194
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800195 Error setActiveConfig(Display display, Config config);
Chia-I Wu06d63de2017-01-04 14:58:51 +0800196
197 /*
198 * The composer caches client targets internally. When target is nullptr,
199 * the composer uses slot to look up the client target from its cache.
200 * When target is not nullptr, the cache is updated with the new target.
201 */
202 Error setClientTarget(Display display, uint32_t slot,
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -0400203 const sp<GraphicBuffer>& target,
Chia-I Wuaab99f52016-10-05 12:59:58 +0800204 int acquireFence, Dataspace dataspace,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800205 const std::vector<IComposerClient::Rect>& damage);
206 Error setColorMode(Display display, ColorMode mode);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800207 Error setColorTransform(Display display, const float* matrix,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800208 ColorTransform hint);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800209 Error setOutputBuffer(Display display, const native_handle_t* buffer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800210 int releaseFence);
211 Error setPowerMode(Display display, IComposerClient::PowerMode mode);
212 Error setVsyncEnabled(Display display, IComposerClient::Vsync enabled);
213
214 Error setClientTargetSlotCount(Display display);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800215
Chia-I Wu67e376d2016-12-19 11:36:22 +0800216 Error validateDisplay(Display display, uint32_t* outNumTypes,
217 uint32_t* outNumRequests);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800218
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700219 Error presentOrValidateDisplay(Display display, uint32_t* outNumTypes,
220 uint32_t* outNumRequests,
221 int* outPresentFence,
222 uint32_t* state);
223
Chia-I Wuaab99f52016-10-05 12:59:58 +0800224 Error setCursorPosition(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800225 int32_t x, int32_t y);
Chia-I Wu06d63de2017-01-04 14:58:51 +0800226 /* see setClientTarget for the purpose of slot */
227 Error setLayerBuffer(Display display, Layer layer, uint32_t slot,
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -0400228 const sp<GraphicBuffer>& buffer, int acquireFence);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800229 Error setLayerSurfaceDamage(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800230 const std::vector<IComposerClient::Rect>& damage);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800231 Error setLayerBlendMode(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800232 IComposerClient::BlendMode mode);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800233 Error setLayerColor(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800234 const IComposerClient::Color& color);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800235 Error setLayerCompositionType(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800236 IComposerClient::Composition type);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800237 Error setLayerDataspace(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800238 Dataspace dataspace);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800239 Error setLayerDisplayFrame(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800240 const IComposerClient::Rect& frame);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800241 Error setLayerPlaneAlpha(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800242 float alpha);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800243 Error setLayerSidebandStream(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800244 const native_handle_t* stream);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800245 Error setLayerSourceCrop(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800246 const IComposerClient::FRect& crop);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800247 Error setLayerTransform(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800248 Transform transform);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800249 Error setLayerVisibleRegion(Display display, Layer layer,
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800250 const std::vector<IComposerClient::Rect>& visible);
251 Error setLayerZOrder(Display display, Layer layer, uint32_t z);
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500252 Error setLayerInfo(Display display, Layer layer, uint32_t type,
253 uint32_t appId);
Chia-I Wuaab99f52016-10-05 12:59:58 +0800254private:
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500255 class CommandWriter : public CommandWriterBase {
256 public:
257 CommandWriter(uint32_t initialMaxSize);
258 ~CommandWriter() override;
259
260 void setLayerInfo(uint32_t type, uint32_t appId);
Daniel Nicoara1f42e3a2017-04-10 13:27:32 -0400261 void setClientTargetMetadata(
262 const IVrComposerClient::BufferMetadata& metadata);
263 void setLayerBufferMetadata(
264 const IVrComposerClient::BufferMetadata& metadata);
265
266 private:
267 void writeBufferMetadata(
268 const IVrComposerClient::BufferMetadata& metadata);
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500269 };
270
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800271 // Many public functions above simply write a command into the command
272 // queue to batch the calls. validateDisplay and presentDisplay will call
273 // this function to execute the command queue.
274 Error execute();
275
276 sp<IComposer> mComposer;
277 sp<IComposerClient> mClient;
278
279 // 64KiB minus a small space for metadata such as read/write pointers
280 static constexpr size_t kWriterInitialSize =
281 64 * 1024 / sizeof(uint32_t) - 16;
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500282 CommandWriter mWriter;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800283 CommandReader mReader;
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500284
Hendrik Wagenaar87670ff2017-02-01 12:10:46 -0800285 // When true, the we attach to the vr_hwcomposer service instead of the
286 // hwcomposer. This allows us to redirect surfaces to 3d surfaces in vr.
287 const bool mIsUsingVrComposer;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800288};
289
290} // namespace Hwc2
291
292} // namespace android
293
294#endif // ANDROID_SF_COMPOSER_HAL_H