blob: 1581084fdcbc6647522e94a0b3ff31cfc79badc7 [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>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080031#include <ui/PixelFormat.h>
Mathias Agopian9cce3252010-02-09 17:46:37 -080032
Mathias Agopian90ac7992012-02-25 18:48:35 -080033#include <gui/IGraphicBufferAlloc.h>
34#include <gui/ISurfaceComposerClient.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080035
36namespace android {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080037// ----------------------------------------------------------------------------
38
Mathias Agopian439cf852011-11-29 13:07:24 -080039class ComposerState;
Mathias Agopian8b33f032012-07-24 20:43:54 -070040class DisplayState;
Mathias Agopianc666cae2012-07-25 18:56:13 -070041class DisplayInfo;
Mathias Agopiand0566bc2011-11-17 17:49:17 -080042class IDisplayEventConnection;
43class IMemoryHeap;
Dan Stozac1879002014-05-22 15:59:05 -070044class Rect;
Mathias Agopiana67932f2011-04-20 14:20:59 -070045
Andy McFadden882e3a32013-01-08 16:06:15 -080046/*
47 * This class defines the Binder IPC interface for accessing various
48 * SurfaceFlinger features.
49 */
Mathias Agopian3165cc22012-08-08 19:42:09 -070050class ISurfaceComposer: public IInterface {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080051public:
52 DECLARE_META_INTERFACE(SurfaceComposer);
53
Mathias Agopian3165cc22012-08-08 19:42:09 -070054 // flags for setTransactionState()
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080055 enum {
Mathias Agopian3165cc22012-08-08 19:42:09 -070056 eSynchronous = 0x01,
Jamie Gennis2d5e2302012-10-15 18:24:43 -070057 eAnimation = 0x02,
Jamie Gennis28378392011-10-12 17:39:00 -070058 };
59
Mathias Agopiane57f2922012-08-09 16:29:12 -070060 enum {
61 eDisplayIdMain = 0,
62 eDisplayIdHdmi = 1
63 };
64
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080065 /* create connection with surface flinger, requires
66 * ACCESS_SURFACE_FLINGER permission
67 */
Mathias Agopian7e27f052010-05-28 14:22:23 -070068 virtual sp<ISurfaceComposerClient> createConnection() = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080069
Jamie Gennis9a78c902011-01-12 18:30:40 -080070 /* create a graphic buffer allocator
71 */
72 virtual sp<IGraphicBufferAlloc> createGraphicBufferAlloc() = 0;
73
Mathias Agopiane57f2922012-08-09 16:29:12 -070074 /* return an IDisplayEventConnection */
75 virtual sp<IDisplayEventConnection> createDisplayEventConnection() = 0;
76
Jesse Hall6c913be2013-08-08 12:15:49 -070077 /* create a virtual display
Mathias Agopiane57f2922012-08-09 16:29:12 -070078 * requires ACCESS_SURFACE_FLINGER permission.
79 */
Jamie Gennisdd3cb842012-10-19 18:19:11 -070080 virtual sp<IBinder> createDisplay(const String8& displayName,
81 bool secure) = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -070082
Jesse Hall6c913be2013-08-08 12:15:49 -070083 /* destroy a virtual display
84 * requires ACCESS_SURFACE_FLINGER permission.
85 */
86 virtual void destroyDisplay(const sp<IBinder>& display) = 0;
87
Mathias Agopiane57f2922012-08-09 16:29:12 -070088 /* get the token for the existing default displays. possible values
89 * for id are eDisplayIdMain and eDisplayIdHdmi.
90 */
91 virtual sp<IBinder> getBuiltInDisplay(int32_t id) = 0;
92
Mathias Agopian9cce3252010-02-09 17:46:37 -080093 /* open/close transactions. requires ACCESS_SURFACE_FLINGER permission */
Mathias Agopian3165cc22012-08-08 19:42:09 -070094 virtual void setTransactionState(const Vector<ComposerState>& state,
95 const Vector<DisplayState>& displays, uint32_t flags) = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080096
97 /* signal that we're done booting.
Mathias Agopian9cce3252010-02-09 17:46:37 -080098 * Requires ACCESS_SURFACE_FLINGER permission
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080099 */
100 virtual void bootFinished() = 0;
101
Andy McFadden2adaf042012-12-18 09:49:45 -0800102 /* verify that an IGraphicBufferProducer was created by SurfaceFlinger.
Mathias Agopiane57f2922012-08-09 16:29:12 -0700103 */
104 virtual bool authenticateSurfaceTexture(
Andy McFadden2adaf042012-12-18 09:49:45 -0800105 const sp<IGraphicBufferProducer>& surface) const = 0;
Mathias Agopiane57f2922012-08-09 16:29:12 -0700106
Mathias Agopian041a0752013-03-15 18:31:56 -0700107 /* triggers screen off and waits for it to complete
108 * requires ACCESS_SURFACE_FLINGER permission.
109 */
Andy McFaddenc01a79d2012-09-27 16:02:06 -0700110 virtual void blank(const sp<IBinder>& display) = 0;
Colin Cross8e533062012-06-07 13:17:52 -0700111
Mathias Agopian041a0752013-03-15 18:31:56 -0700112 /* triggers screen on and waits for it to complete
113 * requires ACCESS_SURFACE_FLINGER permission.
114 */
Andy McFaddenc01a79d2012-09-27 16:02:06 -0700115 virtual void unblank(const sp<IBinder>& display) = 0;
Mathias Agopian3094df32012-06-18 18:06:45 -0700116
Dan Stoza7f7da322014-05-02 15:26:25 -0700117 /* returns information for each configuration of the given display
Jeff Brown9d4e3d22012-08-24 20:00:51 -0700118 * intended to be used to get information about built-in displays */
Dan Stoza7f7da322014-05-02 15:26:25 -0700119 virtual status_t getDisplayConfigs(const sp<IBinder>& display,
120 Vector<DisplayInfo>* configs) = 0;
121
122 /* indicates which of the configurations returned by getDisplayInfo is
123 * currently active */
124 virtual int getActiveConfig(const sp<IBinder>& display) = 0;
125
126 /* specifies which configuration (of those returned by getDisplayInfo)
127 * should be used */
128 virtual status_t setActiveConfig(const sp<IBinder>& display, int id) = 0;
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800129
Mathias Agopian041a0752013-03-15 18:31:56 -0700130 /* Capture the specified screen. requires READ_FRAME_BUFFER permission
131 * This function will fail if there is a secure window on screen.
132 */
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800133 virtual status_t captureScreen(const sp<IBinder>& display,
134 const sp<IGraphicBufferProducer>& producer,
Dan Stozac1879002014-05-22 15:59:05 -0700135 Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight,
Dan Stozac7014012014-02-14 15:03:43 -0800136 uint32_t minLayerZ, uint32_t maxLayerZ,
137 bool useIdentityTransform) = 0;
Svetoslavd85084b2014-03-20 10:28:31 -0700138
Svetoslavd85084b2014-03-20 10:28:31 -0700139 /* Clears the frame statistics for animations.
140 *
141 * Requires the ACCESS_SURFACE_FLINGER permission.
142 */
143 virtual status_t clearAnimationFrameStats() = 0;
144
145 /* Gets the frame statistics for animations.
146 *
147 * Requires the ACCESS_SURFACE_FLINGER permission.
148 */
149 virtual status_t getAnimationFrameStats(FrameStats* outStats) const = 0;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800150};
151
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800152// ----------------------------------------------------------------------------
153
Mathias Agopian3165cc22012-08-08 19:42:09 -0700154class BnSurfaceComposer: public BnInterface<ISurfaceComposer> {
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800155public:
156 enum {
157 // Note: BOOT_FINISHED must remain this value, it is called from
158 // Java by ActivityManagerService.
159 BOOT_FINISHED = IBinder::FIRST_CALL_TRANSACTION,
160 CREATE_CONNECTION,
Jamie Gennis9a78c902011-01-12 18:30:40 -0800161 CREATE_GRAPHIC_BUFFER_ALLOC,
Mathias Agopiand0566bc2011-11-17 17:49:17 -0800162 CREATE_DISPLAY_EVENT_CONNECTION,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700163 CREATE_DISPLAY,
Jesse Hall6c913be2013-08-08 12:15:49 -0700164 DESTROY_DISPLAY,
Mathias Agopiane57f2922012-08-09 16:29:12 -0700165 GET_BUILT_IN_DISPLAY,
166 SET_TRANSACTION_STATE,
167 AUTHENTICATE_SURFACE,
Colin Cross8e533062012-06-07 13:17:52 -0700168 BLANK,
169 UNBLANK,
Dan Stoza7f7da322014-05-02 15:26:25 -0700170 GET_DISPLAY_CONFIGS,
171 GET_ACTIVE_CONFIG,
172 SET_ACTIVE_CONFIG,
Mathias Agopian3094df32012-06-18 18:06:45 -0700173 CONNECT_DISPLAY,
Mathias Agopian2a9fc492013-03-01 13:42:57 -0800174 CAPTURE_SCREEN,
Svetoslavd85084b2014-03-20 10:28:31 -0700175 CLEAR_ANIMATION_FRAME_STATS,
176 GET_ANIMATION_FRAME_STATS
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800177 };
178
Mathias Agopian3165cc22012-08-08 19:42:09 -0700179 virtual status_t onTransact(uint32_t code, const Parcel& data,
180 Parcel* reply, uint32_t flags = 0);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800181};
182
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800183// ----------------------------------------------------------------------------
184
185}; // namespace android
186
Mathias Agopian90ac7992012-02-25 18:48:35 -0800187#endif // ANDROID_GUI_ISURFACE_COMPOSER_H