blob: 40316dbeea511a57c554fd9e112b3d3fb80dc0ef [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
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -080017#pragma once
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080018
19#include <stdint.h>
20#include <sys/types.h>
21
Robert Carr866455f2019-04-02 16:28:26 -070022#include <binder/IBinder.h>
Mathias Agopianc5b2c0b2009-05-19 19:08:10 -070023#include <binder/IInterface.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080024
Pablo Gamito6ee484d2020-07-30 14:26:28 +000025#include <android/gui/ITransactionTraceListener.h>
chaviw8ffc7b82020-08-18 11:25:37 -070026#include <gui/IScreenCaptureListener.h>
Marissa Wall3dad52d2019-03-22 14:03:19 -070027#include <gui/ITransactionCompletedListener.h>
28
Ady Abraham62f216c2020-10-13 19:07:23 -070029#include <input/Flags.h>
30
Vishnu Nairb13bb952019-11-15 10:24:08 -080031#include <math/vec4.h>
32
Daniel Solomon42d04562019-01-20 21:03:19 -080033#include <ui/ConfigStoreTypes.h>
Marin Shalamanova524a092020-07-27 21:39:55 +020034#include <ui/DisplayId.h>
Kevin DuBois1d4249a2018-08-29 10:45:14 -070035#include <ui/DisplayedFrameStats.h>
Svetoslavd85084b2014-03-20 10:28:31 -070036#include <ui/FrameStats.h>
Chavi Weingarten40482ff2017-11-30 01:51:40 +000037#include <ui/GraphicBuffer.h>
Peiyong Lin9f034472018-03-28 15:29:00 -070038#include <ui/GraphicTypes.h>
Kevin DuBois1d4249a2018-08-29 10:45:14 -070039#include <ui/PixelFormat.h>
Dominik Laskowski718f9602019-11-09 20:01:35 -080040#include <ui/Rotation.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080041
Marissa Wall3dad52d2019-03-22 14:03:19 -070042#include <utils/Errors.h>
43#include <utils/RefBase.h>
44#include <utils/Timers.h>
45#include <utils/Vector.h>
46
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -080047#include <optional>
Robert Carr866455f2019-04-02 16:28:26 -070048#include <unordered_set>
Brian Anderson069b3652016-07-22 10:32:47 -070049#include <vector>
50
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080051namespace android {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080052
Marissa Wall947d34e2019-03-29 14:03:53 -070053struct client_cache_t;
Colin Crossa2362b42016-09-26 13:48:25 -070054struct ComposerState;
chaviwd2432892020-07-24 17:42:39 -070055struct DisplayCaptureArgs;
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -080056struct DisplayConfig;
Jesse Hall646f5412014-08-07 22:19:07 -070057struct DisplayInfo;
Lajos Molnare7bda062014-09-18 20:05:27 -070058struct DisplayStatInfo;
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -080059struct DisplayState;
chaviw273171b2018-12-26 11:46:30 -080060struct InputWindowCommands;
chaviwd2432892020-07-24 17:42:39 -070061struct LayerCaptureArgs;
62struct ScreenCaptureResults;
Kalle Raitaa099a242017-01-11 11:17:29 -080063class LayerDebugInfo;
Dan Stozac4f471e2016-03-24 09:31:08 -070064class HdrCapabilities;
Mathias Agopiand0566bc2011-11-17 17:49:17 -080065class IDisplayEventConnection;
Mathias Agopian2b5dd402017-02-07 17:36:19 -080066class IGraphicBufferProducer;
67class ISurfaceComposerClient;
Dan Stoza84ab9372018-12-17 15:27:57 -080068class IRegionSamplingListener;
Dan Stozac1879002014-05-22 15:59:05 -070069class Rect;
Brian Anderson3890c392016-07-25 12:48:08 -070070enum class FrameEvent;
Mathias Agopiana67932f2011-04-20 14:20:59 -070071
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -080072namespace ui {
73
74struct DisplayState;
75
76} // namespace ui
77
Andy McFadden882e3a32013-01-08 16:06:15 -080078/*
79 * This class defines the Binder IPC interface for accessing various
80 * SurfaceFlinger features.
81 */
Mathias Agopian3165cc22012-08-08 19:42:09 -070082class ISurfaceComposer: public IInterface {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080083public:
Colin Cross17576de2016-09-26 13:07:06 -070084 DECLARE_META_INTERFACE(SurfaceComposer)
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080085
Ady Abraham0a525092020-03-03 12:51:24 -080086 static constexpr size_t MAX_LAYERS = 4096;
87
Mathias Agopian3165cc22012-08-08 19:42:09 -070088 // flags for setTransactionState()
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080089 enum {
Mathias Agopian3165cc22012-08-08 19:42:09 -070090 eSynchronous = 0x01,
Ady Abrahambf1349c2020-06-12 14:26:18 -070091 eAnimation = 0x02,
Dan Stoza84d619e2018-03-28 17:07:36 -070092
Ady Abrahambf1349c2020-06-12 14:26:18 -070093 // DEPRECATED - use eExplicitEarlyWakeup[Start|End]
94 eEarlyWakeup = 0x04,
95
96 // Explicit indication that this transaction and others to follow will likely result in a
97 // lot of layers being composed, and thus, SurfaceFlinger should wake-up earlier to avoid
98 // missing frame deadlines. In this case SurfaceFlinger will wake up at
99 // (sf vsync offset - debug.sf.early_phase_offset_ns). SurfaceFlinger will continue to be
100 // in the early configuration until it receives eExplicitEarlyWakeupEnd. These flags are
101 // expected to be used by WindowManager only and are guarded by
102 // android.permission.ACCESS_SURFACE_FLINGER
103 eExplicitEarlyWakeupStart = 0x08,
104 eExplicitEarlyWakeupEnd = 0x10,
Jamie Gennis28378392011-10-12 17:39:00 -0700105 };
106
Jorim Jaggib1e2f8d2017-06-08 15:43:59 -0700107 enum VsyncSource {
108 eVsyncSourceApp = 0,
109 eVsyncSourceSurfaceFlinger = 1
110 };
111
Ady Abraham62f216c2020-10-13 19:07:23 -0700112 enum class EventRegistration {
113 configChanged = 1 << 0,
114 frameRateOverride = 1 << 1,
115 };
116
117 using EventRegistrationFlags = Flags<EventRegistration>;
Ady Abraham0f4a1b12019-06-04 16:04:04 -0700118
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700119 // Needs to be in sync with android.graphics.FrameInfo.INVALID_VSYNC_ID in java
120 static constexpr int64_t INVALID_VSYNC_ID = -1;
121
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800122 /*
Robert Carrb89ea9d2018-12-10 13:01:14 -0800123 * Create a connection with SurfaceFlinger.
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800124 */
Mathias Agopian7e27f052010-05-28 14:22:23 -0700125 virtual sp<ISurfaceComposerClient> createConnection() = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800126
Mathias Agopiane57f2922012-08-09 16:29:12 -0700127 /* return an IDisplayEventConnection */
Jorim Jaggib1e2f8d2017-06-08 15:43:59 -0700128 virtual sp<IDisplayEventConnection> createDisplayEventConnection(
Ady Abraham0f4a1b12019-06-04 16:04:04 -0700129 VsyncSource vsyncSource = eVsyncSourceApp,
Ady Abraham62f216c2020-10-13 19:07:23 -0700130 EventRegistrationFlags eventRegistration = {}) = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700131
Jesse Hall6c913be2013-08-08 12:15:49 -0700132 /* create a virtual display
Mathias Agopiane57f2922012-08-09 16:29:12 -0700133 * requires ACCESS_SURFACE_FLINGER permission.
134 */
Jamie Gennisdd3cb842012-10-19 18:19:11 -0700135 virtual sp<IBinder> createDisplay(const String8& displayName,
136 bool secure) = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700137
Jesse Hall6c913be2013-08-08 12:15:49 -0700138 /* destroy a virtual display
139 * requires ACCESS_SURFACE_FLINGER permission.
140 */
141 virtual void destroyDisplay(const sp<IBinder>& display) = 0;
142
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800143 /* get stable IDs for connected physical displays.
Mathias Agopiane57f2922012-08-09 16:29:12 -0700144 */
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800145 virtual std::vector<PhysicalDisplayId> getPhysicalDisplayIds() const = 0;
146
147 // TODO(b/74619554): Remove this stopgap once the framework is display-agnostic.
148 std::optional<PhysicalDisplayId> getInternalDisplayId() const {
149 const auto displayIds = getPhysicalDisplayIds();
150 return displayIds.empty() ? std::nullopt : std::make_optional(displayIds.front());
151 }
152
153 /* get token for a physical display given its stable ID obtained via getPhysicalDisplayIds or a
154 * DisplayEventReceiver hotplug event.
155 */
156 virtual sp<IBinder> getPhysicalDisplayToken(PhysicalDisplayId displayId) const = 0;
157
158 // TODO(b/74619554): Remove this stopgap once the framework is display-agnostic.
159 sp<IBinder> getInternalDisplayToken() const {
160 const auto displayId = getInternalDisplayId();
161 return displayId ? getPhysicalDisplayToken(*displayId) : nullptr;
162 }
Mathias Agopiane57f2922012-08-09 16:29:12 -0700163
Mathias Agopian9cce3252010-02-09 17:46:37 -0800164 /* open/close transactions. requires ACCESS_SURFACE_FLINGER permission */
chaviw308ddba2020-08-11 16:23:51 -0700165 virtual status_t setTransactionState(
Ady Abraham22c7b5c2020-09-22 19:33:40 -0700166 int64_t frameTimelineVsyncId, const Vector<ComposerState>& state,
167 const Vector<DisplayState>& displays, uint32_t flags, const sp<IBinder>& applyToken,
chaviw308ddba2020-08-11 16:23:51 -0700168 const InputWindowCommands& inputWindowCommands, int64_t desiredPresentTime,
Ady Abrahamf0c56492020-12-17 18:04:15 -0800169 bool isAutoTimestamp, const client_cache_t& uncacheBuffer, bool hasListenerCallbacks,
Pablo Gamito7eb7ee72020-08-05 10:57:05 +0000170 const std::vector<ListenerCallbacks>& listenerCallbacks, uint64_t transactionId) = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800171
172 /* signal that we're done booting.
Mathias Agopian9cce3252010-02-09 17:46:37 -0800173 * Requires ACCESS_SURFACE_FLINGER permission
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800174 */
175 virtual void bootFinished() = 0;
176
Andy McFadden2adaf042012-12-18 09:49:45 -0800177 /* verify that an IGraphicBufferProducer was created by SurfaceFlinger.
Mathias Agopiane57f2922012-08-09 16:29:12 -0700178 */
179 virtual bool authenticateSurfaceTexture(
Andy McFadden2adaf042012-12-18 09:49:45 -0800180 const sp<IGraphicBufferProducer>& surface) const = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700181
Brian Anderson6b376712017-04-04 10:51:39 -0700182 /* Returns the frame timestamps supported by SurfaceFlinger.
183 */
184 virtual status_t getSupportedFrameTimestamps(
185 std::vector<FrameEvent>* outSupported) const = 0;
186
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700187 /* set display power mode. depending on the mode, it can either trigger
188 * screen on, off or low power mode and wait for it to complete.
Mathias Agopian041a0752013-03-15 18:31:56 -0700189 * requires ACCESS_SURFACE_FLINGER permission.
190 */
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700191 virtual void setPowerMode(const sp<IBinder>& display, int mode) = 0;
Mathias Agopian3094df32012-06-18 18:06:45 -0700192
Dan Stoza7f7da322014-05-02 15:26:25 -0700193
Lajos Molnar67d8bd62014-09-11 14:58:45 -0700194 /* returns display statistics for a given display
195 * intended to be used by the media framework to properly schedule
196 * video frames */
197 virtual status_t getDisplayStats(const sp<IBinder>& display,
198 DisplayStatInfo* stats) = 0;
199
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -0800200 /**
201 * Get transactional state of given display.
202 */
203 virtual status_t getDisplayState(const sp<IBinder>& display, ui::DisplayState*) = 0;
204
205 /**
206 * Get immutable information about given physical display.
207 */
208 virtual status_t getDisplayInfo(const sp<IBinder>& display, DisplayInfo*) = 0;
209
210 /**
211 * Get configurations supported by given physical display.
212 */
213 virtual status_t getDisplayConfigs(const sp<IBinder>& display, Vector<DisplayConfig>*) = 0;
214
215 /**
216 * Get the index into configurations returned by getDisplayConfigs,
217 * corresponding to the active configuration.
218 */
Dan Stoza7f7da322014-05-02 15:26:25 -0700219 virtual int getActiveConfig(const sp<IBinder>& display) = 0;
220
Michael Wright28f24d02016-07-12 13:30:53 -0700221 virtual status_t getDisplayColorModes(const sp<IBinder>& display,
Peiyong Lin9f034472018-03-28 15:29:00 -0700222 Vector<ui::ColorMode>* outColorModes) = 0;
Daniel Solomon42d04562019-01-20 21:03:19 -0800223 virtual status_t getDisplayNativePrimaries(const sp<IBinder>& display,
224 ui::DisplayPrimaries& primaries) = 0;
Peiyong Lin9f034472018-03-28 15:29:00 -0700225 virtual ui::ColorMode getActiveColorMode(const sp<IBinder>& display) = 0;
Michael Wright28f24d02016-07-12 13:30:53 -0700226 virtual status_t setActiveColorMode(const sp<IBinder>& display,
Peiyong Lin9f034472018-03-28 15:29:00 -0700227 ui::ColorMode colorMode) = 0;
Michael Wright28f24d02016-07-12 13:30:53 -0700228
Chia-I Wuff79ef82018-08-22 15:27:32 -0700229 /**
Galia Peycheva5492cb52019-10-30 14:13:16 +0100230 * Returns true if the connected display reports support for HDMI 2.1 Auto
231 * Low Latency Mode.
232 * For more information, see the HDMI 2.1 specification.
233 */
234 virtual status_t getAutoLowLatencyModeSupport(const sp<IBinder>& display,
235 bool* outSupport) const = 0;
236
237 /**
238 * Switches Auto Low Latency Mode on/off on the connected display, if it is
239 * available. This should only be called if #getAutoLowLatencyMode returns
240 * true.
241 * For more information, see the HDMI 2.1 specification.
242 */
243 virtual void setAutoLowLatencyMode(const sp<IBinder>& display, bool on) = 0;
244
245 /**
246 * Returns true if the connected display reports support for Game Content Type.
247 * For more information, see the HDMI 1.4 specification.
248 */
249 virtual status_t getGameContentTypeSupport(const sp<IBinder>& display,
250 bool* outSupport) const = 0;
251
252 /**
253 * This will start sending infoframes to the connected display with
254 * ContentType=Game (if on=true). This will switch the disply to Game mode.
255 * This should only be called if #getGameContentTypeSupport returns true.
256 * For more information, see the HDMI 1.4 specification.
257 */
258 virtual void setGameContentType(const sp<IBinder>& display, bool on) = 0;
259
260 /**
Chia-I Wuff79ef82018-08-22 15:27:32 -0700261 * Capture the specified screen. This requires READ_FRAME_BUFFER
262 * permission. This function will fail if there is a secure window on
chaviwd2432892020-07-24 17:42:39 -0700263 * screen and DisplayCaptureArgs.captureSecureLayers is false.
Chia-I Wuff79ef82018-08-22 15:27:32 -0700264 *
265 * This function can capture a subregion (the source crop) of the screen.
266 * The subregion can be optionally rotated. It will also be scaled to
267 * match the size of the output buffer.
Peiyong Lin0e003c92018-09-17 11:09:51 -0700268 */
chaviwd2432892020-07-24 17:42:39 -0700269 virtual status_t captureDisplay(const DisplayCaptureArgs& args,
chaviw8ffc7b82020-08-18 11:25:37 -0700270 const sp<IScreenCaptureListener>& captureListener) = 0;
Svetoslavd85084b2014-03-20 10:28:31 -0700271
chaviwd2432892020-07-24 17:42:39 -0700272 virtual status_t captureDisplay(uint64_t displayOrLayerStack,
chaviw8ffc7b82020-08-18 11:25:37 -0700273 const sp<IScreenCaptureListener>& captureListener) = 0;
chaviw93df2ea2019-04-30 16:45:12 -0700274
Robert Carr866455f2019-04-02 16:28:26 -0700275 template <class AA>
276 struct SpHash {
277 size_t operator()(const sp<AA>& k) const { return std::hash<AA*>()(k.get()); }
278 };
279
Robert Carr578038f2018-03-09 12:25:24 -0800280 /**
281 * Capture a subtree of the layer hierarchy, potentially ignoring the root node.
chaviw3efadb12020-07-27 10:07:15 -0700282 * This requires READ_FRAME_BUFFER permission. This function will fail if there
283 * is a secure window on screen
Robert Carr578038f2018-03-09 12:25:24 -0800284 */
chaviw3efadb12020-07-27 10:07:15 -0700285 virtual status_t captureLayers(const LayerCaptureArgs& args,
chaviw8ffc7b82020-08-18 11:25:37 -0700286 const sp<IScreenCaptureListener>& captureListener) = 0;
Peiyong Lin0e003c92018-09-17 11:09:51 -0700287
Svetoslavd85084b2014-03-20 10:28:31 -0700288 /* Clears the frame statistics for animations.
289 *
290 * Requires the ACCESS_SURFACE_FLINGER permission.
291 */
292 virtual status_t clearAnimationFrameStats() = 0;
293
294 /* Gets the frame statistics for animations.
295 *
296 * Requires the ACCESS_SURFACE_FLINGER permission.
297 */
298 virtual status_t getAnimationFrameStats(FrameStats* outStats) const = 0;
Dan Stozac4f471e2016-03-24 09:31:08 -0700299
300 /* Gets the supported HDR capabilities of the given display.
301 *
302 * Requires the ACCESS_SURFACE_FLINGER permission.
303 */
304 virtual status_t getHdrCapabilities(const sp<IBinder>& display,
305 HdrCapabilities* outCapabilities) const = 0;
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -0700306
307 virtual status_t enableVSyncInjections(bool enable) = 0;
308
309 virtual status_t injectVSync(nsecs_t when) = 0;
Kalle Raitaa099a242017-01-11 11:17:29 -0800310
311 /* Gets the list of active layers in Z order for debugging purposes
312 *
313 * Requires the ACCESS_SURFACE_FLINGER permission.
314 */
Vishnu Nair43bccf82020-06-05 10:53:37 -0700315 virtual status_t getLayerDebugInfo(std::vector<LayerDebugInfo>* outLayers) = 0;
Peiyong Lin0256f722018-08-31 15:45:10 -0700316
Ady Abraham37965d42018-11-01 13:43:32 -0700317 virtual status_t getColorManagement(bool* outGetColorManagement) const = 0;
Peiyong Linc6780972018-10-28 15:24:08 -0700318
319 /* Gets the composition preference of the default data space and default pixel format,
320 * as well as the wide color gamut data space and wide color gamut pixel format.
321 * If the wide color gamut data space is V0_SRGB, then it implies that the platform
322 * has no wide color gamut support.
323 *
324 * Requires the ACCESS_SURFACE_FLINGER permission.
325 */
326 virtual status_t getCompositionPreference(ui::Dataspace* defaultDataspace,
327 ui::PixelFormat* defaultPixelFormat,
328 ui::Dataspace* wideColorGamutDataspace,
329 ui::PixelFormat* wideColorGamutPixelFormat) const = 0;
Kevin DuBois9c0a1762018-10-16 13:32:31 -0700330 /*
331 * Requires the ACCESS_SURFACE_FLINGER permission.
332 */
333 virtual status_t getDisplayedContentSamplingAttributes(const sp<IBinder>& display,
334 ui::PixelFormat* outFormat,
335 ui::Dataspace* outDataspace,
336 uint8_t* outComponentMask) const = 0;
Kevin DuBois74e53772018-11-19 10:52:38 -0800337
338 /* Turns on the color sampling engine on the display.
339 *
340 * Requires the ACCESS_SURFACE_FLINGER permission.
341 */
342 virtual status_t setDisplayContentSamplingEnabled(const sp<IBinder>& display, bool enable,
343 uint8_t componentMask,
Dominik Laskowski470df5f2020-04-02 22:27:42 -0700344 uint64_t maxFrames) = 0;
Kevin DuBois1d4249a2018-08-29 10:45:14 -0700345
346 /* Returns statistics on the color profile of the last frame displayed for a given display
347 *
348 * Requires the ACCESS_SURFACE_FLINGER permission.
349 */
350 virtual status_t getDisplayedContentSample(const sp<IBinder>& display, uint64_t maxFrames,
351 uint64_t timestamp,
352 DisplayedFrameStats* outStats) const = 0;
Peiyong Lin3c2791e2019-01-14 17:05:18 -0800353
354 /*
355 * Gets whether SurfaceFlinger can support protected content in GPU composition.
356 * Requires the ACCESS_SURFACE_FLINGER permission.
357 */
358 virtual status_t getProtectedContentSupport(bool* outSupported) const = 0;
Marissa Wallebc2c052019-01-16 19:16:55 -0800359
Peiyong Lin4f3fddf2019-01-24 17:21:24 -0800360 /*
361 * Queries whether the given display is a wide color display.
362 * Requires the ACCESS_SURFACE_FLINGER permission.
363 */
364 virtual status_t isWideColorDisplay(const sp<IBinder>& token,
365 bool* outIsWideColorDisplay) const = 0;
Dan Stoza84ab9372018-12-17 15:27:57 -0800366
367 /* Registers a listener to stream median luma updates from SurfaceFlinger.
368 *
369 * The sampling area is bounded by both samplingArea and the given stopLayerHandle
370 * (i.e., only layers behind the stop layer will be captured and sampled).
371 *
372 * Multiple listeners may be provided so long as they have independent listeners.
373 * If multiple listeners are provided, the effective sampling region for each listener will
374 * be bounded by whichever stop layer has a lower Z value.
375 *
376 * Requires the same permissions as captureLayers and captureScreen.
377 */
378 virtual status_t addRegionSamplingListener(const Rect& samplingArea,
379 const sp<IBinder>& stopLayerHandle,
380 const sp<IRegionSamplingListener>& listener) = 0;
381
382 /*
383 * Removes a listener that was streaming median luma updates from SurfaceFlinger.
384 */
385 virtual status_t removeRegionSamplingListener(const sp<IRegionSamplingListener>& listener) = 0;
Ady Abraham838de062019-02-04 10:24:03 -0800386
Steven Thomasf734df42020-04-13 21:09:28 -0700387 /* Sets the refresh rate boundaries for the display.
388 *
389 * The primary refresh rate range represents display manager's general guidance on the display
390 * configs we'll consider when switching refresh rates. Unless we get an explicit signal from an
391 * app, we should stay within this range.
392 *
393 * The app request refresh rate range allows us to consider more display configs when switching
394 * refresh rates. Although we should generally stay within the primary range, specific
395 * considerations, such as layer frame rate settings specified via the setFrameRate() api, may
396 * cause us to go outside the primary range. We never go outside the app request range. The app
397 * request range will be greater than or equal to the primary refresh rate range, never smaller.
398 *
399 * defaultConfig is used to narrow the list of display configs SurfaceFlinger will consider
400 * switching between. Only configs with a config group and resolution matching defaultConfig
401 * will be considered for switching. The defaultConfig index corresponds to the list of configs
402 * returned from getDisplayConfigs().
Ana Krulec0782b882019-10-15 17:34:54 -0700403 */
404 virtual status_t setDesiredDisplayConfigSpecs(const sp<IBinder>& displayToken,
Marin Shalamanov30b0b3c2020-10-13 19:15:06 +0200405 int32_t defaultConfig, bool allowGroupSwitching,
Steven Thomasf734df42020-04-13 21:09:28 -0700406 float primaryRefreshRateMin,
407 float primaryRefreshRateMax,
408 float appRequestRefreshRateMin,
409 float appRequestRefreshRateMax) = 0;
Ana Krulec0782b882019-10-15 17:34:54 -0700410
Ana Krulec234bb162019-11-10 22:55:55 +0100411 virtual status_t getDesiredDisplayConfigSpecs(const sp<IBinder>& displayToken,
Ana Kruleced3a8cc2019-11-14 00:55:07 +0100412 int32_t* outDefaultConfig,
Marin Shalamanov30b0b3c2020-10-13 19:15:06 +0200413 bool* outAllowGroupSwitching,
Steven Thomasf734df42020-04-13 21:09:28 -0700414 float* outPrimaryRefreshRateMin,
415 float* outPrimaryRefreshRateMax,
416 float* outAppRequestRefreshRateMin,
417 float* outAppRequestRefreshRateMax) = 0;
Ana Krulec0782b882019-10-15 17:34:54 -0700418 /*
Dan Gittik57e63c52019-01-18 16:37:54 +0000419 * Gets whether brightness operations are supported on a display.
420 *
421 * displayToken
422 * The token of the display.
423 * outSupport
424 * An output parameter for whether brightness operations are supported.
425 *
426 * Returns NO_ERROR upon success. Otherwise,
427 * NAME_NOT_FOUND if the display is invalid, or
428 * BAD_VALUE if the output parameter is invalid.
429 */
430 virtual status_t getDisplayBrightnessSupport(const sp<IBinder>& displayToken,
431 bool* outSupport) const = 0;
432
433 /*
434 * Sets the brightness of a display.
435 *
436 * displayToken
437 * The token of the display whose brightness is set.
438 * brightness
439 * A number between 0.0f (minimum brightness) and 1.0 (maximum brightness), or -1.0f to
440 * turn the backlight off.
441 *
442 * Returns NO_ERROR upon success. Otherwise,
443 * NAME_NOT_FOUND if the display is invalid, or
444 * BAD_VALUE if the brightness is invalid, or
445 * INVALID_OPERATION if brightness operations are not supported.
446 */
Dominik Laskowski470df5f2020-04-02 22:27:42 -0700447 virtual status_t setDisplayBrightness(const sp<IBinder>& displayToken, float brightness) = 0;
Ady Abraham8532d012019-05-08 14:50:56 -0700448
449 /*
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100450 * Sends a power boost to the composer. This function is asynchronous.
Ady Abraham8532d012019-05-08 14:50:56 -0700451 *
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100452 * boostId
453 * boost id according to android::hardware::power::Boost
Ady Abraham8532d012019-05-08 14:50:56 -0700454 *
455 * Returns NO_ERROR upon success.
456 */
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100457 virtual status_t notifyPowerBoost(int32_t boostId) = 0;
Vishnu Nairb13bb952019-11-15 10:24:08 -0800458
459 /*
460 * Sets the global configuration for all the shadows drawn by SurfaceFlinger. Shadow follows
461 * material design guidelines.
462 *
463 * ambientColor
464 * Color to the ambient shadow. The alpha is premultiplied.
465 *
466 * spotColor
467 * Color to the spot shadow. The alpha is premultiplied. The position of the spot shadow
468 * depends on the light position.
469 *
470 * lightPosY/lightPosZ
471 * Position of the light used to cast the spot shadow. The X value is always the display
472 * width / 2.
473 *
474 * lightRadius
475 * Radius of the light casting the shadow.
476 */
477 virtual status_t setGlobalShadowSettings(const half4& ambientColor, const half4& spotColor,
478 float lightPosY, float lightPosZ,
479 float lightRadius) = 0;
Steven Thomas62a4cf82020-01-31 12:04:03 -0800480
481 /*
482 * Sets the intended frame rate for a surface. See ANativeWindow_setFrameRate() for more info.
483 */
484 virtual status_t setFrameRate(const sp<IGraphicBufferProducer>& surface, float frameRate,
Marin Shalamanov46084422020-10-13 12:33:42 +0200485 int8_t compatibility, bool shouldBeSeamless) = 0;
Steven Thomasd4071902020-03-24 16:02:53 -0700486
487 /*
488 * Acquire a frame rate flexibility token from SurfaceFlinger. While this token is acquired,
489 * surface flinger will freely switch between frame rates in any way it sees fit, regardless of
490 * the current restrictions applied by DisplayManager. This is useful to get consistent behavior
491 * for tests. Release the token by releasing the returned IBinder reference.
492 */
493 virtual status_t acquireFrameRateFlexibilityToken(sp<IBinder>* outToken) = 0;
Ady Abraham74e17562020-08-24 18:18:19 -0700494
495 /*
496 * Sets the frame timeline vsync id received from choreographer that corresponds to next
497 * buffer submitted on that surface.
498 */
499 virtual status_t setFrameTimelineVsync(const sp<IGraphicBufferProducer>& surface,
500 int64_t frameTimelineVsyncId) = 0;
Pablo Gamito6ee484d2020-07-30 14:26:28 +0000501
502 /*
503 * Adds a TransactionTraceListener to listen for transaction tracing state updates.
504 */
505 virtual status_t addTransactionTraceListener(
506 const sp<gui::ITransactionTraceListener>& listener) = 0;
Ana Krulec31f2b3c2020-12-14 14:30:09 -0800507
508 /**
509 * Gets priority of the RenderEngine in SurfaceFlinger.
510 */
511 virtual int getGPUContextPriority() = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800512};
513
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800514// ----------------------------------------------------------------------------
515
Mathias Agopian3165cc22012-08-08 19:42:09 -0700516class BnSurfaceComposer: public BnInterface<ISurfaceComposer> {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800517public:
Ana Krulec13be8ad2018-08-21 02:43:56 +0000518 enum ISurfaceComposerTag {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800519 // Note: BOOT_FINISHED must remain this value, it is called from
520 // Java by ActivityManagerService.
521 BOOT_FINISHED = IBinder::FIRST_CALL_TRANSACTION,
522 CREATE_CONNECTION,
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -0800523 GET_DISPLAY_INFO,
Mathias Agopiand0566bc2011-11-17 17:49:17 -0800524 CREATE_DISPLAY_EVENT_CONNECTION,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700525 CREATE_DISPLAY,
Jesse Hall6c913be2013-08-08 12:15:49 -0700526 DESTROY_DISPLAY,
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800527 GET_PHYSICAL_DISPLAY_TOKEN,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700528 SET_TRANSACTION_STATE,
529 AUTHENTICATE_SURFACE,
Brian Anderson069b3652016-07-22 10:32:47 -0700530 GET_SUPPORTED_FRAME_TIMESTAMPS,
Dan Stoza7f7da322014-05-02 15:26:25 -0700531 GET_DISPLAY_CONFIGS,
532 GET_ACTIVE_CONFIG,
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -0800533 GET_DISPLAY_STATE,
chaviwd2432892020-07-24 17:42:39 -0700534 CAPTURE_DISPLAY,
chaviwa76b2712017-09-20 12:02:26 -0700535 CAPTURE_LAYERS,
Svetoslavd85084b2014-03-20 10:28:31 -0700536 CLEAR_ANIMATION_FRAME_STATS,
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700537 GET_ANIMATION_FRAME_STATS,
538 SET_POWER_MODE,
Lajos Molnar67d8bd62014-09-11 14:58:45 -0700539 GET_DISPLAY_STATS,
Dan Stozac4f471e2016-03-24 09:31:08 -0700540 GET_HDR_CAPABILITIES,
Michael Wright28f24d02016-07-12 13:30:53 -0700541 GET_DISPLAY_COLOR_MODES,
542 GET_ACTIVE_COLOR_MODE,
543 SET_ACTIVE_COLOR_MODE,
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -0700544 ENABLE_VSYNC_INJECTIONS,
Robert Carr1db73f62016-12-21 12:58:51 -0800545 INJECT_VSYNC,
Kalle Raitaa099a242017-01-11 11:17:29 -0800546 GET_LAYER_DEBUG_INFO,
Peiyong Lin0256f722018-08-31 15:45:10 -0700547 GET_COMPOSITION_PREFERENCE,
Ady Abraham37965d42018-11-01 13:43:32 -0700548 GET_COLOR_MANAGEMENT,
Kevin DuBois9c0a1762018-10-16 13:32:31 -0700549 GET_DISPLAYED_CONTENT_SAMPLING_ATTRIBUTES,
Kevin DuBois74e53772018-11-19 10:52:38 -0800550 SET_DISPLAY_CONTENT_SAMPLING_ENABLED,
Kevin DuBois1d4249a2018-08-29 10:45:14 -0700551 GET_DISPLAYED_CONTENT_SAMPLE,
Peiyong Lin3c2791e2019-01-14 17:05:18 -0800552 GET_PROTECTED_CONTENT_SUPPORT,
Peiyong Lin4f3fddf2019-01-24 17:21:24 -0800553 IS_WIDE_COLOR_DISPLAY,
Daniel Solomon42d04562019-01-20 21:03:19 -0800554 GET_DISPLAY_NATIVE_PRIMARIES,
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -0800555 GET_PHYSICAL_DISPLAY_IDS,
Dan Stoza84ab9372018-12-17 15:27:57 -0800556 ADD_REGION_SAMPLING_LISTENER,
557 REMOVE_REGION_SAMPLING_LISTENER,
Ana Krulec0782b882019-10-15 17:34:54 -0700558 SET_DESIRED_DISPLAY_CONFIG_SPECS,
Ana Krulec234bb162019-11-10 22:55:55 +0100559 GET_DESIRED_DISPLAY_CONFIG_SPECS,
Dan Gittik57e63c52019-01-18 16:37:54 +0000560 GET_DISPLAY_BRIGHTNESS_SUPPORT,
561 SET_DISPLAY_BRIGHTNESS,
chaviwd2432892020-07-24 17:42:39 -0700562 CAPTURE_DISPLAY_BY_ID,
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100563 NOTIFY_POWER_BOOST,
Vishnu Nairb13bb952019-11-15 10:24:08 -0800564 SET_GLOBAL_SHADOW_SETTINGS,
Galia Peycheva5492cb52019-10-30 14:13:16 +0100565 GET_AUTO_LOW_LATENCY_MODE_SUPPORT,
566 SET_AUTO_LOW_LATENCY_MODE,
567 GET_GAME_CONTENT_TYPE_SUPPORT,
568 SET_GAME_CONTENT_TYPE,
Steven Thomas62a4cf82020-01-31 12:04:03 -0800569 SET_FRAME_RATE,
Steven Thomasd4071902020-03-24 16:02:53 -0700570 ACQUIRE_FRAME_RATE_FLEXIBILITY_TOKEN,
Ady Abraham74e17562020-08-24 18:18:19 -0700571 SET_FRAME_TIMELINE_VSYNC,
Pablo Gamito6ee484d2020-07-30 14:26:28 +0000572 ADD_TRANSACTION_TRACE_LISTENER,
Ana Krulec31f2b3c2020-12-14 14:30:09 -0800573 GET_GPU_CONTEXT_PRIORITY,
Peiyong Lin4f3fddf2019-01-24 17:21:24 -0800574 // Always append new enum to the end.
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800575 };
576
Mathias Agopian3165cc22012-08-08 19:42:09 -0700577 virtual status_t onTransact(uint32_t code, const Parcel& data,
578 Parcel* reply, uint32_t flags = 0);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800579};
580
Dominik Laskowski3cb3d4e2019-11-21 11:14:45 -0800581} // namespace android