blob: 99a3a75502dae7dc0d0389dc1bba82169ddb1b7f [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
23#include <utils/RefBase.h>
24#include <utils/Errors.h>
Svetoslavd85084b2014-03-20 10:28:31 -070025#include <utils/Timers.h>
26#include <utils/Vector.h>
Mathias Agopian9cce3252010-02-09 17:46:37 -080027
Mathias Agopianc5b2c0b2009-05-19 19:08:10 -070028#include <binder/IInterface.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080029
Svetoslavd85084b2014-03-20 10:28:31 -070030#include <ui/FrameStats.h>
Mathias Agopian2b5dd402017-02-07 17:36:19 -080031#include <ui/PixelFormat.h>
Chavi Weingarten40482ff2017-11-30 01:51:40 +000032#include <ui/GraphicBuffer.h>
Peiyong Linfd997e02018-03-28 15:29:00 -070033#include <ui/GraphicTypes.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080034
Brian Anderson069b3652016-07-22 10:32:47 -070035#include <vector>
36
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080037namespace android {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080038// ----------------------------------------------------------------------------
39
Colin Crossa2362b42016-09-26 13:48:25 -070040struct ComposerState;
41struct DisplayState;
Jesse Hall646f5412014-08-07 22:19:07 -070042struct DisplayInfo;
Lajos Molnare7bda062014-09-18 20:05:27 -070043struct DisplayStatInfo;
Kalle Raitaa099a242017-01-11 11:17:29 -080044class LayerDebugInfo;
Dan Stozac4f471e2016-03-24 09:31:08 -070045class HdrCapabilities;
Mathias Agopiand0566bc2011-11-17 17:49:17 -080046class IDisplayEventConnection;
Mathias Agopian2b5dd402017-02-07 17:36:19 -080047class IGraphicBufferProducer;
48class ISurfaceComposerClient;
Dan Stozac1879002014-05-22 15:59:05 -070049class Rect;
Brian Anderson3890c392016-07-25 12:48:08 -070050enum class FrameEvent;
Mathias Agopiana67932f2011-04-20 14:20:59 -070051
Andy McFadden882e3a32013-01-08 16:06:15 -080052/*
53 * This class defines the Binder IPC interface for accessing various
54 * SurfaceFlinger features.
55 */
Mathias Agopian3165cc22012-08-08 19:42:09 -070056class ISurfaceComposer: public IInterface {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080057public:
Colin Cross17576de2016-09-26 13:07:06 -070058 DECLARE_META_INTERFACE(SurfaceComposer)
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080059
Mathias Agopian3165cc22012-08-08 19:42:09 -070060 // flags for setTransactionState()
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080061 enum {
Mathias Agopian3165cc22012-08-08 19:42:09 -070062 eSynchronous = 0x01,
Jamie Gennis2d5e2302012-10-15 18:24:43 -070063 eAnimation = 0x02,
Dan Stoza2713c302018-03-28 17:07:36 -070064
65 // Indicates that this transaction will likely result in a lot of layers being composed, and
66 // thus, SurfaceFlinger should wake-up earlier to avoid missing frame deadlines. In this
67 // case SurfaceFlinger will wake up at (sf vsync offset - debug.sf.early_phase_offset_ns)
68 eEarlyWakeup = 0x04
Jamie Gennis28378392011-10-12 17:39:00 -070069 };
70
Mathias Agopiane57f2922012-08-09 16:29:12 -070071 enum {
72 eDisplayIdMain = 0,
73 eDisplayIdHdmi = 1
74 };
75
Riley Andrewsc3ebe662014-09-04 16:20:31 -070076 enum Rotation {
77 eRotateNone = 0,
78 eRotate90 = 1,
79 eRotate180 = 2,
80 eRotate270 = 3
81 };
82
Jorim Jaggib1e2f8d2017-06-08 15:43:59 -070083 enum VsyncSource {
84 eVsyncSourceApp = 0,
85 eVsyncSourceSurfaceFlinger = 1
86 };
87
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080088 /* create connection with surface flinger, requires
89 * ACCESS_SURFACE_FLINGER permission
90 */
Mathias Agopian7e27f052010-05-28 14:22:23 -070091 virtual sp<ISurfaceComposerClient> createConnection() = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080092
Robert Carr1db73f62016-12-21 12:58:51 -080093 /** create a scoped connection with surface flinger.
94 * Surfaces produced with this connection will act
95 * as children of the passed in GBP. That is to say
96 * SurfaceFlinger will draw them relative and confined to
97 * drawing of buffers from the layer associated with parent.
98 * As this is graphically equivalent in reach to just drawing
99 * pixels into the parent buffers, it requires no special permission.
100 */
101 virtual sp<ISurfaceComposerClient> createScopedConnection(
102 const sp<IGraphicBufferProducer>& parent) = 0;
103
Mathias Agopiane57f2922012-08-09 16:29:12 -0700104 /* return an IDisplayEventConnection */
Jorim Jaggib1e2f8d2017-06-08 15:43:59 -0700105 virtual sp<IDisplayEventConnection> createDisplayEventConnection(
106 VsyncSource vsyncSource = eVsyncSourceApp) = 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
Mathias Agopiane57f2922012-08-09 16:29:12 -0700119 /* get the token for the existing default displays. possible values
120 * for id are eDisplayIdMain and eDisplayIdHdmi.
121 */
122 virtual sp<IBinder> getBuiltInDisplay(int32_t id) = 0;
123
Mathias Agopian9cce3252010-02-09 17:46:37 -0800124 /* open/close transactions. requires ACCESS_SURFACE_FLINGER permission */
Mathias Agopian3165cc22012-08-08 19:42:09 -0700125 virtual void setTransactionState(const Vector<ComposerState>& state,
126 const Vector<DisplayState>& displays, uint32_t flags) = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800127
128 /* signal that we're done booting.
Mathias Agopian9cce3252010-02-09 17:46:37 -0800129 * Requires ACCESS_SURFACE_FLINGER permission
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800130 */
131 virtual void bootFinished() = 0;
132
Andy McFadden2adaf042012-12-18 09:49:45 -0800133 /* verify that an IGraphicBufferProducer was created by SurfaceFlinger.
Mathias Agopiane57f2922012-08-09 16:29:12 -0700134 */
135 virtual bool authenticateSurfaceTexture(
Andy McFadden2adaf042012-12-18 09:49:45 -0800136 const sp<IGraphicBufferProducer>& surface) const = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700137
Brian Anderson6b376712017-04-04 10:51:39 -0700138 /* Returns the frame timestamps supported by SurfaceFlinger.
139 */
140 virtual status_t getSupportedFrameTimestamps(
141 std::vector<FrameEvent>* outSupported) const = 0;
142
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700143 /* set display power mode. depending on the mode, it can either trigger
144 * screen on, off or low power mode and wait for it to complete.
Mathias Agopian041a0752013-03-15 18:31:56 -0700145 * requires ACCESS_SURFACE_FLINGER permission.
146 */
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700147 virtual void setPowerMode(const sp<IBinder>& display, int mode) = 0;
Mathias Agopian3094df32012-06-18 18:06:45 -0700148
Dan Stoza7f7da322014-05-02 15:26:25 -0700149 /* returns information for each configuration of the given display
Jeff Brown9d4e3d22012-08-24 20:00:51 -0700150 * intended to be used to get information about built-in displays */
Dan Stoza7f7da322014-05-02 15:26:25 -0700151 virtual status_t getDisplayConfigs(const sp<IBinder>& display,
152 Vector<DisplayInfo>* configs) = 0;
153
Lajos Molnar67d8bd62014-09-11 14:58:45 -0700154 /* returns display statistics for a given display
155 * intended to be used by the media framework to properly schedule
156 * video frames */
157 virtual status_t getDisplayStats(const sp<IBinder>& display,
158 DisplayStatInfo* stats) = 0;
159
Yiwei Zhang1d465af2018-08-21 15:15:42 -0700160 /* returns display viewport information of the given display */
161 virtual status_t getDisplayViewport(const sp<IBinder>& display, Rect* outViewport) = 0;
162
Dan Stoza7f7da322014-05-02 15:26:25 -0700163 /* indicates which of the configurations returned by getDisplayInfo is
164 * currently active */
165 virtual int getActiveConfig(const sp<IBinder>& display) = 0;
166
167 /* specifies which configuration (of those returned by getDisplayInfo)
168 * should be used */
169 virtual status_t setActiveConfig(const sp<IBinder>& display, int id) = 0;
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800170
Michael Wright28f24d02016-07-12 13:30:53 -0700171 virtual status_t getDisplayColorModes(const sp<IBinder>& display,
Peiyong Linfd997e02018-03-28 15:29:00 -0700172 Vector<ui::ColorMode>* outColorModes) = 0;
173 virtual ui::ColorMode getActiveColorMode(const sp<IBinder>& display) = 0;
Michael Wright28f24d02016-07-12 13:30:53 -0700174 virtual status_t setActiveColorMode(const sp<IBinder>& display,
Peiyong Linfd997e02018-03-28 15:29:00 -0700175 ui::ColorMode colorMode) = 0;
Michael Wright28f24d02016-07-12 13:30:53 -0700176
Mathias Agopian041a0752013-03-15 18:31:56 -0700177 /* Capture the specified screen. requires READ_FRAME_BUFFER permission
178 * This function will fail if there is a secure window on screen.
179 */
Chavi Weingarten40482ff2017-11-30 01:51:40 +0000180 virtual status_t captureScreen(const sp<IBinder>& display, sp<GraphicBuffer>* outBuffer,
181 Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight,
182 int32_t minLayerZ, int32_t maxLayerZ, bool useIdentityTransform,
183 Rotation rotation = eRotateNone) = 0;
Svetoslavd85084b2014-03-20 10:28:31 -0700184
Robert Carr578038f2018-03-09 12:25:24 -0800185 /**
186 * Capture a subtree of the layer hierarchy, potentially ignoring the root node.
187 */
chaviwa76b2712017-09-20 12:02:26 -0700188 virtual status_t captureLayers(const sp<IBinder>& layerHandleBinder,
Chavi Weingarten40482ff2017-11-30 01:51:40 +0000189 sp<GraphicBuffer>* outBuffer, const Rect& sourceCrop,
Robert Carr578038f2018-03-09 12:25:24 -0800190 float frameScale = 1.0, bool childrenOnly = false) = 0;
chaviwa76b2712017-09-20 12:02:26 -0700191
Svetoslavd85084b2014-03-20 10:28:31 -0700192 /* Clears the frame statistics for animations.
193 *
194 * Requires the ACCESS_SURFACE_FLINGER permission.
195 */
196 virtual status_t clearAnimationFrameStats() = 0;
197
198 /* Gets the frame statistics for animations.
199 *
200 * Requires the ACCESS_SURFACE_FLINGER permission.
201 */
202 virtual status_t getAnimationFrameStats(FrameStats* outStats) const = 0;
Dan Stozac4f471e2016-03-24 09:31:08 -0700203
204 /* Gets the supported HDR capabilities of the given display.
205 *
206 * Requires the ACCESS_SURFACE_FLINGER permission.
207 */
208 virtual status_t getHdrCapabilities(const sp<IBinder>& display,
209 HdrCapabilities* outCapabilities) const = 0;
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -0700210
211 virtual status_t enableVSyncInjections(bool enable) = 0;
212
213 virtual status_t injectVSync(nsecs_t when) = 0;
Kalle Raitaa099a242017-01-11 11:17:29 -0800214
215 /* Gets the list of active layers in Z order for debugging purposes
216 *
217 * Requires the ACCESS_SURFACE_FLINGER permission.
218 */
219 virtual status_t getLayerDebugInfo(std::vector<LayerDebugInfo>* outLayers) const = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800220};
221
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800222// ----------------------------------------------------------------------------
223
Mathias Agopian3165cc22012-08-08 19:42:09 -0700224class BnSurfaceComposer: public BnInterface<ISurfaceComposer> {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800225public:
226 enum {
227 // Note: BOOT_FINISHED must remain this value, it is called from
228 // Java by ActivityManagerService.
229 BOOT_FINISHED = IBinder::FIRST_CALL_TRANSACTION,
230 CREATE_CONNECTION,
Mathias Agopian0556d792017-03-22 15:49:32 -0700231 UNUSED, // formerly CREATE_GRAPHIC_BUFFER_ALLOC
Mathias Agopiand0566bc2011-11-17 17:49:17 -0800232 CREATE_DISPLAY_EVENT_CONNECTION,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700233 CREATE_DISPLAY,
Jesse Hall6c913be2013-08-08 12:15:49 -0700234 DESTROY_DISPLAY,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700235 GET_BUILT_IN_DISPLAY,
236 SET_TRANSACTION_STATE,
237 AUTHENTICATE_SURFACE,
Brian Anderson069b3652016-07-22 10:32:47 -0700238 GET_SUPPORTED_FRAME_TIMESTAMPS,
Dan Stoza7f7da322014-05-02 15:26:25 -0700239 GET_DISPLAY_CONFIGS,
240 GET_ACTIVE_CONFIG,
241 SET_ACTIVE_CONFIG,
Mathias Agopian3094df32012-06-18 18:06:45 -0700242 CONNECT_DISPLAY,
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800243 CAPTURE_SCREEN,
chaviwa76b2712017-09-20 12:02:26 -0700244 CAPTURE_LAYERS,
Svetoslavd85084b2014-03-20 10:28:31 -0700245 CLEAR_ANIMATION_FRAME_STATS,
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700246 GET_ANIMATION_FRAME_STATS,
247 SET_POWER_MODE,
Lajos Molnar67d8bd62014-09-11 14:58:45 -0700248 GET_DISPLAY_STATS,
Dan Stozac4f471e2016-03-24 09:31:08 -0700249 GET_HDR_CAPABILITIES,
Michael Wright28f24d02016-07-12 13:30:53 -0700250 GET_DISPLAY_COLOR_MODES,
251 GET_ACTIVE_COLOR_MODE,
252 SET_ACTIVE_COLOR_MODE,
Sahil Dhanjuc1ba5c42016-06-07 20:09:20 -0700253 ENABLE_VSYNC_INJECTIONS,
Robert Carr1db73f62016-12-21 12:58:51 -0800254 INJECT_VSYNC,
Kalle Raitaa099a242017-01-11 11:17:29 -0800255 GET_LAYER_DEBUG_INFO,
Yiwei Zhang1d465af2018-08-21 15:15:42 -0700256 CREATE_SCOPED_CONNECTION,
257 GET_DISPLAY_VIEWPORT
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800258 };
259
Mathias Agopian3165cc22012-08-08 19:42:09 -0700260 virtual status_t onTransact(uint32_t code, const Parcel& data,
261 Parcel* reply, uint32_t flags = 0);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800262};
263
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800264// ----------------------------------------------------------------------------
265
266}; // namespace android
267
Mathias Agopian90ac7992012-02-25 18:48:35 -0800268#endif // ANDROID_GUI_ISURFACE_COMPOSER_H