blob: fe114b9512adff501d7bb8f1b286ef7e77f53738 [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>
Dominik Laskowski13948602021-03-08 20:48:28 -080021#include <optional>
Chia-I Wuaab99f52016-10-05 12:59:58 +080022#include <string>
Chia-I Wucd8d7f02016-11-16 11:02:31 +080023#include <unordered_map>
24#include <utility>
Chia-I Wuaab99f52016-10-05 12:59:58 +080025#include <vector>
26
Ady Abraham8a82ba62020-01-17 12:43:17 -080027// TODO(b/129481165): remove the #pragma below and fix conversion issues
28#pragma clang diagnostic push
29#pragma clang diagnostic ignored "-Wconversion"
Marin Shalamanovbed7fd32020-12-21 20:02:20 +010030#pragma clang diagnostic ignored "-Wextra"
Ady Abraham8a82ba62020-01-17 12:43:17 -080031
Peiyong Lin34beb7a2018-03-28 11:57:12 -070032#include <android/hardware/graphics/common/1.1/types.h>
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -070033#include <android/hardware/graphics/composer/2.4/IComposer.h>
34#include <android/hardware/graphics/composer/2.4/IComposerClient.h>
Peiyong Linafa0f572020-01-13 16:35:02 -080035#include <composer-command-buffer/2.4/ComposerCommandBuffer.h>
Alec Mourie7cc1c22021-04-27 15:23:26 -070036#include <gui/BufferQueue.h>
Courtney Goeltzenleuchterf9c98e52018-02-12 07:23:17 -070037#include <gui/HdrMetadata.h>
Peiyong Lin0e7a7912018-04-05 14:36:36 -070038#include <math/mat4.h>
Kevin DuBois1d4249a2018-08-29 10:45:14 -070039#include <ui/DisplayedFrameStats.h>
Lloyd Piqued0094aa2017-12-20 16:43:28 -080040#include <ui/GraphicBuffer.h>
Chia-I Wuaab99f52016-10-05 12:59:58 +080041#include <utils/StrongPointer.h>
42
Ady Abraham8a82ba62020-01-17 12:43:17 -080043// TODO(b/129481165): remove the #pragma below and fix conversion issues
Marin Shalamanovbed7fd32020-12-21 20:02:20 +010044#pragma clang diagnostic pop // ignored "-Wconversion -Wextra"
Ady Abraham8a82ba62020-01-17 12:43:17 -080045
Chia-I Wuaab99f52016-10-05 12:59:58 +080046namespace android {
47
48namespace Hwc2 {
49
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070050namespace types = hardware::graphics::common;
Chia-I Wuaab99f52016-10-05 12:59:58 +080051
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070052namespace V2_1 = hardware::graphics::composer::V2_1;
53namespace V2_2 = hardware::graphics::composer::V2_2;
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -070054namespace V2_3 = hardware::graphics::composer::V2_3;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -070055namespace V2_4 = hardware::graphics::composer::V2_4;
Chia-I Wuaab99f52016-10-05 12:59:58 +080056
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070057using types::V1_0::ColorTransform;
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070058using types::V1_0::Transform;
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070059using types::V1_1::RenderIntent;
Valerie Hau9758ae02018-10-09 16:05:09 -070060using types::V1_2::ColorMode;
61using types::V1_2::Dataspace;
Valerie Haue9e843a2018-12-18 13:39:23 -080062using types::V1_2::Hdr;
Kevin DuBois73d0f482019-01-25 11:18:03 -080063using types::V1_2::PixelFormat;
Valerie Haue9e843a2018-12-18 13:39:23 -080064
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070065using V2_1::Config;
66using V2_1::Display;
67using V2_1::Error;
Dominik Laskowski6231aaf2018-04-02 17:10:23 -070068using V2_1::Layer;
Peiyong Linafa0f572020-01-13 16:35:02 -080069using V2_4::CommandReaderBase;
70using V2_4::CommandWriterBase;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -070071using V2_4::IComposer;
Ady Abraham7159f572019-10-11 11:10:18 -070072using V2_4::IComposerCallback;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -070073using V2_4::IComposerClient;
Ady Abraham7159f572019-10-11 11:10:18 -070074using V2_4::VsyncPeriodChangeTimeline;
75using V2_4::VsyncPeriodNanos;
Peiyong Lined531a32018-10-26 18:27:56 -070076using DisplayCapability = IComposerClient::DisplayCapability;
Peiyong Lin0ac5f4e2018-04-19 22:06:34 -070077using PerFrameMetadata = IComposerClient::PerFrameMetadata;
78using PerFrameMetadataKey = IComposerClient::PerFrameMetadataKey;
Valerie Haue9e843a2018-12-18 13:39:23 -080079using PerFrameMetadataBlob = IComposerClient::PerFrameMetadataBlob;
Peiyong Lin0ac5f4e2018-04-19 22:06:34 -070080
Lloyd Piquea822d522017-12-20 16:42:57 -080081class Composer {
82public:
83 virtual ~Composer() = 0;
84
85 virtual std::vector<IComposer::Capability> getCapabilities() = 0;
86 virtual std::string dumpDebugInfo() = 0;
87
88 virtual void registerCallback(const sp<IComposerCallback>& callback) = 0;
89
Lloyd Piquea822d522017-12-20 16:42:57 -080090 // Reset all pending commands in the command buffer. Useful if you want to
91 // skip a frame but have already queued some commands.
92 virtual void resetCommands() = 0;
93
94 // Explicitly flush all pending commands in the command buffer.
95 virtual Error executeCommands() = 0;
96
97 virtual uint32_t getMaxVirtualDisplayCount() = 0;
Dominik Laskowski13948602021-03-08 20:48:28 -080098 virtual Error createVirtualDisplay(uint32_t width, uint32_t height, PixelFormat*,
Dominik Laskowski263eec42021-07-21 23:13:24 -070099 Display* outDisplay) = 0;
Lloyd Piquea822d522017-12-20 16:42:57 -0800100 virtual Error destroyVirtualDisplay(Display display) = 0;
101
102 virtual Error acceptDisplayChanges(Display display) = 0;
103
104 virtual Error createLayer(Display display, Layer* outLayer) = 0;
105 virtual Error destroyLayer(Display display, Layer layer) = 0;
106
107 virtual Error getActiveConfig(Display display, Config* outConfig) = 0;
108 virtual Error getChangedCompositionTypes(
109 Display display, std::vector<Layer>* outLayers,
110 std::vector<IComposerClient::Composition>* outTypes) = 0;
111 virtual Error getColorModes(Display display, std::vector<ColorMode>* outModes) = 0;
112 virtual Error getDisplayAttribute(Display display, Config config,
113 IComposerClient::Attribute attribute, int32_t* outValue) = 0;
114 virtual Error getDisplayConfigs(Display display, std::vector<Config>* outConfigs) = 0;
115 virtual Error getDisplayName(Display display, std::string* outName) = 0;
116
117 virtual Error getDisplayRequests(Display display, uint32_t* outDisplayRequestMask,
118 std::vector<Layer>* outLayers,
119 std::vector<uint32_t>* outLayerRequestMasks) = 0;
120
Lloyd Piquea822d522017-12-20 16:42:57 -0800121 virtual Error getDozeSupport(Display display, bool* outSupport) = 0;
122 virtual Error getHdrCapabilities(Display display, std::vector<Hdr>* outTypes,
123 float* outMaxLuminance, float* outMaxAverageLuminance,
124 float* outMinLuminance) = 0;
125
126 virtual Error getReleaseFences(Display display, std::vector<Layer>* outLayers,
127 std::vector<int>* outReleaseFences) = 0;
128
129 virtual Error presentDisplay(Display display, int* outPresentFence) = 0;
130
131 virtual Error setActiveConfig(Display display, Config config) = 0;
132
133 /*
134 * The composer caches client targets internally. When target is nullptr,
135 * the composer uses slot to look up the client target from its cache.
136 * When target is not nullptr, the cache is updated with the new target.
137 */
138 virtual Error setClientTarget(Display display, uint32_t slot, const sp<GraphicBuffer>& target,
139 int acquireFence, Dataspace dataspace,
140 const std::vector<IComposerClient::Rect>& damage) = 0;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700141 virtual Error setColorMode(Display display, ColorMode mode, RenderIntent renderIntent) = 0;
Lloyd Piquea822d522017-12-20 16:42:57 -0800142 virtual Error setColorTransform(Display display, const float* matrix, ColorTransform hint) = 0;
143 virtual Error setOutputBuffer(Display display, const native_handle_t* buffer,
144 int releaseFence) = 0;
145 virtual Error setPowerMode(Display display, IComposerClient::PowerMode mode) = 0;
146 virtual Error setVsyncEnabled(Display display, IComposerClient::Vsync enabled) = 0;
147
148 virtual Error setClientTargetSlotCount(Display display) = 0;
149
150 virtual Error validateDisplay(Display display, uint32_t* outNumTypes,
151 uint32_t* outNumRequests) = 0;
152
153 virtual Error presentOrValidateDisplay(Display display, uint32_t* outNumTypes,
154 uint32_t* outNumRequests, int* outPresentFence,
155 uint32_t* state) = 0;
156
157 virtual Error setCursorPosition(Display display, Layer layer, int32_t x, int32_t y) = 0;
158 /* see setClientTarget for the purpose of slot */
159 virtual Error setLayerBuffer(Display display, Layer layer, uint32_t slot,
160 const sp<GraphicBuffer>& buffer, int acquireFence) = 0;
161 virtual Error setLayerSurfaceDamage(Display display, Layer layer,
162 const std::vector<IComposerClient::Rect>& damage) = 0;
163 virtual Error setLayerBlendMode(Display display, Layer layer,
164 IComposerClient::BlendMode mode) = 0;
165 virtual Error setLayerColor(Display display, Layer layer,
166 const IComposerClient::Color& color) = 0;
167 virtual Error setLayerCompositionType(Display display, Layer layer,
168 IComposerClient::Composition type) = 0;
169 virtual Error setLayerDataspace(Display display, Layer layer, Dataspace dataspace) = 0;
170 virtual Error setLayerDisplayFrame(Display display, Layer layer,
171 const IComposerClient::Rect& frame) = 0;
172 virtual Error setLayerPlaneAlpha(Display display, Layer layer, float alpha) = 0;
173 virtual Error setLayerSidebandStream(Display display, Layer layer,
174 const native_handle_t* stream) = 0;
175 virtual Error setLayerSourceCrop(Display display, Layer layer,
176 const IComposerClient::FRect& crop) = 0;
177 virtual Error setLayerTransform(Display display, Layer layer, Transform transform) = 0;
178 virtual Error setLayerVisibleRegion(Display display, Layer layer,
179 const std::vector<IComposerClient::Rect>& visible) = 0;
180 virtual Error setLayerZOrder(Display display, Layer layer, uint32_t z) = 0;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700181
182 // Composer HAL 2.2
Peiyong Lin0ac5f4e2018-04-19 22:06:34 -0700183 virtual Error setLayerPerFrameMetadata(
184 Display display, Layer layer,
185 const std::vector<IComposerClient::PerFrameMetadata>& perFrameMetadatas) = 0;
Chia-I Wud7e01d72018-06-21 13:39:09 +0800186 virtual std::vector<IComposerClient::PerFrameMetadataKey> getPerFrameMetadataKeys(
187 Display display) = 0;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700188 virtual Error getRenderIntents(Display display, ColorMode colorMode,
189 std::vector<RenderIntent>* outRenderIntents) = 0;
190 virtual Error getDataspaceSaturationMatrix(Dataspace dataspace, mat4* outMatrix) = 0;
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -0700191
192 // Composer HAL 2.3
193 virtual Error getDisplayIdentificationData(Display display, uint8_t* outPort,
194 std::vector<uint8_t>* outData) = 0;
Peiyong Lin698147a2018-09-14 13:27:18 -0700195 virtual Error setLayerColorTransform(Display display, Layer layer,
196 const float* matrix) = 0;
Kevin DuBois9c0a1762018-10-16 13:32:31 -0700197 virtual Error getDisplayedContentSamplingAttributes(Display display, PixelFormat* outFormat,
198 Dataspace* outDataspace,
199 uint8_t* outComponentMask) = 0;
Kevin DuBois74e53772018-11-19 10:52:38 -0800200 virtual Error setDisplayContentSamplingEnabled(Display display, bool enabled,
201 uint8_t componentMask, uint64_t maxFrames) = 0;
Kevin DuBois1d4249a2018-08-29 10:45:14 -0700202 virtual Error getDisplayedContentSample(Display display, uint64_t maxFrames, uint64_t timestamp,
203 DisplayedFrameStats* outStats) = 0;
Valerie Haue9e843a2018-12-18 13:39:23 -0800204 virtual Error setLayerPerFrameMetadataBlobs(
205 Display display, Layer layer, const std::vector<PerFrameMetadataBlob>& metadata) = 0;
Dan Gittik57e63c52019-01-18 16:37:54 +0000206 virtual Error setDisplayBrightness(Display display, float brightness) = 0;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700207
208 // Composer HAL 2.4
Ady Abraham7159f572019-10-11 11:10:18 -0700209 virtual bool isVsyncPeriodSwitchSupported() = 0;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700210 virtual Error getDisplayCapabilities(Display display,
211 std::vector<DisplayCapability>* outCapabilities) = 0;
Ady Abraham7159f572019-10-11 11:10:18 -0700212 virtual V2_4::Error getDisplayConnectionType(
213 Display display, IComposerClient::DisplayConnectionType* outType) = 0;
214 virtual V2_4::Error getDisplayVsyncPeriod(Display display,
215 VsyncPeriodNanos* outVsyncPeriod) = 0;
216 virtual V2_4::Error setActiveConfigWithConstraints(
217 Display display, Config config,
218 const IComposerClient::VsyncPeriodChangeConstraints& vsyncPeriodChangeConstraints,
219 VsyncPeriodChangeTimeline* outTimeline) = 0;
Galia Peycheva5492cb52019-10-30 14:13:16 +0100220
221 virtual V2_4::Error setAutoLowLatencyMode(Display displayId, bool on) = 0;
222 virtual V2_4::Error getSupportedContentTypes(
223 Display displayId,
224 std::vector<IComposerClient::ContentType>* outSupportedContentTypes) = 0;
225 virtual V2_4::Error setContentType(Display displayId,
226 IComposerClient::ContentType contentType) = 0;
Dan Stoza18d48cb2019-10-21 15:39:24 -0700227 virtual V2_4::Error setLayerGenericMetadata(Display display, Layer layer,
228 const std::string& key, bool mandatory,
229 const std::vector<uint8_t>& value) = 0;
230 virtual V2_4::Error getLayerGenericMetadataKeys(
231 std::vector<IComposerClient::LayerGenericMetadataKey>* outKeys) = 0;
Peiyong Lindfc3f7c2020-05-07 20:15:50 -0700232 virtual Error getClientTargetProperty(
233 Display display, IComposerClient::ClientTargetProperty* outClientTargetProperty) = 0;
Lloyd Piquea822d522017-12-20 16:42:57 -0800234};
235
236namespace impl {
237
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800238class CommandReader : public CommandReaderBase {
239public:
240 ~CommandReader();
241
242 // Parse and execute commands from the command queue. The commands are
243 // actually return values from the server and will be saved in ReturnData.
244 Error parse();
245
246 // Get and clear saved errors.
247 struct CommandError {
248 uint32_t location;
249 Error error;
250 };
251 std::vector<CommandError> takeErrors();
252
Chia-I Wu67e376d2016-12-19 11:36:22 +0800253 bool hasChanges(Display display, uint32_t* outNumChangedCompositionTypes,
254 uint32_t* outNumLayerRequestMasks) const;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800255
256 // Get and clear saved changed composition types.
257 void takeChangedCompositionTypes(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800258 std::vector<Layer>* outLayers,
259 std::vector<IComposerClient::Composition>* outTypes);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800260
261 // Get and clear saved display requests.
262 void takeDisplayRequests(Display display,
Chia-I Wu67e376d2016-12-19 11:36:22 +0800263 uint32_t* outDisplayRequestMask, std::vector<Layer>* outLayers,
264 std::vector<uint32_t>* outLayerRequestMasks);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800265
266 // Get and clear saved release fences.
Chia-I Wu67e376d2016-12-19 11:36:22 +0800267 void takeReleaseFences(Display display, std::vector<Layer>* outLayers,
268 std::vector<int>* outReleaseFences);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800269
270 // Get and clear saved present fence.
Chia-I Wu67e376d2016-12-19 11:36:22 +0800271 void takePresentFence(Display display, int* outPresentFence);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800272
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700273 // Get what stage succeeded during PresentOrValidate: Present or Validate
274 void takePresentOrValidateStage(Display display, uint32_t * state);
275
Peiyong Lindfc3f7c2020-05-07 20:15:50 -0700276 // Get the client target properties requested by hardware composer.
277 void takeClientTargetProperty(Display display,
278 IComposerClient::ClientTargetProperty* outClientTargetProperty);
279
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800280private:
281 void resetData();
282
283 bool parseSelectDisplay(uint16_t length);
284 bool parseSetError(uint16_t length);
285 bool parseSetChangedCompositionTypes(uint16_t length);
286 bool parseSetDisplayRequests(uint16_t length);
287 bool parseSetPresentFence(uint16_t length);
288 bool parseSetReleaseFences(uint16_t length);
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700289 bool parseSetPresentOrValidateDisplayResult(uint16_t length);
Peiyong Linafa0f572020-01-13 16:35:02 -0800290 bool parseSetClientTargetProperty(uint16_t length);
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800291
292 struct ReturnData {
293 uint32_t displayRequests = 0;
294
295 std::vector<Layer> changedLayers;
296 std::vector<IComposerClient::Composition> compositionTypes;
297
298 std::vector<Layer> requestedLayers;
299 std::vector<uint32_t> requestMasks;
300
301 int presentFence = -1;
302
303 std::vector<Layer> releasedLayers;
304 std::vector<int> releaseFences;
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700305
306 uint32_t presentOrValidateState;
Peiyong Linafa0f572020-01-13 16:35:02 -0800307
308 // Composer 2.4 implementation can return a client target property
309 // structure to indicate the client target properties that hardware
310 // composer requests. The composer client must change the client target
311 // properties to match this request.
312 IComposerClient::ClientTargetProperty clientTargetProperty{PixelFormat::RGBA_8888,
313 Dataspace::UNKNOWN};
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800314 };
315
316 std::vector<CommandError> mErrors;
317 std::unordered_map<Display, ReturnData> mReturnData;
318
319 // When SELECT_DISPLAY is parsed, this is updated to point to the
320 // display's return data in mReturnData. We use it to avoid repeated
321 // map lookups.
322 ReturnData* mCurrentReturnData;
323};
324
Chia-I Wuaab99f52016-10-05 12:59:58 +0800325// Composer is a wrapper to IComposer, a proxy to server-side composer.
Lloyd Piquea822d522017-12-20 16:42:57 -0800326class Composer final : public Hwc2::Composer {
Chia-I Wuaab99f52016-10-05 12:59:58 +0800327public:
Chih-Hung Hsieh22749042018-12-20 15:50:39 -0800328 explicit Composer(const std::string& serviceName);
Lloyd Piquea822d522017-12-20 16:42:57 -0800329 ~Composer() override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800330
Lloyd Piquea822d522017-12-20 16:42:57 -0800331 std::vector<IComposer::Capability> getCapabilities() override;
332 std::string dumpDebugInfo() override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800333
Lloyd Piquea822d522017-12-20 16:42:57 -0800334 void registerCallback(const sp<IComposerCallback>& callback) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800335
Steven Thomas0af4b9f2017-04-26 14:34:01 -0700336 // Reset all pending commands in the command buffer. Useful if you want to
337 // skip a frame but have already queued some commands.
Lloyd Piquea822d522017-12-20 16:42:57 -0800338 void resetCommands() override;
Steven Thomas0af4b9f2017-04-26 14:34:01 -0700339
Chia-I Wuae5a6b82017-10-10 09:09:22 -0700340 // Explicitly flush all pending commands in the command buffer.
Lloyd Piquea822d522017-12-20 16:42:57 -0800341 Error executeCommands() override;
Chia-I Wuae5a6b82017-10-10 09:09:22 -0700342
Lloyd Piquea822d522017-12-20 16:42:57 -0800343 uint32_t getMaxVirtualDisplayCount() override;
Lloyd Piquea822d522017-12-20 16:42:57 -0800344 Error createVirtualDisplay(uint32_t width, uint32_t height, PixelFormat* format,
Dominik Laskowski263eec42021-07-21 23:13:24 -0700345 Display* outDisplay) override;
Lloyd Piquea822d522017-12-20 16:42:57 -0800346 Error destroyVirtualDisplay(Display display) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800347
Lloyd Piquea822d522017-12-20 16:42:57 -0800348 Error acceptDisplayChanges(Display display) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800349
Lloyd Piquea822d522017-12-20 16:42:57 -0800350 Error createLayer(Display display, Layer* outLayer) override;
351 Error destroyLayer(Display display, Layer layer) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800352
Lloyd Piquea822d522017-12-20 16:42:57 -0800353 Error getActiveConfig(Display display, Config* outConfig) override;
354 Error getChangedCompositionTypes(Display display, std::vector<Layer>* outLayers,
355 std::vector<IComposerClient::Composition>* outTypes) override;
356 Error getColorModes(Display display, std::vector<ColorMode>* outModes) override;
357 Error getDisplayAttribute(Display display, Config config, IComposerClient::Attribute attribute,
358 int32_t* outValue) override;
Chia-I Wu67e376d2016-12-19 11:36:22 +0800359 Error getDisplayConfigs(Display display, std::vector<Config>* outConfigs);
Lloyd Piquea822d522017-12-20 16:42:57 -0800360 Error getDisplayName(Display display, std::string* outName) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800361
Chia-I Wu67e376d2016-12-19 11:36:22 +0800362 Error getDisplayRequests(Display display, uint32_t* outDisplayRequestMask,
Lloyd Piquea822d522017-12-20 16:42:57 -0800363 std::vector<Layer>* outLayers,
364 std::vector<uint32_t>* outLayerRequestMasks) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800365
Lloyd Piquea822d522017-12-20 16:42:57 -0800366 Error getDozeSupport(Display display, bool* outSupport) override;
367 Error getHdrCapabilities(Display display, std::vector<Hdr>* outTypes, float* outMaxLuminance,
368 float* outMaxAverageLuminance, float* outMinLuminance) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800369
Chia-I Wu67e376d2016-12-19 11:36:22 +0800370 Error getReleaseFences(Display display, std::vector<Layer>* outLayers,
Lloyd Piquea822d522017-12-20 16:42:57 -0800371 std::vector<int>* outReleaseFences) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800372
Lloyd Piquea822d522017-12-20 16:42:57 -0800373 Error presentDisplay(Display display, int* outPresentFence) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800374
Lloyd Piquea822d522017-12-20 16:42:57 -0800375 Error setActiveConfig(Display display, Config config) override;
Chia-I Wu06d63de2017-01-04 14:58:51 +0800376
377 /*
378 * The composer caches client targets internally. When target is nullptr,
379 * the composer uses slot to look up the client target from its cache.
380 * When target is not nullptr, the cache is updated with the new target.
381 */
Lloyd Piquea822d522017-12-20 16:42:57 -0800382 Error setClientTarget(Display display, uint32_t slot, const sp<GraphicBuffer>& target,
383 int acquireFence, Dataspace dataspace,
384 const std::vector<IComposerClient::Rect>& damage) override;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700385 Error setColorMode(Display display, ColorMode mode, RenderIntent renderIntent) override;
Lloyd Piquea822d522017-12-20 16:42:57 -0800386 Error setColorTransform(Display display, const float* matrix, ColorTransform hint) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800387 Error setOutputBuffer(Display display, const native_handle_t* buffer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800388 int releaseFence) override;
389 Error setPowerMode(Display display, IComposerClient::PowerMode mode) override;
390 Error setVsyncEnabled(Display display, IComposerClient::Vsync enabled) override;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800391
Lloyd Piquea822d522017-12-20 16:42:57 -0800392 Error setClientTargetSlotCount(Display display) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800393
Chia-I Wu67e376d2016-12-19 11:36:22 +0800394 Error validateDisplay(Display display, uint32_t* outNumTypes,
Lloyd Piquea822d522017-12-20 16:42:57 -0800395 uint32_t* outNumRequests) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800396
Lloyd Piquea822d522017-12-20 16:42:57 -0800397 Error presentOrValidateDisplay(Display display, uint32_t* outNumTypes, uint32_t* outNumRequests,
398 int* outPresentFence, uint32_t* state) override;
Fabien Sanglard249c0ae2017-06-19 19:22:36 -0700399
Lloyd Piquea822d522017-12-20 16:42:57 -0800400 Error setCursorPosition(Display display, Layer layer, int32_t x, int32_t y) override;
Chia-I Wu06d63de2017-01-04 14:58:51 +0800401 /* see setClientTarget for the purpose of slot */
402 Error setLayerBuffer(Display display, Layer layer, uint32_t slot,
Lloyd Piquea822d522017-12-20 16:42:57 -0800403 const sp<GraphicBuffer>& buffer, int acquireFence) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800404 Error setLayerSurfaceDamage(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800405 const std::vector<IComposerClient::Rect>& damage) override;
406 Error setLayerBlendMode(Display display, Layer layer, IComposerClient::BlendMode mode) override;
407 Error setLayerColor(Display display, Layer layer, const IComposerClient::Color& color) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800408 Error setLayerCompositionType(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800409 IComposerClient::Composition type) override;
410 Error setLayerDataspace(Display display, Layer layer, Dataspace dataspace) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800411 Error setLayerDisplayFrame(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800412 const IComposerClient::Rect& frame) override;
413 Error setLayerPlaneAlpha(Display display, Layer layer, float alpha) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800414 Error setLayerSidebandStream(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800415 const native_handle_t* stream) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800416 Error setLayerSourceCrop(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800417 const IComposerClient::FRect& crop) override;
418 Error setLayerTransform(Display display, Layer layer, Transform transform) override;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800419 Error setLayerVisibleRegion(Display display, Layer layer,
Lloyd Piquea822d522017-12-20 16:42:57 -0800420 const std::vector<IComposerClient::Rect>& visible) override;
421 Error setLayerZOrder(Display display, Layer layer, uint32_t z) override;
Lloyd Piquea822d522017-12-20 16:42:57 -0800422
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700423 // Composer HAL 2.2
Peiyong Lin0ac5f4e2018-04-19 22:06:34 -0700424 Error setLayerPerFrameMetadata(
425 Display display, Layer layer,
426 const std::vector<IComposerClient::PerFrameMetadata>& perFrameMetadatas) override;
Chia-I Wud7e01d72018-06-21 13:39:09 +0800427 std::vector<IComposerClient::PerFrameMetadataKey> getPerFrameMetadataKeys(
428 Display display) override;
Peiyong Lin0e7a7912018-04-05 14:36:36 -0700429 Error getRenderIntents(Display display, ColorMode colorMode,
430 std::vector<RenderIntent>* outRenderIntents) override;
431 Error getDataspaceSaturationMatrix(Dataspace dataspace, mat4* outMatrix) override;
432
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -0700433 // Composer HAL 2.3
434 Error getDisplayIdentificationData(Display display, uint8_t* outPort,
435 std::vector<uint8_t>* outData) override;
Peiyong Lin698147a2018-09-14 13:27:18 -0700436 Error setLayerColorTransform(Display display, Layer layer, const float* matrix) override;
Kevin DuBois9c0a1762018-10-16 13:32:31 -0700437 Error getDisplayedContentSamplingAttributes(Display display, PixelFormat* outFormat,
438 Dataspace* outDataspace,
439 uint8_t* outComponentMask) override;
Kevin DuBois74e53772018-11-19 10:52:38 -0800440 Error setDisplayContentSamplingEnabled(Display display, bool enabled, uint8_t componentMask,
441 uint64_t maxFrames) override;
Kevin DuBois1d4249a2018-08-29 10:45:14 -0700442 Error getDisplayedContentSample(Display display, uint64_t maxFrames, uint64_t timestamp,
443 DisplayedFrameStats* outStats) override;
Valerie Haue9e843a2018-12-18 13:39:23 -0800444 Error setLayerPerFrameMetadataBlobs(
445 Display display, Layer layer,
446 const std::vector<IComposerClient::PerFrameMetadataBlob>& metadata) override;
Dan Gittik57e63c52019-01-18 16:37:54 +0000447 Error setDisplayBrightness(Display display, float brightness) override;
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -0700448
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700449 // Composer HAL 2.4
Ady Abraham7159f572019-10-11 11:10:18 -0700450 bool isVsyncPeriodSwitchSupported() override { return mClient_2_4 != nullptr; }
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700451 Error getDisplayCapabilities(Display display,
452 std::vector<DisplayCapability>* outCapabilities) override;
Ady Abraham7159f572019-10-11 11:10:18 -0700453 V2_4::Error getDisplayConnectionType(Display display,
454 IComposerClient::DisplayConnectionType* outType) override;
455 V2_4::Error getDisplayVsyncPeriod(Display display, VsyncPeriodNanos* outVsyncPeriod) override;
456 V2_4::Error setActiveConfigWithConstraints(
457 Display display, Config config,
458 const IComposerClient::VsyncPeriodChangeConstraints& vsyncPeriodChangeConstraints,
459 VsyncPeriodChangeTimeline* outTimeline) override;
Galia Peycheva5492cb52019-10-30 14:13:16 +0100460 V2_4::Error setAutoLowLatencyMode(Display displayId, bool on) override;
461 V2_4::Error getSupportedContentTypes(
462 Display displayId,
463 std::vector<IComposerClient::ContentType>* outSupportedContentTypes) override;
464 V2_4::Error setContentType(Display displayId,
465 IComposerClient::ContentType contentType) override;
Dan Stoza18d48cb2019-10-21 15:39:24 -0700466 V2_4::Error setLayerGenericMetadata(Display display, Layer layer, const std::string& key,
467 bool mandatory, const std::vector<uint8_t>& value) override;
468 V2_4::Error getLayerGenericMetadataKeys(
469 std::vector<IComposerClient::LayerGenericMetadataKey>* outKeys) override;
Peiyong Lindfc3f7c2020-05-07 20:15:50 -0700470 Error getClientTargetProperty(
471 Display display,
472 IComposerClient::ClientTargetProperty* outClientTargetProperty) override;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700473
Chia-I Wuaab99f52016-10-05 12:59:58 +0800474private:
mamik94e91f62019-08-19 09:11:33 -0700475 class CommandWriter : public CommandWriterBase {
476 public:
477 explicit CommandWriter(uint32_t initialMaxSize) : CommandWriterBase(initialMaxSize) {}
478 ~CommandWriter() override {}
479 };
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500480
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800481 // Many public functions above simply write a command into the command
482 // queue to batch the calls. validateDisplay and presentDisplay will call
483 // this function to execute the command queue.
484 Error execute();
485
Dominik Laskowski6231aaf2018-04-02 17:10:23 -0700486 sp<V2_1::IComposer> mComposer;
487
488 sp<V2_1::IComposerClient> mClient;
Dominik Laskowskie9ef7c42018-03-12 19:34:30 -0700489 sp<V2_2::IComposerClient> mClient_2_2;
Dominik Laskowski25a4e7d2019-09-20 14:50:10 -0700490 sp<V2_3::IComposerClient> mClient_2_3;
491 sp<IComposerClient> mClient_2_4;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800492
493 // 64KiB minus a small space for metadata such as read/write pointers
494 static constexpr size_t kWriterInitialSize =
495 64 * 1024 / sizeof(uint32_t) - 16;
Alec Mourie7cc1c22021-04-27 15:23:26 -0700496 // Max number of buffers that may be cached for a given layer
497 // We obtain this number by:
498 // 1. Tightly coupling this cache to the max size of BufferQueue
499 // 2. Adding an additional slot for the layer caching feature in SurfaceFlinger (see: Planner.h)
500 static const constexpr uint32_t kMaxLayerBufferCount = BufferQueue::NUM_BUFFER_SLOTS + 1;
Daniel Nicoara2f5f8a52016-12-20 16:11:58 -0500501 CommandWriter mWriter;
Chia-I Wucd8d7f02016-11-16 11:02:31 +0800502 CommandReader mReader;
Chia-I Wuaab99f52016-10-05 12:59:58 +0800503};
504
Lloyd Piquea822d522017-12-20 16:42:57 -0800505} // namespace impl
506
Chia-I Wuaab99f52016-10-05 12:59:58 +0800507} // namespace Hwc2
508
509} // namespace android
510
511#endif // ANDROID_SF_COMPOSER_HAL_H