blob: 555a0cc6ab914bb14844e26dd34ca27ea6cc1042 [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 Agopian9cce3252010-02-09 17:46:37 -080031
Mathias Agopian90ac7992012-02-25 18:48:35 -080032#include <gui/IGraphicBufferAlloc.h>
33#include <gui/ISurfaceComposerClient.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080034
35namespace android {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080036// ----------------------------------------------------------------------------
37
Colin Crossa2362b42016-09-26 13:48:25 -070038struct ComposerState;
39struct DisplayState;
Jesse Hall646f5412014-08-07 22:19:07 -070040struct DisplayInfo;
Lajos Molnare7bda062014-09-18 20:05:27 -070041struct DisplayStatInfo;
Dan Stozac4f471e2016-03-24 09:31:08 -070042class HdrCapabilities;
Mathias Agopiand0566bc2011-11-17 17:49:17 -080043class IDisplayEventConnection;
44class IMemoryHeap;
Dan Stozac1879002014-05-22 15:59:05 -070045class Rect;
Mathias Agopiana67932f2011-04-20 14:20:59 -070046
Andy McFadden882e3a32013-01-08 16:06:15 -080047/*
48 * This class defines the Binder IPC interface for accessing various
49 * SurfaceFlinger features.
50 */
Mathias Agopian3165cc22012-08-08 19:42:09 -070051class ISurfaceComposer: public IInterface {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080052public:
Colin Cross17576de2016-09-26 13:07:06 -070053 DECLARE_META_INTERFACE(SurfaceComposer)
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080054
Mathias Agopian3165cc22012-08-08 19:42:09 -070055 // flags for setTransactionState()
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080056 enum {
Mathias Agopian3165cc22012-08-08 19:42:09 -070057 eSynchronous = 0x01,
Jamie Gennis2d5e2302012-10-15 18:24:43 -070058 eAnimation = 0x02,
Jamie Gennis28378392011-10-12 17:39:00 -070059 };
60
Mathias Agopiane57f2922012-08-09 16:29:12 -070061 enum {
62 eDisplayIdMain = 0,
63 eDisplayIdHdmi = 1
64 };
65
Riley Andrewsc3ebe662014-09-04 16:20:31 -070066 enum Rotation {
67 eRotateNone = 0,
68 eRotate90 = 1,
69 eRotate180 = 2,
70 eRotate270 = 3
71 };
72
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080073 /* create connection with surface flinger, requires
74 * ACCESS_SURFACE_FLINGER permission
75 */
Mathias Agopian7e27f052010-05-28 14:22:23 -070076 virtual sp<ISurfaceComposerClient> createConnection() = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080077
Jamie Gennis9a78c902011-01-12 18:30:40 -080078 /* create a graphic buffer allocator
79 */
80 virtual sp<IGraphicBufferAlloc> createGraphicBufferAlloc() = 0;
81
Mathias Agopiane57f2922012-08-09 16:29:12 -070082 /* return an IDisplayEventConnection */
83 virtual sp<IDisplayEventConnection> createDisplayEventConnection() = 0;
84
Jesse Hall6c913be2013-08-08 12:15:49 -070085 /* create a virtual display
Mathias Agopiane57f2922012-08-09 16:29:12 -070086 * requires ACCESS_SURFACE_FLINGER permission.
87 */
Jamie Gennisdd3cb842012-10-19 18:19:11 -070088 virtual sp<IBinder> createDisplay(const String8& displayName,
89 bool secure) = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -070090
Jesse Hall6c913be2013-08-08 12:15:49 -070091 /* destroy a virtual display
92 * requires ACCESS_SURFACE_FLINGER permission.
93 */
94 virtual void destroyDisplay(const sp<IBinder>& display) = 0;
95
Mathias Agopiane57f2922012-08-09 16:29:12 -070096 /* get the token for the existing default displays. possible values
97 * for id are eDisplayIdMain and eDisplayIdHdmi.
98 */
99 virtual sp<IBinder> getBuiltInDisplay(int32_t id) = 0;
100
Mathias Agopian9cce3252010-02-09 17:46:37 -0800101 /* open/close transactions. requires ACCESS_SURFACE_FLINGER permission */
Mathias Agopian3165cc22012-08-08 19:42:09 -0700102 virtual void setTransactionState(const Vector<ComposerState>& state,
103 const Vector<DisplayState>& displays, uint32_t flags) = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800104
105 /* signal that we're done booting.
Mathias Agopian9cce3252010-02-09 17:46:37 -0800106 * Requires ACCESS_SURFACE_FLINGER permission
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800107 */
108 virtual void bootFinished() = 0;
109
Andy McFadden2adaf042012-12-18 09:49:45 -0800110 /* verify that an IGraphicBufferProducer was created by SurfaceFlinger.
Mathias Agopiane57f2922012-08-09 16:29:12 -0700111 */
112 virtual bool authenticateSurfaceTexture(
Andy McFadden2adaf042012-12-18 09:49:45 -0800113 const sp<IGraphicBufferProducer>& surface) const = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700114
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700115 /* set display power mode. depending on the mode, it can either trigger
116 * screen on, off or low power mode and wait for it to complete.
Mathias Agopian041a0752013-03-15 18:31:56 -0700117 * requires ACCESS_SURFACE_FLINGER permission.
118 */
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700119 virtual void setPowerMode(const sp<IBinder>& display, int mode) = 0;
Mathias Agopian3094df32012-06-18 18:06:45 -0700120
Dan Stoza7f7da322014-05-02 15:26:25 -0700121 /* returns information for each configuration of the given display
Jeff Brown9d4e3d22012-08-24 20:00:51 -0700122 * intended to be used to get information about built-in displays */
Dan Stoza7f7da322014-05-02 15:26:25 -0700123 virtual status_t getDisplayConfigs(const sp<IBinder>& display,
124 Vector<DisplayInfo>* configs) = 0;
125
Lajos Molnar67d8bd62014-09-11 14:58:45 -0700126 /* returns display statistics for a given display
127 * intended to be used by the media framework to properly schedule
128 * video frames */
129 virtual status_t getDisplayStats(const sp<IBinder>& display,
130 DisplayStatInfo* stats) = 0;
131
Dan Stoza7f7da322014-05-02 15:26:25 -0700132 /* indicates which of the configurations returned by getDisplayInfo is
133 * currently active */
134 virtual int getActiveConfig(const sp<IBinder>& display) = 0;
135
136 /* specifies which configuration (of those returned by getDisplayInfo)
137 * should be used */
138 virtual status_t setActiveConfig(const sp<IBinder>& display, int id) = 0;
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800139
Michael Wright28f24d02016-07-12 13:30:53 -0700140 virtual status_t getDisplayColorModes(const sp<IBinder>& display,
141 Vector<android_color_mode_t>* outColorModes) = 0;
142 virtual android_color_mode_t getActiveColorMode(const sp<IBinder>& display) = 0;
143 virtual status_t setActiveColorMode(const sp<IBinder>& display,
144 android_color_mode_t colorMode) = 0;
145
Mathias Agopian041a0752013-03-15 18:31:56 -0700146 /* Capture the specified screen. requires READ_FRAME_BUFFER permission
147 * This function will fail if there is a secure window on screen.
148 */
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800149 virtual status_t captureScreen(const sp<IBinder>& display,
150 const sp<IGraphicBufferProducer>& producer,
Dan Stozac1879002014-05-22 15:59:05 -0700151 Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight,
Dan Stozac7014012014-02-14 15:03:43 -0800152 uint32_t minLayerZ, uint32_t maxLayerZ,
Riley Andrewsc3ebe662014-09-04 16:20:31 -0700153 bool useIdentityTransform,
154 Rotation rotation = eRotateNone) = 0;
Svetoslavd85084b2014-03-20 10:28:31 -0700155
Svetoslavd85084b2014-03-20 10:28:31 -0700156 /* Clears the frame statistics for animations.
157 *
158 * Requires the ACCESS_SURFACE_FLINGER permission.
159 */
160 virtual status_t clearAnimationFrameStats() = 0;
161
162 /* Gets the frame statistics for animations.
163 *
164 * Requires the ACCESS_SURFACE_FLINGER permission.
165 */
166 virtual status_t getAnimationFrameStats(FrameStats* outStats) const = 0;
Dan Stozac4f471e2016-03-24 09:31:08 -0700167
168 /* Gets the supported HDR capabilities of the given display.
169 *
170 * Requires the ACCESS_SURFACE_FLINGER permission.
171 */
172 virtual status_t getHdrCapabilities(const sp<IBinder>& display,
173 HdrCapabilities* outCapabilities) const = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800174};
175
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800176// ----------------------------------------------------------------------------
177
Mathias Agopian3165cc22012-08-08 19:42:09 -0700178class BnSurfaceComposer: public BnInterface<ISurfaceComposer> {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800179public:
180 enum {
181 // Note: BOOT_FINISHED must remain this value, it is called from
182 // Java by ActivityManagerService.
183 BOOT_FINISHED = IBinder::FIRST_CALL_TRANSACTION,
184 CREATE_CONNECTION,
Jamie Gennis9a78c902011-01-12 18:30:40 -0800185 CREATE_GRAPHIC_BUFFER_ALLOC,
Mathias Agopiand0566bc2011-11-17 17:49:17 -0800186 CREATE_DISPLAY_EVENT_CONNECTION,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700187 CREATE_DISPLAY,
Jesse Hall6c913be2013-08-08 12:15:49 -0700188 DESTROY_DISPLAY,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700189 GET_BUILT_IN_DISPLAY,
190 SET_TRANSACTION_STATE,
191 AUTHENTICATE_SURFACE,
Dan Stoza7f7da322014-05-02 15:26:25 -0700192 GET_DISPLAY_CONFIGS,
193 GET_ACTIVE_CONFIG,
194 SET_ACTIVE_CONFIG,
Mathias Agopian3094df32012-06-18 18:06:45 -0700195 CONNECT_DISPLAY,
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800196 CAPTURE_SCREEN,
Svetoslavd85084b2014-03-20 10:28:31 -0700197 CLEAR_ANIMATION_FRAME_STATS,
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700198 GET_ANIMATION_FRAME_STATS,
199 SET_POWER_MODE,
Lajos Molnar67d8bd62014-09-11 14:58:45 -0700200 GET_DISPLAY_STATS,
Dan Stozac4f471e2016-03-24 09:31:08 -0700201 GET_HDR_CAPABILITIES,
Michael Wright28f24d02016-07-12 13:30:53 -0700202 GET_DISPLAY_COLOR_MODES,
203 GET_ACTIVE_COLOR_MODE,
204 SET_ACTIVE_COLOR_MODE,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800205 };
206
Mathias Agopian3165cc22012-08-08 19:42:09 -0700207 virtual status_t onTransact(uint32_t code, const Parcel& data,
208 Parcel* reply, uint32_t flags = 0);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800209};
210
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800211// ----------------------------------------------------------------------------
212
213}; // namespace android
214
Mathias Agopian90ac7992012-02-25 18:48:35 -0800215#endif // ANDROID_GUI_ISURFACE_COMPOSER_H