blob: 0619b8c444595e830f0b678d2e19a348928619b1 [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
Ady Abraham8a82ba62020-01-17 12:43:17 -080026// TODO(b/129481165): remove the #pragma below and fix conversion issues
27#pragma clang diagnostic push
28#pragma clang diagnostic ignored "-Wconversion"
Marin Shalamanovbed7fd32020-12-21 20:02:20 +010029#pragma clang diagnostic ignored "-Wextra"
Ady Abraham8a82ba62020-01-17 12:43:17 -080030
Peiyong Lin34beb7a2018-03-28 11:57:12 -070031#include <android/hardware/graphics/common/1.1/types.h>
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -070032#include <android/hardware/graphics/composer/2.4/IComposer.h>
33#include <android/hardware/graphics/composer/2.4/IComposerClient.h>
Peiyong Linafa0f572020-01-13 16:35:02 -080034#include <composer-command-buffer/2.4/ComposerCommandBuffer.h>
Alec Mourie7cc1c22021-04-27 15:23:26 -070035#include <gui/BufferQueue.h>
Courtney Goeltzenleuchterf9c98e52018-02-12 07:23:17 -070036#include <gui/HdrMetadata.h>
Peiyong Lin0e7a7912018-04-05 14:36:36 -070037#include <math/mat4.h>
Kevin DuBois1d4249a2018-08-29 10:45:14 -070038#include <ui/DisplayedFrameStats.h>
Lloyd Piqued0094aa2017-12-20 16:43:28 -080039#include <ui/GraphicBuffer.h>
Chia-I Wuaab99f52016-10-05 12:59:58 +080040#include <utils/StrongPointer.h>
41
Ady Abraham8a82ba62020-01-17 12:43:17 -080042// TODO(b/129481165): remove the #pragma below and fix conversion issues
Marin Shalamanovbed7fd32020-12-21 20:02:20 +010043#pragma clang diagnostic pop // ignored "-Wconversion -Wextra"
Ady Abraham8a82ba62020-01-17 12:43:17 -080044
Chia-I Wuaab99f52016-10-05 12:59:58 +080045namespace android {
46
47namespace Hwc2 {
48
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070049namespace types = hardware::graphics::common;
Chia-I Wuaab99f52016-10-05 12:59:58 +080050
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070051namespace V2_1 = hardware::graphics::composer::V2_1;
52namespace V2_2 = hardware::graphics::composer::V2_2;
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -070053namespace V2_3 = hardware::graphics::composer::V2_3;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -070054namespace V2_4 = hardware::graphics::composer::V2_4;
Chia-I Wuaab99f52016-10-05 12:59:58 +080055
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070056using types::V1_0::ColorTransform;
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070057using types::V1_0::Transform;
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070058using types::V1_1::RenderIntent;
Valerie Hau9758ae02018-10-09 16:05:09 -070059using types::V1_2::ColorMode;
60using types::V1_2::Dataspace;
Valerie Haue9e843a2018-12-18 13:39:23 -080061using types::V1_2::Hdr;
Kevin DuBois73d0f482019-01-25 11:18:03 -080062using types::V1_2::PixelFormat;
Valerie Haue9e843a2018-12-18 13:39:23 -080063
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070064using V2_1::Config;
65using V2_1::Display;
66using V2_1::Error;
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070067using V2_1::Layer;
Peiyong Linafa0f572020-01-13 16:35:02 -080068using V2_4::CommandReaderBase;
69using V2_4::CommandWriterBase;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -070070using V2_4::IComposer;
Ady Abraham7159f572019-10-11 11:10:18 -070071using V2_4::IComposerCallback;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -070072using V2_4::IComposerClient;
Ady Abraham7159f572019-10-11 11:10:18 -070073using V2_4::VsyncPeriodChangeTimeline;
74using V2_4::VsyncPeriodNanos;
Peiyong Lined531a32018-10-26 18:27:56 -070075using DisplayCapability = IComposerClient::DisplayCapability;
Peiyong Lin0ac5f4e2018-04-19 22:06:34 -070076using PerFrameMetadata = IComposerClient::PerFrameMetadata;
77using PerFrameMetadataKey = IComposerClient::PerFrameMetadataKey;
Valerie Haue9e843a2018-12-18 13:39:23 -080078using PerFrameMetadataBlob = IComposerClient::PerFrameMetadataBlob;
Peiyong Lin0ac5f4e2018-04-19 22:06:34 -070079
Lloyd Piquea822d522017-12-20 16:42:57 -080080class Composer {
81public:
82 virtual ~Composer() = 0;
83
84 virtual std::vector<IComposer::Capability> getCapabilities() = 0;
85 virtual std::string dumpDebugInfo() = 0;
86
87 virtual void registerCallback(const sp<IComposerCallback>& callback) = 0;
88
Lloyd Piquea822d522017-12-20 16:42:57 -080089 // Reset all pending commands in the command buffer. Useful if you want to
90 // skip a frame but have already queued some commands.
91 virtual void resetCommands() = 0;
92
93 // Explicitly flush all pending commands in the command buffer.
94 virtual Error executeCommands() = 0;
95
96 virtual uint32_t getMaxVirtualDisplayCount() = 0;
Lloyd Piquea822d522017-12-20 16:42:57 -080097 virtual Error createVirtualDisplay(uint32_t width, uint32_t height, PixelFormat* format,
98 Display* outDisplay) = 0;
99 virtual Error destroyVirtualDisplay(Display display) = 0;
100
101 virtual Error acceptDisplayChanges(Display display) = 0;
102
103 virtual Error createLayer(Display display, Layer* outLayer) = 0;
104 virtual Error destroyLayer(Display display, Layer layer) = 0;
105
106 virtual Error getActiveConfig(Display display, Config* outConfig) = 0;
107 virtual Error getChangedCompositionTypes(
108 Display display, std::vector<Layer>* outLayers,
109 std::vector<IComposerClient::Composition>* outTypes) = 0;
110 virtual Error getColorModes(Display display, std::vector<ColorMode>* outModes) = 0;
111 virtual Error getDisplayAttribute(Display display, Config config,
112 IComposerClient::Attribute attribute, int32_t* outValue) = 0;
113 virtual Error getDisplayConfigs(Display display, std::vector<Config>* outConfigs) = 0;
114 virtual Error getDisplayName(Display display, std::string* outName) = 0;
115
116 virtual Error getDisplayRequests(Display display, uint32_t* outDisplayRequestMask,
117 std::vector<Layer>* outLayers,
118 std::vector<uint32_t>* outLayerRequestMasks) = 0;
119
Lloyd Piquea822d522017-12-20 16:42:57 -0800120 virtual Error getDozeSupport(Display display, bool* outSupport) = 0;
121 virtual Error getHdrCapabilities(Display display, std::vector<Hdr>* outTypes,
122 float* outMaxLuminance, float* outMaxAverageLuminance,
123 float* outMinLuminance) = 0;
124
125 virtual Error getReleaseFences(Display display, std::vector<Layer>* outLayers,
126 std::vector<int>* outReleaseFences) = 0;
127
128 virtual Error presentDisplay(Display display, int* outPresentFence) = 0;
129
130 virtual Error setActiveConfig(Display display, Config config) = 0;
131
132 /*
133 * The composer caches client targets internally. When target is nullptr,
134 * the composer uses slot to look up the client target from its cache.
135 * When target is not nullptr, the cache is updated with the new target.
136 */
137 virtual Error setClientTarget(Display display, uint32_t slot, const sp<GraphicBuffer>& target,
138 int acquireFence, Dataspace dataspace,
139 const std::vector<IComposerClient::Rect>& damage) = 0;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700140 virtual Error setColorMode(Display display, ColorMode mode, RenderIntent renderIntent) = 0;
Lloyd Piquea822d522017-12-20 16:42:57 -0800141 virtual Error setColorTransform(Display display, const float* matrix, ColorTransform hint) = 0;
142 virtual Error setOutputBuffer(Display display, const native_handle_t* buffer,
143 int releaseFence) = 0;
144 virtual Error setPowerMode(Display display, IComposerClient::PowerMode mode) = 0;
145 virtual Error setVsyncEnabled(Display display, IComposerClient::Vsync enabled) = 0;
146
147 virtual Error setClientTargetSlotCount(Display display) = 0;
148
149 virtual Error validateDisplay(Display display, uint32_t* outNumTypes,
150 uint32_t* outNumRequests) = 0;
151
152 virtual Error presentOrValidateDisplay(Display display, uint32_t* outNumTypes,
153 uint32_t* outNumRequests, int* outPresentFence,
154 uint32_t* state) = 0;
155
156 virtual Error setCursorPosition(Display display, Layer layer, int32_t x, int32_t y) = 0;
157 /* see setClientTarget for the purpose of slot */
158 virtual Error setLayerBuffer(Display display, Layer layer, uint32_t slot,
159 const sp<GraphicBuffer>& buffer, int acquireFence) = 0;
160 virtual Error setLayerSurfaceDamage(Display display, Layer layer,
161 const std::vector<IComposerClient::Rect>& damage) = 0;
162 virtual Error setLayerBlendMode(Display display, Layer layer,
163 IComposerClient::BlendMode mode) = 0;
164 virtual Error setLayerColor(Display display, Layer layer,
165 const IComposerClient::Color& color) = 0;
166 virtual Error setLayerCompositionType(Display display, Layer layer,
167 IComposerClient::Composition type) = 0;
168 virtual Error setLayerDataspace(Display display, Layer layer, Dataspace dataspace) = 0;
169 virtual Error setLayerDisplayFrame(Display display, Layer layer,
170 const IComposerClient::Rect& frame) = 0;
171 virtual Error setLayerPlaneAlpha(Display display, Layer layer, float alpha) = 0;
172 virtual Error setLayerSidebandStream(Display display, Layer layer,
173 const native_handle_t* stream) = 0;
174 virtual Error setLayerSourceCrop(Display display, Layer layer,
175 const IComposerClient::FRect& crop) = 0;
176 virtual Error setLayerTransform(Display display, Layer layer, Transform transform) = 0;
177 virtual Error setLayerVisibleRegion(Display display, Layer layer,
178 const std::vector<IComposerClient::Rect>& visible) = 0;
179 virtual Error setLayerZOrder(Display display, Layer layer, uint32_t z) = 0;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700180
181 // Composer HAL 2.2
Peiyong Lin0ac5f4e2018-04-19 22:06:34 -0700182 virtual Error setLayerPerFrameMetadata(
183 Display display, Layer layer,
184 const std::vector<IComposerClient::PerFrameMetadata>& perFrameMetadatas) = 0;
Chia-I Wud7e01d72018-06-21 13:39:09 +0800185 virtual std::vector<IComposerClient::PerFrameMetadataKey> getPerFrameMetadataKeys(
186 Display display) = 0;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700187 virtual Error getRenderIntents(Display display, ColorMode colorMode,
188 std::vector<RenderIntent>* outRenderIntents) = 0;
189 virtual Error getDataspaceSaturationMatrix(Dataspace dataspace, mat4* outMatrix) = 0;
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -0700190
191 // Composer HAL 2.3
192 virtual Error getDisplayIdentificationData(Display display, uint8_t* outPort,
193 std::vector<uint8_t>* outData) = 0;
Peiyong Lin698147a2018-09-14 13:27:18 -0700194 virtual Error setLayerColorTransform(Display display, Layer layer,
195 const float* matrix) = 0;
Kevin DuBois9c0a1762018-10-16 13:32:31 -0700196 virtual Error getDisplayedContentSamplingAttributes(Display display, PixelFormat* outFormat,
197 Dataspace* outDataspace,
198 uint8_t* outComponentMask) = 0;
Kevin DuBois74e53772018-11-19 10:52:38 -0800199 virtual Error setDisplayContentSamplingEnabled(Display display, bool enabled,
200 uint8_t componentMask, uint64_t maxFrames) = 0;
Kevin DuBois1d4249a2018-08-29 10:45:14 -0700201 virtual Error getDisplayedContentSample(Display display, uint64_t maxFrames, uint64_t timestamp,
202 DisplayedFrameStats* outStats) = 0;
Valerie Haue9e843a2018-12-18 13:39:23 -0800203 virtual Error setLayerPerFrameMetadataBlobs(
204 Display display, Layer layer, const std::vector<PerFrameMetadataBlob>& metadata) = 0;
Dan Gittik57e63c52019-01-18 16:37:54 +0000205 virtual Error setDisplayBrightness(Display display, float brightness) = 0;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700206
207 // Composer HAL 2.4
Ady Abraham7159f572019-10-11 11:10:18 -0700208 virtual bool isVsyncPeriodSwitchSupported() = 0;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700209 virtual Error getDisplayCapabilities(Display display,
210 std::vector<DisplayCapability>* outCapabilities) = 0;
Ady Abraham7159f572019-10-11 11:10:18 -0700211 virtual V2_4::Error getDisplayConnectionType(
212 Display display, IComposerClient::DisplayConnectionType* outType) = 0;
213 virtual V2_4::Error getDisplayVsyncPeriod(Display display,
214 VsyncPeriodNanos* outVsyncPeriod) = 0;
215 virtual V2_4::Error setActiveConfigWithConstraints(
216 Display display, Config config,
217 const IComposerClient::VsyncPeriodChangeConstraints& vsyncPeriodChangeConstraints,
218 VsyncPeriodChangeTimeline* outTimeline) = 0;
Galia Peycheva5492cb52019-10-30 14:13:16 +0100219
220 virtual V2_4::Error setAutoLowLatencyMode(Display displayId, bool on) = 0;
221 virtual V2_4::Error getSupportedContentTypes(
222 Display displayId,
223 std::vector<IComposerClient::ContentType>* outSupportedContentTypes) = 0;
224 virtual V2_4::Error setContentType(Display displayId,
225 IComposerClient::ContentType contentType) = 0;
Dan Stoza18d48cb2019-10-21 15:39:24 -0700226 virtual V2_4::Error setLayerGenericMetadata(Display display, Layer layer,
227 const std::string& key, bool mandatory,
228 const std::vector<uint8_t>& value) = 0;
229 virtual V2_4::Error getLayerGenericMetadataKeys(
230 std::vector<IComposerClient::LayerGenericMetadataKey>* outKeys) = 0;
Peiyong Lindfc3f7c2020-05-07 20:15:50 -0700231 virtual Error getClientTargetProperty(
232 Display display, IComposerClient::ClientTargetProperty* outClientTargetProperty) = 0;
Lloyd Piquea822d522017-12-20 16:42:57 -0800233};
234
235namespace impl {
236
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800237class CommandReader : public CommandReaderBase {
238public:
239 ~CommandReader();
240
241 // Parse and execute commands from the command queue. The commands are
242 // actually return values from the server and will be saved in ReturnData.
243 Error parse();
244
245 // Get and clear saved errors.
246 struct CommandError {
247 uint32_t location;
248 Error error;
249 };
250 std::vector<CommandError> takeErrors();
251
Chia-I Wu67e376d2016-12-19 11:36:22 +0800252 bool hasChanges(Display display, uint32_t* outNumChangedCompositionTypes,
253 uint32_t* outNumLayerRequestMasks) const;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800254
255 // Get and clear saved changed composition types.
256 void takeChangedCompositionTypes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800257 std::vector<Layer>* outLayers,
258 std::vector<IComposerClient::Composition>* outTypes);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800259
260 // Get and clear saved display requests.
261 void takeDisplayRequests(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800262 uint32_t* outDisplayRequestMask, std::vector<Layer>* outLayers,
263 std::vector<uint32_t>* outLayerRequestMasks);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800264
265 // Get and clear saved release fences.
Chia-I Wu67e376d2016-12-19 11:36:22 +0800266 void takeReleaseFences(Display display, std::vector<Layer>* outLayers,
267 std::vector<int>* outReleaseFences);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800268
269 // Get and clear saved present fence.
Chia-I Wu67e376d2016-12-19 11:36:22 +0800270 void takePresentFence(Display display, int* outPresentFence);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800271
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700272 // Get what stage succeeded during PresentOrValidate: Present or Validate
273 void takePresentOrValidateStage(Display display, uint32_t * state);
274
Peiyong Lindfc3f7c2020-05-07 20:15:50 -0700275 // Get the client target properties requested by hardware composer.
276 void takeClientTargetProperty(Display display,
277 IComposerClient::ClientTargetProperty* outClientTargetProperty);
278
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800279private:
280 void resetData();
281
282 bool parseSelectDisplay(uint16_t length);
283 bool parseSetError(uint16_t length);
284 bool parseSetChangedCompositionTypes(uint16_t length);
285 bool parseSetDisplayRequests(uint16_t length);
286 bool parseSetPresentFence(uint16_t length);
287 bool parseSetReleaseFences(uint16_t length);
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700288 bool parseSetPresentOrValidateDisplayResult(uint16_t length);
Peiyong Linafa0f572020-01-13 16:35:02 -0800289 bool parseSetClientTargetProperty(uint16_t length);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800290
291 struct ReturnData {
292 uint32_t displayRequests = 0;
293
294 std::vector<Layer> changedLayers;
295 std::vector<IComposerClient::Composition> compositionTypes;
296
297 std::vector<Layer> requestedLayers;
298 std::vector<uint32_t> requestMasks;
299
300 int presentFence = -1;
301
302 std::vector<Layer> releasedLayers;
303 std::vector<int> releaseFences;
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700304
305 uint32_t presentOrValidateState;
Peiyong Linafa0f572020-01-13 16:35:02 -0800306
307 // Composer 2.4 implementation can return a client target property
308 // structure to indicate the client target properties that hardware
309 // composer requests. The composer client must change the client target
310 // properties to match this request.
311 IComposerClient::ClientTargetProperty clientTargetProperty{PixelFormat::RGBA_8888,
312 Dataspace::UNKNOWN};
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800313 };
314
315 std::vector<CommandError> mErrors;
316 std::unordered_map<Display, ReturnData> mReturnData;
317
318 // When SELECT_DISPLAY is parsed, this is updated to point to the
319 // display's return data in mReturnData. We use it to avoid repeated
320 // map lookups.
321 ReturnData* mCurrentReturnData;
322};
323
Chia-I Wuaab99f52016-10-05 12:59:58 +0800324// Composer is a wrapper to IComposer, a proxy to server-side composer.
Lloyd Piquea822d522017-12-20 16:42:57 -0800325class Composer final : public Hwc2::Composer {
Chia-I Wuaab99f52016-10-05 12:59:58 +0800326public:
Chih-Hung Hsieh22749042018-12-20 15:50:39 -0800327 explicit Composer(const std::string& serviceName);
Lloyd Piquea822d522017-12-20 16:42:57 -0800328 ~Composer() override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800329
Lloyd Piquea822d522017-12-20 16:42:57 -0800330 std::vector<IComposer::Capability> getCapabilities() override;
331 std::string dumpDebugInfo() override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800332
Lloyd Piquea822d522017-12-20 16:42:57 -0800333 void registerCallback(const sp<IComposerCallback>& callback) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800334
Steven Thomas0af4b9f2017-04-26 14:34:01 -0700335 // Reset all pending commands in the command buffer. Useful if you want to
336 // skip a frame but have already queued some commands.
Lloyd Piquea822d522017-12-20 16:42:57 -0800337 void resetCommands() override;
Steven Thomas0af4b9f2017-04-26 14:34:01 -0700338
Chia-I Wuae5a6b82017-10-10 09:09:22 -0700339 // Explicitly flush all pending commands in the command buffer.
Lloyd Piquea822d522017-12-20 16:42:57 -0800340 Error executeCommands() override;
Chia-I Wuae5a6b82017-10-10 09:09:22 -0700341
Lloyd Piquea822d522017-12-20 16:42:57 -0800342 uint32_t getMaxVirtualDisplayCount() override;
Lloyd Piquea822d522017-12-20 16:42:57 -0800343 Error createVirtualDisplay(uint32_t width, uint32_t height, PixelFormat* format,
344 Display* outDisplay) override;
345 Error destroyVirtualDisplay(Display display) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800346
Lloyd Piquea822d522017-12-20 16:42:57 -0800347 Error acceptDisplayChanges(Display display) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800348
Lloyd Piquea822d522017-12-20 16:42:57 -0800349 Error createLayer(Display display, Layer* outLayer) override;
350 Error destroyLayer(Display display, Layer layer) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800351
Lloyd Piquea822d522017-12-20 16:42:57 -0800352 Error getActiveConfig(Display display, Config* outConfig) override;
353 Error getChangedCompositionTypes(Display display, std::vector<Layer>* outLayers,
354 std::vector<IComposerClient::Composition>* outTypes) override;
355 Error getColorModes(Display display, std::vector<ColorMode>* outModes) override;
356 Error getDisplayAttribute(Display display, Config config, IComposerClient::Attribute attribute,
357 int32_t* outValue) override;
Chia-I Wu67e376d2016-12-19 11:36:22 +0800358 Error getDisplayConfigs(Display display, std::vector<Config>* outConfigs);
Lloyd Piquea822d522017-12-20 16:42:57 -0800359 Error getDisplayName(Display display, std::string* outName) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800360
Chia-I Wu67e376d2016-12-19 11:36:22 +0800361 Error getDisplayRequests(Display display, uint32_t* outDisplayRequestMask,
Lloyd Piquea822d522017-12-20 16:42:57 -0800362 std::vector<Layer>* outLayers,
363 std::vector<uint32_t>* outLayerRequestMasks) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800364
Lloyd Piquea822d522017-12-20 16:42:57 -0800365 Error getDozeSupport(Display display, bool* outSupport) override;
366 Error getHdrCapabilities(Display display, std::vector<Hdr>* outTypes, float* outMaxLuminance,
367 float* outMaxAverageLuminance, float* outMinLuminance) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800368
Chia-I Wu67e376d2016-12-19 11:36:22 +0800369 Error getReleaseFences(Display display, std::vector<Layer>* outLayers,
Lloyd Piquea822d522017-12-20 16:42:57 -0800370 std::vector<int>* outReleaseFences) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800371
Lloyd Piquea822d522017-12-20 16:42:57 -0800372 Error presentDisplay(Display display, int* outPresentFence) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800373
Lloyd Piquea822d522017-12-20 16:42:57 -0800374 Error setActiveConfig(Display display, Config config) override;
Chia-I Wu06d63de2017-01-04 14:58:51 +0800375
376 /*
377 * The composer caches client targets internally. When target is nullptr,
378 * the composer uses slot to look up the client target from its cache.
379 * When target is not nullptr, the cache is updated with the new target.
380 */
Lloyd Piquea822d522017-12-20 16:42:57 -0800381 Error setClientTarget(Display display, uint32_t slot, const sp<GraphicBuffer>& target,
382 int acquireFence, Dataspace dataspace,
383 const std::vector<IComposerClient::Rect>& damage) override;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700384 Error setColorMode(Display display, ColorMode mode, RenderIntent renderIntent) override;
Lloyd Piquea822d522017-12-20 16:42:57 -0800385 Error setColorTransform(Display display, const float* matrix, ColorTransform hint) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800386 Error setOutputBuffer(Display display, const native_handle_t* buffer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800387 int releaseFence) override;
388 Error setPowerMode(Display display, IComposerClient::PowerMode mode) override;
389 Error setVsyncEnabled(Display display, IComposerClient::Vsync enabled) override;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800390
Lloyd Piquea822d522017-12-20 16:42:57 -0800391 Error setClientTargetSlotCount(Display display) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800392
Chia-I Wu67e376d2016-12-19 11:36:22 +0800393 Error validateDisplay(Display display, uint32_t* outNumTypes,
Lloyd Piquea822d522017-12-20 16:42:57 -0800394 uint32_t* outNumRequests) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800395
Lloyd Piquea822d522017-12-20 16:42:57 -0800396 Error presentOrValidateDisplay(Display display, uint32_t* outNumTypes, uint32_t* outNumRequests,
397 int* outPresentFence, uint32_t* state) override;
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700398
Lloyd Piquea822d522017-12-20 16:42:57 -0800399 Error setCursorPosition(Display display, Layer layer, int32_t x, int32_t y) override;
Chia-I Wu06d63de2017-01-04 14:58:51 +0800400 /* see setClientTarget for the purpose of slot */
401 Error setLayerBuffer(Display display, Layer layer, uint32_t slot,
Lloyd Piquea822d522017-12-20 16:42:57 -0800402 const sp<GraphicBuffer>& buffer, int acquireFence) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800403 Error setLayerSurfaceDamage(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800404 const std::vector<IComposerClient::Rect>& damage) override;
405 Error setLayerBlendMode(Display display, Layer layer, IComposerClient::BlendMode mode) override;
406 Error setLayerColor(Display display, Layer layer, const IComposerClient::Color& color) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800407 Error setLayerCompositionType(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800408 IComposerClient::Composition type) override;
409 Error setLayerDataspace(Display display, Layer layer, Dataspace dataspace) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800410 Error setLayerDisplayFrame(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800411 const IComposerClient::Rect& frame) override;
412 Error setLayerPlaneAlpha(Display display, Layer layer, float alpha) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800413 Error setLayerSidebandStream(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800414 const native_handle_t* stream) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800415 Error setLayerSourceCrop(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800416 const IComposerClient::FRect& crop) override;
417 Error setLayerTransform(Display display, Layer layer, Transform transform) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800418 Error setLayerVisibleRegion(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800419 const std::vector<IComposerClient::Rect>& visible) override;
420 Error setLayerZOrder(Display display, Layer layer, uint32_t z) override;
Lloyd Piquea822d522017-12-20 16:42:57 -0800421
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700422 // Composer HAL 2.2
Peiyong Lin0ac5f4e2018-04-19 22:06:34 -0700423 Error setLayerPerFrameMetadata(
424 Display display, Layer layer,
425 const std::vector<IComposerClient::PerFrameMetadata>& perFrameMetadatas) override;
Chia-I Wud7e01d72018-06-21 13:39:09 +0800426 std::vector<IComposerClient::PerFrameMetadataKey> getPerFrameMetadataKeys(
427 Display display) override;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700428 Error getRenderIntents(Display display, ColorMode colorMode,
429 std::vector<RenderIntent>* outRenderIntents) override;
430 Error getDataspaceSaturationMatrix(Dataspace dataspace, mat4* outMatrix) override;
431
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -0700432 // Composer HAL 2.3
433 Error getDisplayIdentificationData(Display display, uint8_t* outPort,
434 std::vector<uint8_t>* outData) override;
Peiyong Lin698147a2018-09-14 13:27:18 -0700435 Error setLayerColorTransform(Display display, Layer layer, const float* matrix) override;
Kevin DuBois9c0a1762018-10-16 13:32:31 -0700436 Error getDisplayedContentSamplingAttributes(Display display, PixelFormat* outFormat,
437 Dataspace* outDataspace,
438 uint8_t* outComponentMask) override;
Kevin DuBois74e53772018-11-19 10:52:38 -0800439 Error setDisplayContentSamplingEnabled(Display display, bool enabled, uint8_t componentMask,
440 uint64_t maxFrames) override;
Kevin DuBois1d4249a2018-08-29 10:45:14 -0700441 Error getDisplayedContentSample(Display display, uint64_t maxFrames, uint64_t timestamp,
442 DisplayedFrameStats* outStats) override;
Valerie Haue9e843a2018-12-18 13:39:23 -0800443 Error setLayerPerFrameMetadataBlobs(
444 Display display, Layer layer,
445 const std::vector<IComposerClient::PerFrameMetadataBlob>& metadata) override;
Dan Gittik57e63c52019-01-18 16:37:54 +0000446 Error setDisplayBrightness(Display display, float brightness) override;
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -0700447
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700448 // Composer HAL 2.4
Ady Abraham7159f572019-10-11 11:10:18 -0700449 bool isVsyncPeriodSwitchSupported() override { return mClient_2_4 != nullptr; }
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700450 Error getDisplayCapabilities(Display display,
451 std::vector<DisplayCapability>* outCapabilities) override;
Ady Abraham7159f572019-10-11 11:10:18 -0700452 V2_4::Error getDisplayConnectionType(Display display,
453 IComposerClient::DisplayConnectionType* outType) override;
454 V2_4::Error getDisplayVsyncPeriod(Display display, VsyncPeriodNanos* outVsyncPeriod) override;
455 V2_4::Error setActiveConfigWithConstraints(
456 Display display, Config config,
457 const IComposerClient::VsyncPeriodChangeConstraints& vsyncPeriodChangeConstraints,
458 VsyncPeriodChangeTimeline* outTimeline) override;
Galia Peycheva5492cb52019-10-30 14:13:16 +0100459 V2_4::Error setAutoLowLatencyMode(Display displayId, bool on) override;
460 V2_4::Error getSupportedContentTypes(
461 Display displayId,
462 std::vector<IComposerClient::ContentType>* outSupportedContentTypes) override;
463 V2_4::Error setContentType(Display displayId,
464 IComposerClient::ContentType contentType) override;
Dan Stoza18d48cb2019-10-21 15:39:24 -0700465 V2_4::Error setLayerGenericMetadata(Display display, Layer layer, const std::string& key,
466 bool mandatory, const std::vector<uint8_t>& value) override;
467 V2_4::Error getLayerGenericMetadataKeys(
468 std::vector<IComposerClient::LayerGenericMetadataKey>* outKeys) override;
Peiyong Lindfc3f7c2020-05-07 20:15:50 -0700469 Error getClientTargetProperty(
470 Display display,
471 IComposerClient::ClientTargetProperty* outClientTargetProperty) override;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700472
Chia-I Wuaab99f52016-10-05 12:59:58 +0800473private:
mamik94e91f62019-08-19 09:11:33 -0700474 class CommandWriter : public CommandWriterBase {
475 public:
476 explicit CommandWriter(uint32_t initialMaxSize) : CommandWriterBase(initialMaxSize) {}
477 ~CommandWriter() override {}
478 };
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500479
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800480 // Many public functions above simply write a command into the command
481 // queue to batch the calls. validateDisplay and presentDisplay will call
482 // this function to execute the command queue.
483 Error execute();
484
Dominik Laskowski6231aaf2018-04-02 17:10:23 -0700485 sp<V2_1::IComposer> mComposer;
486
487 sp<V2_1::IComposerClient> mClient;
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -0700488 sp<V2_2::IComposerClient> mClient_2_2;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700489 sp<V2_3::IComposerClient> mClient_2_3;
490 sp<IComposerClient> mClient_2_4;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800491
492 // 64KiB minus a small space for metadata such as read/write pointers
493 static constexpr size_t kWriterInitialSize =
494 64 * 1024 / sizeof(uint32_t) - 16;
Alec Mourie7cc1c22021-04-27 15:23:26 -0700495 // Max number of buffers that may be cached for a given layer
496 // We obtain this number by:
497 // 1. Tightly coupling this cache to the max size of BufferQueue
498 // 2. Adding an additional slot for the layer caching feature in SurfaceFlinger (see: Planner.h)
499 static const constexpr uint32_t kMaxLayerBufferCount = BufferQueue::NUM_BUFFER_SLOTS + 1;
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500500 CommandWriter mWriter;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800501 CommandReader mReader;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800502};
503
Lloyd Piquea822d522017-12-20 16:42:57 -0800504} // namespace impl
505
Chia-I Wuaab99f52016-10-05 12:59:58 +0800506} // namespace Hwc2
507
508} // namespace android
509
510#endif // ANDROID_SF_COMPOSER_HAL_H