blob: 514dfe2d82a7b4ac402bb00d32ab7ff996fe7eb3 [file] [log] [blame]
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2006 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
Mathias Agopian90ac7992012-02-25 18:48:35 -080017#ifndef ANDROID_GUI_ISURFACE_COMPOSER_H
18#define ANDROID_GUI_ISURFACE_COMPOSER_H
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080019
20#include <stdint.h>
21#include <sys/types.h>
22
Robert Carr866455f2019-04-02 16:28:26 -070023#include <binder/IBinder.h>
Mathias Agopianc5b2c0b2009-05-19 19:08:10 -070024#include <binder/IInterface.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080025
Marissa Wall3dad52d2019-03-22 14:03:19 -070026#include <gui/ITransactionCompletedListener.h>
27
Vishnu Nairb13bb952019-11-15 10:24:08 -080028#include <math/vec4.h>
29
Daniel Solomon42d04562019-01-20 21:03:19 -080030#include <ui/ConfigStoreTypes.h>
Kevin DuBois1d4249a2018-08-29 10:45:14 -070031#include <ui/DisplayedFrameStats.h>
Svetoslavd85084b2014-03-20 10:28:31 -070032#include <ui/FrameStats.h>
Chavi Weingarten40482ff2017-11-30 01:51:40 +000033#include <ui/GraphicBuffer.h>
Peiyong Lin9f034472018-03-28 15:29:00 -070034#include <ui/GraphicTypes.h>
Dominik Laskowski5acb2b82019-11-01 13:16:38 -070035#include <ui/PhysicalDisplayId.h>
Kevin DuBois1d4249a2018-08-29 10:45:14 -070036#include <ui/PixelFormat.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080037
Marissa Wall3dad52d2019-03-22 14:03:19 -070038#include <utils/Errors.h>
39#include <utils/RefBase.h>
40#include <utils/Timers.h>
41#include <utils/Vector.h>
42
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -080043#include <optional>
Robert Carr866455f2019-04-02 16:28:26 -070044#include <unordered_set>
Brian Anderson069b3652016-07-22 10:32:47 -070045#include <vector>
46
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080047namespace android {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080048// ----------------------------------------------------------------------------
49
Marissa Wall947d34e2019-03-29 14:03:53 -070050struct client_cache_t;
Colin Crossa2362b42016-09-26 13:48:25 -070051struct ComposerState;
52struct DisplayState;
Jesse Hall646f5412014-08-07 22:19:07 -070053struct DisplayInfo;
Lajos Molnare7bda062014-09-18 20:05:27 -070054struct DisplayStatInfo;
chaviw273171b2018-12-26 11:46:30 -080055struct InputWindowCommands;
Kalle Raitaa099a242017-01-11 11:17:29 -080056class LayerDebugInfo;
Dan Stozac4f471e2016-03-24 09:31:08 -070057class HdrCapabilities;
Mathias Agopiand0566bc2011-11-17 17:49:17 -080058class IDisplayEventConnection;
Mathias Agopian2b5dd402017-02-07 17:36:19 -080059class IGraphicBufferProducer;
60class ISurfaceComposerClient;
Dan Stoza84ab9372018-12-17 15:27:57 -080061class IRegionSamplingListener;
Dan Stozac1879002014-05-22 15:59:05 -070062class Rect;
Brian Anderson3890c392016-07-25 12:48:08 -070063enum class FrameEvent;
Mathias Agopiana67932f2011-04-20 14:20:59 -070064
Andy McFadden882e3a32013-01-08 16:06:15 -080065/*
66 * This class defines the Binder IPC interface for accessing various
67 * SurfaceFlinger features.
68 */
Mathias Agopian3165cc22012-08-08 19:42:09 -070069class ISurfaceComposer: public IInterface {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080070public:
Colin Cross17576de2016-09-26 13:07:06 -070071 DECLARE_META_INTERFACE(SurfaceComposer)
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080072
Mathias Agopian3165cc22012-08-08 19:42:09 -070073 // flags for setTransactionState()
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080074 enum {
Mathias Agopian3165cc22012-08-08 19:42:09 -070075 eSynchronous = 0x01,
Jamie Gennis2d5e2302012-10-15 18:24:43 -070076 eAnimation = 0x02,
Dan Stoza84d619e2018-03-28 17:07:36 -070077
78 // Indicates that this transaction will likely result in a lot of layers being composed, and
79 // thus, SurfaceFlinger should wake-up earlier to avoid missing frame deadlines. In this
80 // case SurfaceFlinger will wake up at (sf vsync offset - debug.sf.early_phase_offset_ns)
81 eEarlyWakeup = 0x04
Jamie Gennis28378392011-10-12 17:39:00 -070082 };
83
Riley Andrewsc3ebe662014-09-04 16:20:31 -070084 enum Rotation {
85 eRotateNone = 0,
86 eRotate90 = 1,
87 eRotate180 = 2,
88 eRotate270 = 3
89 };
90
Jorim Jaggib1e2f8d2017-06-08 15:43:59 -070091 enum VsyncSource {
92 eVsyncSourceApp = 0,
93 eVsyncSourceSurfaceFlinger = 1
94 };
95
Ady Abraham0f4a1b12019-06-04 16:04:04 -070096 enum ConfigChanged { eConfigChangedSuppress = 0, eConfigChangedDispatch = 1 };
97
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -080098 /*
Robert Carrb89ea9d2018-12-10 13:01:14 -080099 * Create a connection with SurfaceFlinger.
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800100 */
Mathias Agopian7e27f052010-05-28 14:22:23 -0700101 virtual sp<ISurfaceComposerClient> createConnection() = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800102
Mathias Agopiane57f2922012-08-09 16:29:12 -0700103 /* return an IDisplayEventConnection */
Jorim Jaggib1e2f8d2017-06-08 15:43:59 -0700104 virtual sp<IDisplayEventConnection> createDisplayEventConnection(
Ady Abraham0f4a1b12019-06-04 16:04:04 -0700105 VsyncSource vsyncSource = eVsyncSourceApp,
106 ConfigChanged configChanged = eConfigChangedSuppress) = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700107
Jesse Hall6c913be2013-08-08 12:15:49 -0700108 /* create a virtual display
Mathias Agopiane57f2922012-08-09 16:29:12 -0700109 * requires ACCESS_SURFACE_FLINGER permission.
110 */
Jamie Gennisdd3cb842012-10-19 18:19:11 -0700111 virtual sp<IBinder> createDisplay(const String8& displayName,
112 bool secure) = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700113
Jesse Hall6c913be2013-08-08 12:15:49 -0700114 /* destroy a virtual display
115 * requires ACCESS_SURFACE_FLINGER permission.
116 */
117 virtual void destroyDisplay(const sp<IBinder>& display) = 0;
118
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800119 /* get stable IDs for connected physical displays.
Mathias Agopiane57f2922012-08-09 16:29:12 -0700120 */
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800121 virtual std::vector<PhysicalDisplayId> getPhysicalDisplayIds() const = 0;
122
123 // TODO(b/74619554): Remove this stopgap once the framework is display-agnostic.
124 std::optional<PhysicalDisplayId> getInternalDisplayId() const {
125 const auto displayIds = getPhysicalDisplayIds();
126 return displayIds.empty() ? std::nullopt : std::make_optional(displayIds.front());
127 }
128
129 /* get token for a physical display given its stable ID obtained via getPhysicalDisplayIds or a
130 * DisplayEventReceiver hotplug event.
131 */
132 virtual sp<IBinder> getPhysicalDisplayToken(PhysicalDisplayId displayId) const = 0;
133
134 // TODO(b/74619554): Remove this stopgap once the framework is display-agnostic.
135 sp<IBinder> getInternalDisplayToken() const {
136 const auto displayId = getInternalDisplayId();
137 return displayId ? getPhysicalDisplayToken(*displayId) : nullptr;
138 }
Mathias Agopiane57f2922012-08-09 16:29:12 -0700139
Mathias Agopian9cce3252010-02-09 17:46:37 -0800140 /* open/close transactions. requires ACCESS_SURFACE_FLINGER permission */
Mathias Agopian3165cc22012-08-08 19:42:09 -0700141 virtual void setTransactionState(const Vector<ComposerState>& state,
Marissa Wall713b63f2018-10-17 15:42:43 -0700142 const Vector<DisplayState>& displays, uint32_t flags,
chaviw273171b2018-12-26 11:46:30 -0800143 const sp<IBinder>& applyToken,
Marissa Wall17b4e452018-12-26 16:32:34 -0800144 const InputWindowCommands& inputWindowCommands,
Marissa Wall78b72202019-03-15 14:58:34 -0700145 int64_t desiredPresentTime,
Valerie Hau9dab9732019-08-20 09:29:25 -0700146 const client_cache_t& uncacheBuffer, bool hasListenerCallbacks,
Marissa Wall3dad52d2019-03-22 14:03:19 -0700147 const std::vector<ListenerCallbacks>& listenerCallbacks) = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800148
149 /* signal that we're done booting.
Mathias Agopian9cce3252010-02-09 17:46:37 -0800150 * Requires ACCESS_SURFACE_FLINGER permission
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800151 */
152 virtual void bootFinished() = 0;
153
Andy McFadden2adaf042012-12-18 09:49:45 -0800154 /* verify that an IGraphicBufferProducer was created by SurfaceFlinger.
Mathias Agopiane57f2922012-08-09 16:29:12 -0700155 */
156 virtual bool authenticateSurfaceTexture(
Andy McFadden2adaf042012-12-18 09:49:45 -0800157 const sp<IGraphicBufferProducer>& surface) const = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700158
Brian Anderson6b376712017-04-04 10:51:39 -0700159 /* Returns the frame timestamps supported by SurfaceFlinger.
160 */
161 virtual status_t getSupportedFrameTimestamps(
162 std::vector<FrameEvent>* outSupported) const = 0;
163
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700164 /* set display power mode. depending on the mode, it can either trigger
165 * screen on, off or low power mode and wait for it to complete.
Mathias Agopian041a0752013-03-15 18:31:56 -0700166 * requires ACCESS_SURFACE_FLINGER permission.
167 */
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700168 virtual void setPowerMode(const sp<IBinder>& display, int mode) = 0;
Mathias Agopian3094df32012-06-18 18:06:45 -0700169
Dan Stoza7f7da322014-05-02 15:26:25 -0700170 /* returns information for each configuration of the given display
Jeff Brown9d4e3d22012-08-24 20:00:51 -0700171 * intended to be used to get information about built-in displays */
Dan Stoza7f7da322014-05-02 15:26:25 -0700172 virtual status_t getDisplayConfigs(const sp<IBinder>& display,
173 Vector<DisplayInfo>* configs) = 0;
174
Lajos Molnar67d8bd62014-09-11 14:58:45 -0700175 /* returns display statistics for a given display
176 * intended to be used by the media framework to properly schedule
177 * video frames */
178 virtual status_t getDisplayStats(const sp<IBinder>& display,
179 DisplayStatInfo* stats) = 0;
180
Dan Stoza7f7da322014-05-02 15:26:25 -0700181 /* indicates which of the configurations returned by getDisplayInfo is
182 * currently active */
183 virtual int getActiveConfig(const sp<IBinder>& display) = 0;
184
185 /* specifies which configuration (of those returned by getDisplayInfo)
186 * should be used */
187 virtual status_t setActiveConfig(const sp<IBinder>& display, int id) = 0;
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800188
Michael Wright28f24d02016-07-12 13:30:53 -0700189 virtual status_t getDisplayColorModes(const sp<IBinder>& display,
Peiyong Lin9f034472018-03-28 15:29:00 -0700190 Vector<ui::ColorMode>* outColorModes) = 0;
Daniel Solomon42d04562019-01-20 21:03:19 -0800191 virtual status_t getDisplayNativePrimaries(const sp<IBinder>& display,
192 ui::DisplayPrimaries& primaries) = 0;
Peiyong Lin9f034472018-03-28 15:29:00 -0700193 virtual ui::ColorMode getActiveColorMode(const sp<IBinder>& display) = 0;
Michael Wright28f24d02016-07-12 13:30:53 -0700194 virtual status_t setActiveColorMode(const sp<IBinder>& display,
Peiyong Lin9f034472018-03-28 15:29:00 -0700195 ui::ColorMode colorMode) = 0;
Michael Wright28f24d02016-07-12 13:30:53 -0700196
Chia-I Wuff79ef82018-08-22 15:27:32 -0700197 /**
198 * Capture the specified screen. This requires READ_FRAME_BUFFER
199 * permission. This function will fail if there is a secure window on
200 * screen.
201 *
202 * This function can capture a subregion (the source crop) of the screen.
203 * The subregion can be optionally rotated. It will also be scaled to
204 * match the size of the output buffer.
205 *
Peiyong Lin0e003c92018-09-17 11:09:51 -0700206 * reqDataspace and reqPixelFormat specify the data space and pixel format
207 * of the buffer. The caller should pick the data space and pixel format
208 * that it can consume.
209 *
Yiwei Zhang11a7dbe2019-03-21 00:03:14 -0700210 * sourceCrop is the crop on the logical display.
Peiyong Lin0e003c92018-09-17 11:09:51 -0700211 *
212 * reqWidth and reqHeight specifies the size of the buffer. When either
213 * of them is 0, they are set to the size of the logical display viewport.
214 *
215 * When useIdentityTransform is true, layer transformations are disabled.
216 *
217 * rotation specifies the rotation of the source crop (and the pixels in
218 * it) around its center.
219 */
220 virtual status_t captureScreen(const sp<IBinder>& display, sp<GraphicBuffer>* outBuffer,
Robert Carr108b2c72019-04-02 16:32:58 -0700221 bool& outCapturedSecureLayers, const ui::Dataspace reqDataspace,
Peiyong Lin0e003c92018-09-17 11:09:51 -0700222 const ui::PixelFormat reqPixelFormat, Rect sourceCrop,
223 uint32_t reqWidth, uint32_t reqHeight, bool useIdentityTransform,
Robert Carrfa8855f2019-02-19 10:05:00 -0800224 Rotation rotation = eRotateNone,
225 bool captureSecureLayers = false) = 0;
Peiyong Lin0e003c92018-09-17 11:09:51 -0700226 /**
227 * Capture the specified screen. This requires READ_FRAME_BUFFER
228 * permission. This function will fail if there is a secure window on
229 * screen.
230 *
231 * This function can capture a subregion (the source crop) of the screen
232 * into an sRGB buffer with RGBA_8888 pixel format.
233 * The subregion can be optionally rotated. It will also be scaled to
234 * match the size of the output buffer.
235 *
Chia-I Wuff79ef82018-08-22 15:27:32 -0700236 * At the moment, sourceCrop is ignored and is always set to the visible
237 * region (projected display viewport) of the screen.
238 *
239 * reqWidth and reqHeight specifies the size of the buffer. When either
240 * of them is 0, they are set to the size of the logical display viewport.
241 *
242 * When useIdentityTransform is true, layer transformations are disabled.
243 *
244 * rotation specifies the rotation of the source crop (and the pixels in
245 * it) around its center.
Mathias Agopian041a0752013-03-15 18:31:56 -0700246 */
Chavi Weingarten40482ff2017-11-30 01:51:40 +0000247 virtual status_t captureScreen(const sp<IBinder>& display, sp<GraphicBuffer>* outBuffer,
248 Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight,
Peiyong Lin0e003c92018-09-17 11:09:51 -0700249 bool useIdentityTransform, Rotation rotation = eRotateNone) {
Robert Carr108b2c72019-04-02 16:32:58 -0700250 bool outIgnored;
251 return captureScreen(display, outBuffer, outIgnored, ui::Dataspace::V0_SRGB,
252 ui::PixelFormat::RGBA_8888, sourceCrop, reqWidth, reqHeight,
253 useIdentityTransform, rotation);
Peiyong Lin0e003c92018-09-17 11:09:51 -0700254 }
Svetoslavd85084b2014-03-20 10:28:31 -0700255
chaviw93df2ea2019-04-30 16:45:12 -0700256 virtual status_t captureScreen(uint64_t displayOrLayerStack, ui::Dataspace* outDataspace,
257 sp<GraphicBuffer>* outBuffer) = 0;
258
Robert Carr866455f2019-04-02 16:28:26 -0700259 template <class AA>
260 struct SpHash {
261 size_t operator()(const sp<AA>& k) const { return std::hash<AA*>()(k.get()); }
262 };
263
Robert Carr578038f2018-03-09 12:25:24 -0800264 /**
265 * Capture a subtree of the layer hierarchy, potentially ignoring the root node.
Peiyong Lin0e003c92018-09-17 11:09:51 -0700266 *
267 * reqDataspace and reqPixelFormat specify the data space and pixel format
268 * of the buffer. The caller should pick the data space and pixel format
269 * that it can consume.
Robert Carr578038f2018-03-09 12:25:24 -0800270 */
Robert Carr866455f2019-04-02 16:28:26 -0700271 virtual status_t captureLayers(
272 const sp<IBinder>& layerHandleBinder, sp<GraphicBuffer>* outBuffer,
273 const ui::Dataspace reqDataspace, const ui::PixelFormat reqPixelFormat,
274 const Rect& sourceCrop,
275 const std::unordered_set<sp<IBinder>, SpHash<IBinder>>& excludeHandles,
276 float frameScale = 1.0, bool childrenOnly = false) = 0;
chaviwa76b2712017-09-20 12:02:26 -0700277
Peiyong Lin0e003c92018-09-17 11:09:51 -0700278 /**
279 * Capture a subtree of the layer hierarchy into an sRGB buffer with RGBA_8888 pixel format,
280 * potentially ignoring the root node.
281 */
282 status_t captureLayers(const sp<IBinder>& layerHandleBinder, sp<GraphicBuffer>* outBuffer,
283 const Rect& sourceCrop, float frameScale = 1.0,
284 bool childrenOnly = false) {
285 return captureLayers(layerHandleBinder, outBuffer, ui::Dataspace::V0_SRGB,
Robert Carr866455f2019-04-02 16:28:26 -0700286 ui::PixelFormat::RGBA_8888, sourceCrop, {}, frameScale, childrenOnly);
Peiyong Lin0e003c92018-09-17 11:09:51 -0700287 }
288
Svetoslavd85084b2014-03-20 10:28:31 -0700289 /* Clears the frame statistics for animations.
290 *
291 * Requires the ACCESS_SURFACE_FLINGER permission.
292 */
293 virtual status_t clearAnimationFrameStats() = 0;
294
295 /* Gets the frame statistics for animations.
296 *
297 * Requires the ACCESS_SURFACE_FLINGER permission.
298 */
299 virtual status_t getAnimationFrameStats(FrameStats* outStats) const = 0;
Dan Stozac4f471e2016-03-24 09:31:08 -0700300
301 /* Gets the supported HDR capabilities of the given display.
302 *
303 * Requires the ACCESS_SURFACE_FLINGER permission.
304 */
305 virtual status_t getHdrCapabilities(const sp<IBinder>& display,
306 HdrCapabilities* outCapabilities) const = 0;
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -0700307
308 virtual status_t enableVSyncInjections(bool enable) = 0;
309
310 virtual status_t injectVSync(nsecs_t when) = 0;
Kalle Raitaa099a242017-01-11 11:17:29 -0800311
312 /* Gets the list of active layers in Z order for debugging purposes
313 *
314 * Requires the ACCESS_SURFACE_FLINGER permission.
315 */
316 virtual status_t getLayerDebugInfo(std::vector<LayerDebugInfo>* outLayers) const = 0;
Peiyong Lin0256f722018-08-31 15:45:10 -0700317
Ady Abraham37965d42018-11-01 13:43:32 -0700318 virtual status_t getColorManagement(bool* outGetColorManagement) const = 0;
Peiyong Linc6780972018-10-28 15:24:08 -0700319
320 /* Gets the composition preference of the default data space and default pixel format,
321 * as well as the wide color gamut data space and wide color gamut pixel format.
322 * If the wide color gamut data space is V0_SRGB, then it implies that the platform
323 * has no wide color gamut support.
324 *
325 * Requires the ACCESS_SURFACE_FLINGER permission.
326 */
327 virtual status_t getCompositionPreference(ui::Dataspace* defaultDataspace,
328 ui::PixelFormat* defaultPixelFormat,
329 ui::Dataspace* wideColorGamutDataspace,
330 ui::PixelFormat* wideColorGamutPixelFormat) const = 0;
Kevin DuBois9c0a1762018-10-16 13:32:31 -0700331 /*
332 * Requires the ACCESS_SURFACE_FLINGER permission.
333 */
334 virtual status_t getDisplayedContentSamplingAttributes(const sp<IBinder>& display,
335 ui::PixelFormat* outFormat,
336 ui::Dataspace* outDataspace,
337 uint8_t* outComponentMask) const = 0;
Kevin DuBois74e53772018-11-19 10:52:38 -0800338
339 /* Turns on the color sampling engine on the display.
340 *
341 * Requires the ACCESS_SURFACE_FLINGER permission.
342 */
343 virtual status_t setDisplayContentSamplingEnabled(const sp<IBinder>& display, bool enable,
344 uint8_t componentMask,
345 uint64_t maxFrames) const = 0;
Kevin DuBois1d4249a2018-08-29 10:45:14 -0700346
347 /* Returns statistics on the color profile of the last frame displayed for a given display
348 *
349 * Requires the ACCESS_SURFACE_FLINGER permission.
350 */
351 virtual status_t getDisplayedContentSample(const sp<IBinder>& display, uint64_t maxFrames,
352 uint64_t timestamp,
353 DisplayedFrameStats* outStats) const = 0;
Peiyong Lin3c2791e2019-01-14 17:05:18 -0800354
355 /*
356 * Gets whether SurfaceFlinger can support protected content in GPU composition.
357 * Requires the ACCESS_SURFACE_FLINGER permission.
358 */
359 virtual status_t getProtectedContentSupport(bool* outSupported) const = 0;
Marissa Wallebc2c052019-01-16 19:16:55 -0800360
Peiyong Lin4f3fddf2019-01-24 17:21:24 -0800361 /*
362 * Queries whether the given display is a wide color display.
363 * Requires the ACCESS_SURFACE_FLINGER permission.
364 */
365 virtual status_t isWideColorDisplay(const sp<IBinder>& token,
366 bool* outIsWideColorDisplay) const = 0;
Dan Stoza84ab9372018-12-17 15:27:57 -0800367
368 /* Registers a listener to stream median luma updates from SurfaceFlinger.
369 *
370 * The sampling area is bounded by both samplingArea and the given stopLayerHandle
371 * (i.e., only layers behind the stop layer will be captured and sampled).
372 *
373 * Multiple listeners may be provided so long as they have independent listeners.
374 * If multiple listeners are provided, the effective sampling region for each listener will
375 * be bounded by whichever stop layer has a lower Z value.
376 *
377 * Requires the same permissions as captureLayers and captureScreen.
378 */
379 virtual status_t addRegionSamplingListener(const Rect& samplingArea,
380 const sp<IBinder>& stopLayerHandle,
381 const sp<IRegionSamplingListener>& listener) = 0;
382
383 /*
384 * Removes a listener that was streaming median luma updates from SurfaceFlinger.
385 */
386 virtual status_t removeRegionSamplingListener(const sp<IRegionSamplingListener>& listener) = 0;
Ady Abraham838de062019-02-04 10:24:03 -0800387
388 /*
389 * Sets the allowed display configurations to be used.
390 * The allowedConfigs in a vector of indexes corresponding to the configurations
391 * returned from getDisplayConfigs().
392 */
393 virtual status_t setAllowedDisplayConfigs(const sp<IBinder>& displayToken,
394 const std::vector<int32_t>& allowedConfigs) = 0;
Ady Abrahamd9b3ea62019-02-26 14:08:03 -0800395
396 /*
397 * Returns the allowed display configurations currently set.
398 * The allowedConfigs in a vector of indexes corresponding to the configurations
399 * returned from getDisplayConfigs().
400 */
401 virtual status_t getAllowedDisplayConfigs(const sp<IBinder>& displayToken,
402 std::vector<int32_t>* outAllowedConfigs) = 0;
Dan Gittik57e63c52019-01-18 16:37:54 +0000403 /*
404 * Gets whether brightness operations are supported on a display.
405 *
406 * displayToken
407 * The token of the display.
408 * outSupport
409 * An output parameter for whether brightness operations are supported.
410 *
411 * Returns NO_ERROR upon success. Otherwise,
412 * NAME_NOT_FOUND if the display is invalid, or
413 * BAD_VALUE if the output parameter is invalid.
414 */
415 virtual status_t getDisplayBrightnessSupport(const sp<IBinder>& displayToken,
416 bool* outSupport) const = 0;
417
418 /*
419 * Sets the brightness of a display.
420 *
421 * displayToken
422 * The token of the display whose brightness is set.
423 * brightness
424 * A number between 0.0f (minimum brightness) and 1.0 (maximum brightness), or -1.0f to
425 * turn the backlight off.
426 *
427 * Returns NO_ERROR upon success. Otherwise,
428 * NAME_NOT_FOUND if the display is invalid, or
429 * BAD_VALUE if the brightness is invalid, or
430 * INVALID_OPERATION if brightness operations are not supported.
431 */
432 virtual status_t setDisplayBrightness(const sp<IBinder>& displayToken,
433 float brightness) const = 0;
Ady Abraham8532d012019-05-08 14:50:56 -0700434
435 /*
436 * Sends a power hint to the composer. This function is asynchronous.
437 *
438 * hintId
439 * hint id according to android::hardware::power::V1_0::PowerHint
440 *
441 * Returns NO_ERROR upon success.
442 */
443 virtual status_t notifyPowerHint(int32_t hintId) = 0;
Vishnu Nairb13bb952019-11-15 10:24:08 -0800444
445 /*
446 * Sets the global configuration for all the shadows drawn by SurfaceFlinger. Shadow follows
447 * material design guidelines.
448 *
449 * ambientColor
450 * Color to the ambient shadow. The alpha is premultiplied.
451 *
452 * spotColor
453 * Color to the spot shadow. The alpha is premultiplied. The position of the spot shadow
454 * depends on the light position.
455 *
456 * lightPosY/lightPosZ
457 * Position of the light used to cast the spot shadow. The X value is always the display
458 * width / 2.
459 *
460 * lightRadius
461 * Radius of the light casting the shadow.
462 */
463 virtual status_t setGlobalShadowSettings(const half4& ambientColor, const half4& spotColor,
464 float lightPosY, float lightPosZ,
465 float lightRadius) = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800466};
467
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800468// ----------------------------------------------------------------------------
469
Mathias Agopian3165cc22012-08-08 19:42:09 -0700470class BnSurfaceComposer: public BnInterface<ISurfaceComposer> {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800471public:
Ana Krulec13be8ad2018-08-21 02:43:56 +0000472 enum ISurfaceComposerTag {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800473 // Note: BOOT_FINISHED must remain this value, it is called from
474 // Java by ActivityManagerService.
475 BOOT_FINISHED = IBinder::FIRST_CALL_TRANSACTION,
476 CREATE_CONNECTION,
Ana Krulec13be8ad2018-08-21 02:43:56 +0000477 CREATE_GRAPHIC_BUFFER_ALLOC_UNUSED, // unused, fails permissions check
Mathias Agopiand0566bc2011-11-17 17:49:17 -0800478 CREATE_DISPLAY_EVENT_CONNECTION,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700479 CREATE_DISPLAY,
Jesse Hall6c913be2013-08-08 12:15:49 -0700480 DESTROY_DISPLAY,
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800481 GET_PHYSICAL_DISPLAY_TOKEN,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700482 SET_TRANSACTION_STATE,
483 AUTHENTICATE_SURFACE,
Brian Anderson069b3652016-07-22 10:32:47 -0700484 GET_SUPPORTED_FRAME_TIMESTAMPS,
Dan Stoza7f7da322014-05-02 15:26:25 -0700485 GET_DISPLAY_CONFIGS,
486 GET_ACTIVE_CONFIG,
487 SET_ACTIVE_CONFIG,
Ana Krulec13be8ad2018-08-21 02:43:56 +0000488 CONNECT_DISPLAY_UNUSED, // unused, fails permissions check
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800489 CAPTURE_SCREEN,
chaviwa76b2712017-09-20 12:02:26 -0700490 CAPTURE_LAYERS,
Svetoslavd85084b2014-03-20 10:28:31 -0700491 CLEAR_ANIMATION_FRAME_STATS,
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700492 GET_ANIMATION_FRAME_STATS,
493 SET_POWER_MODE,
Lajos Molnar67d8bd62014-09-11 14:58:45 -0700494 GET_DISPLAY_STATS,
Dan Stozac4f471e2016-03-24 09:31:08 -0700495 GET_HDR_CAPABILITIES,
Michael Wright28f24d02016-07-12 13:30:53 -0700496 GET_DISPLAY_COLOR_MODES,
497 GET_ACTIVE_COLOR_MODE,
498 SET_ACTIVE_COLOR_MODE,
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -0700499 ENABLE_VSYNC_INJECTIONS,
Robert Carr1db73f62016-12-21 12:58:51 -0800500 INJECT_VSYNC,
Kalle Raitaa099a242017-01-11 11:17:29 -0800501 GET_LAYER_DEBUG_INFO,
Peiyong Lin0256f722018-08-31 15:45:10 -0700502 GET_COMPOSITION_PREFERENCE,
Ady Abraham37965d42018-11-01 13:43:32 -0700503 GET_COLOR_MANAGEMENT,
Kevin DuBois9c0a1762018-10-16 13:32:31 -0700504 GET_DISPLAYED_CONTENT_SAMPLING_ATTRIBUTES,
Kevin DuBois74e53772018-11-19 10:52:38 -0800505 SET_DISPLAY_CONTENT_SAMPLING_ENABLED,
Kevin DuBois1d4249a2018-08-29 10:45:14 -0700506 GET_DISPLAYED_CONTENT_SAMPLE,
Peiyong Lin3c2791e2019-01-14 17:05:18 -0800507 GET_PROTECTED_CONTENT_SUPPORT,
Peiyong Lin4f3fddf2019-01-24 17:21:24 -0800508 IS_WIDE_COLOR_DISPLAY,
Daniel Solomon42d04562019-01-20 21:03:19 -0800509 GET_DISPLAY_NATIVE_PRIMARIES,
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800510 GET_PHYSICAL_DISPLAY_IDS,
Dan Stoza84ab9372018-12-17 15:27:57 -0800511 ADD_REGION_SAMPLING_LISTENER,
512 REMOVE_REGION_SAMPLING_LISTENER,
Ady Abraham838de062019-02-04 10:24:03 -0800513 SET_ALLOWED_DISPLAY_CONFIGS,
Ady Abrahamd9b3ea62019-02-26 14:08:03 -0800514 GET_ALLOWED_DISPLAY_CONFIGS,
Dan Gittik57e63c52019-01-18 16:37:54 +0000515 GET_DISPLAY_BRIGHTNESS_SUPPORT,
516 SET_DISPLAY_BRIGHTNESS,
chaviw93df2ea2019-04-30 16:45:12 -0700517 CAPTURE_SCREEN_BY_ID,
Ady Abraham8532d012019-05-08 14:50:56 -0700518 NOTIFY_POWER_HINT,
Vishnu Nairb13bb952019-11-15 10:24:08 -0800519 SET_GLOBAL_SHADOW_SETTINGS,
Peiyong Lin4f3fddf2019-01-24 17:21:24 -0800520 // Always append new enum to the end.
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800521 };
522
Mathias Agopian3165cc22012-08-08 19:42:09 -0700523 virtual status_t onTransact(uint32_t code, const Parcel& data,
524 Parcel* reply, uint32_t flags = 0);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800525};
526
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800527// ----------------------------------------------------------------------------
528
529}; // namespace android
530
Mathias Agopian90ac7992012-02-25 18:48:35 -0800531#endif // ANDROID_GUI_ISURFACE_COMPOSER_H