blob: 9c8de512ed47293078bd1ae111301a88b604b7a2 [file] [log] [blame]
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2007 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
17#ifndef ANDROID_SURFACE_FLINGER_H
18#define ANDROID_SURFACE_FLINGER_H
19
20#include <stdint.h>
21#include <sys/types.h>
22
23#include <utils/SortedVector.h>
24#include <utils/KeyedVector.h>
25#include <utils/threads.h>
26#include <utils/Atomic.h>
27#include <utils/Errors.h>
Mathias Agopian076b1cc2009-04-10 14:24:30 -070028#include <utils/RefBase.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080029
Mathias Agopian7303c6b2009-07-02 18:11:53 -070030#include <binder/IMemory.h>
Mathias Agopian375f5632009-06-15 18:24:59 -070031#include <binder/Permission.h>
32
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080033#include <ui/PixelFormat.h>
Mathias Agopian9cce3252010-02-09 17:46:37 -080034#include <surfaceflinger/ISurfaceComposer.h>
35#include <surfaceflinger/ISurfaceFlingerClient.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080036
37#include "Barrier.h"
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080038#include "Layer.h"
39#include "Tokenizer.h"
40
Mathias Agopianf1d8e872009-04-20 19:39:12 -070041#include "MessageQueue.h"
42
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080043struct copybit_device_t;
44struct overlay_device_t;
45
46namespace android {
47
48// ---------------------------------------------------------------------------
49
50class Client;
51class BClient;
52class DisplayHardware;
53class FreezeLock;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080054class Layer;
55class LayerBuffer;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080056
57typedef int32_t ClientID;
58
59#define LIKELY( exp ) (__builtin_expect( (exp) != 0, true ))
60#define UNLIKELY( exp ) (__builtin_expect( (exp) != 0, false ))
61
62// ---------------------------------------------------------------------------
63
Mathias Agopianf9d93272009-06-19 17:00:27 -070064class Client : public RefBase
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080065{
66public:
67 Client(ClientID cid, const sp<SurfaceFlinger>& flinger);
68 ~Client();
69
70 int32_t generateId(int pid);
71 void free(int32_t id);
Mathias Agopian076b1cc2009-04-10 14:24:30 -070072 status_t bindLayer(const sp<LayerBaseClient>& layer, int32_t id);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080073
74 inline bool isValid(int32_t i) const;
Mathias Agopian076b1cc2009-04-10 14:24:30 -070075 sp<LayerBaseClient> getLayerUser(int32_t i) const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080076
Mathias Agopian7303c6b2009-07-02 18:11:53 -070077 const Vector< wp<LayerBaseClient> >& getLayers() const {
78 return mLayers;
79 }
80
81 const sp<IMemoryHeap>& getControlBlockMemory() const {
82 return mCblkHeap;
83 }
84
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080085 // pointer to this client's control block
Mathias Agopiancbb288b2009-09-07 16:32:45 -070086 SharedClient* ctrlblk;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080087 ClientID cid;
88
89
90private:
Mathias Agopian7303c6b2009-07-02 18:11:53 -070091 int getClientPid() const { return mPid; }
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080092
Mathias Agopian076b1cc2009-04-10 14:24:30 -070093 int mPid;
94 uint32_t mBitmap;
95 SortedVector<uint8_t> mInUse;
96 Vector< wp<LayerBaseClient> > mLayers;
Mathias Agopian7303c6b2009-07-02 18:11:53 -070097 sp<IMemoryHeap> mCblkHeap;
Mathias Agopian076b1cc2009-04-10 14:24:30 -070098 sp<SurfaceFlinger> mFlinger;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080099};
100
101// ---------------------------------------------------------------------------
102
103class GraphicPlane
104{
105public:
106 static status_t orientationToTransfrom(int orientation, int w, int h,
107 Transform* tr);
108
109 GraphicPlane();
110 ~GraphicPlane();
111
112 bool initialized() const;
113
114 void setDisplayHardware(DisplayHardware *);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800115 status_t setOrientation(int orientation);
Mathias Agopian0d1318b2009-03-27 17:58:20 -0700116 int getOrientation() const { return mOrientation; }
Mathias Agopian2b92d892010-02-08 15:49:35 -0800117 int getWidth() const;
118 int getHeight() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800119
120 const DisplayHardware& displayHardware() const;
121 const Transform& transform() const;
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700122 EGLDisplay getEGLDisplay() const;
123
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800124private:
125 GraphicPlane(const GraphicPlane&);
126 GraphicPlane operator = (const GraphicPlane&);
127
128 DisplayHardware* mHw;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800129 Transform mGlobalTransform;
Mathias Agopian2b92d892010-02-08 15:49:35 -0800130 Transform mDisplayTransform;
Mathias Agopian0d1318b2009-03-27 17:58:20 -0700131 int mOrientation;
Mathias Agopian2b92d892010-02-08 15:49:35 -0800132 float mDisplayWidth;
133 float mDisplayHeight;
134 int mWidth;
135 int mHeight;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800136};
137
138// ---------------------------------------------------------------------------
139
140enum {
141 eTransactionNeeded = 0x01,
142 eTraversalNeeded = 0x02
143};
144
145class SurfaceFlinger : public BnSurfaceComposer, protected Thread
146{
147public:
148 static void instantiate();
149 static void shutdown();
150
151 SurfaceFlinger();
152 virtual ~SurfaceFlinger();
153 void init();
154
155 virtual status_t onTransact(
156 uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags);
157
158 virtual status_t dump(int fd, const Vector<String16>& args);
159
160 // ISurfaceComposer interface
161 virtual sp<ISurfaceFlingerClient> createConnection();
Mathias Agopian7303c6b2009-07-02 18:11:53 -0700162 virtual sp<IMemoryHeap> getCblk() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800163 virtual void bootFinished();
164 virtual void openGlobalTransaction();
165 virtual void closeGlobalTransaction();
166 virtual status_t freezeDisplay(DisplayID dpy, uint32_t flags);
167 virtual status_t unfreezeDisplay(DisplayID dpy, uint32_t flags);
Mathias Agopianc08731e2009-03-27 18:11:38 -0700168 virtual int setOrientation(DisplayID dpy, int orientation, uint32_t flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800169 virtual void signal() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800170
171 void screenReleased(DisplayID dpy);
172 void screenAcquired(DisplayID dpy);
173
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800174 overlay_control_device_t* getOverlayEngine() const;
175
176
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700177 status_t removeLayer(const sp<LayerBase>& layer);
178 status_t addLayer(const sp<LayerBase>& layer);
179 status_t invalidateLayerVisibility(const sp<LayerBase>& layer);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800180
181private:
182 friend class BClient;
183 friend class LayerBase;
184 friend class LayerBuffer;
185 friend class LayerBaseClient;
Mathias Agopian1df3bbb2009-07-06 19:04:03 -0700186 friend class LayerBaseClient::Surface;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800187 friend class Layer;
188 friend class LayerBlur;
Mathias Agopian945ebbf2009-06-18 18:48:39 -0700189 friend class LayerDim;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800190
Mathias Agopian285dbde2010-03-01 16:09:43 -0800191 sp<ISurface> createSurface(ClientID client, int pid, const String8& name,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800192 ISurfaceFlingerClient::surface_data_t* params,
193 DisplayID display, uint32_t w, uint32_t h, PixelFormat format,
194 uint32_t flags);
195
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700196 sp<LayerBaseClient> createNormalSurfaceLocked(
Mathias Agopianf9d93272009-06-19 17:00:27 -0700197 const sp<Client>& client, DisplayID display,
Mathias Agopian1c97d2e2009-08-19 17:46:26 -0700198 int32_t id, uint32_t w, uint32_t h, uint32_t flags,
199 PixelFormat& format);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800200
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700201 sp<LayerBaseClient> createBlurSurfaceLocked(
Mathias Agopianf9d93272009-06-19 17:00:27 -0700202 const sp<Client>& client, DisplayID display,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800203 int32_t id, uint32_t w, uint32_t h, uint32_t flags);
204
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700205 sp<LayerBaseClient> createDimSurfaceLocked(
Mathias Agopianf9d93272009-06-19 17:00:27 -0700206 const sp<Client>& client, DisplayID display,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800207 int32_t id, uint32_t w, uint32_t h, uint32_t flags);
208
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700209 sp<LayerBaseClient> createPushBuffersSurfaceLocked(
Mathias Agopianf9d93272009-06-19 17:00:27 -0700210 const sp<Client>& client, DisplayID display,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800211 int32_t id, uint32_t w, uint32_t h, uint32_t flags);
212
Mathias Agopian9a112062009-04-17 19:36:26 -0700213 status_t removeSurface(SurfaceID surface_id);
214 status_t destroySurface(const sp<LayerBaseClient>& layer);
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700215 status_t setClientState(ClientID cid, int32_t count, const layer_state_t* states);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800216
217
218 class LayerVector {
219 public:
220 inline LayerVector() { }
221 LayerVector(const LayerVector&);
222 inline size_t size() const { return layers.size(); }
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700223 inline sp<LayerBase> const* array() const { return layers.array(); }
224 ssize_t add(const sp<LayerBase>&, Vector< sp<LayerBase> >::compar_t);
225 ssize_t remove(const sp<LayerBase>&);
226 ssize_t reorder(const sp<LayerBase>&, Vector< sp<LayerBase> >::compar_t);
227 ssize_t indexOf(const sp<LayerBase>& key, size_t guess=0) const;
228 inline sp<LayerBase> operator [] (size_t i) const { return layers[i]; }
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800229 private:
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700230 KeyedVector< sp<LayerBase> , size_t> lookup;
231 Vector< sp<LayerBase> > layers;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800232 };
233
234 struct State {
235 State() {
236 orientation = ISurfaceComposer::eOrientationDefault;
237 freezeDisplay = 0;
238 }
239 LayerVector layersSortedByZ;
240 uint8_t orientation;
Mathias Agopianc08731e2009-03-27 18:11:38 -0700241 uint8_t orientationType;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800242 uint8_t freezeDisplay;
243 };
244
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800245 virtual bool threadLoop();
246 virtual status_t readyToRun();
247 virtual void onFirstRef();
248
Andy McFadden550a1142009-10-29 10:19:34 -0700249public: // hack to work around gcc 4.0.3 bug
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800250 const GraphicPlane& graphicPlane(int dpy) const;
251 GraphicPlane& graphicPlane(int dpy);
Andy McFadden550a1142009-10-29 10:19:34 -0700252private:
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800253
254 void waitForEvent();
Andy McFadden2944a2b2009-09-21 14:33:20 -0700255public: // hack to work around gcc 4.0.3 bug
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800256 void signalEvent();
Andy McFadden2944a2b2009-09-21 14:33:20 -0700257private:
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800258 void signalDelayedEvent(nsecs_t delay);
259
260 void handleConsoleEvents();
261 void handleTransaction(uint32_t transactionFlags);
Mathias Agopian3d579642009-06-04 18:46:21 -0700262 void handleTransactionLocked(
263 uint32_t transactionFlags,
264 Vector< sp<LayerBase> >& ditchedLayers);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800265
266 void computeVisibleRegions(
267 LayerVector& currentLayers,
268 Region& dirtyRegion,
269 Region& wormholeRegion);
270
271 void handlePageFlip();
272 bool lockPageFlip(const LayerVector& currentLayers);
273 void unlockPageFlip(const LayerVector& currentLayers);
274 void handleRepaint();
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800275 void postFramebuffer();
276 void composeSurfaces(const Region& dirty);
277 void unlockClients();
278
279
280 void destroyConnection(ClientID cid);
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700281 sp<LayerBaseClient> getLayerUser_l(SurfaceID index) const;
282 status_t addLayer_l(const sp<LayerBase>& layer);
Mathias Agopian1b5e1022010-04-20 17:55:49 -0700283 status_t addClientLayer_l(const sp<LayerBaseClient>& lbc);
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700284 status_t removeLayer_l(const sp<LayerBase>& layer);
Mathias Agopian9a112062009-04-17 19:36:26 -0700285 status_t purgatorizeLayer_l(const sp<LayerBase>& layer);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800286 void free_resources_l();
287
288 uint32_t getTransactionFlags(uint32_t flags);
289 uint32_t setTransactionFlags(uint32_t flags, nsecs_t delay = 0);
290 void commitTransaction();
291
292
293 friend class FreezeLock;
294 sp<FreezeLock> getFreezeLock() const;
Mathias Agopian04087722009-12-01 17:23:28 -0800295 inline void incFreezeCount() {
296 if (mFreezeCount == 0)
297 mFreezeDisplayTime = 0;
298 mFreezeCount++;
299 }
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800300 inline void decFreezeCount() { if (mFreezeCount > 0) mFreezeCount--; }
301 inline bool hasFreezeRequest() const { return mFreezeDisplay; }
302 inline bool isFrozen() const {
Mathias Agopian3330b202009-10-05 17:07:12 -0700303 return (mFreezeDisplay || mFreezeCount>0) && mBootFinished;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800304 }
305
306
307 void debugFlashRegions();
308 void debugShowFPS() const;
309 void drawWormhole() const;
310
Mathias Agopianf1d8e872009-04-20 19:39:12 -0700311
312 mutable MessageQueue mEventQueue;
313
314
315
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800316 // access must be protected by mStateLock
317 mutable Mutex mStateLock;
318 State mCurrentState;
319 State mDrawingState;
320 volatile int32_t mTransactionFlags;
321 volatile int32_t mTransactionCount;
322 Condition mTransactionCV;
Mathias Agopiancbb288b2009-09-07 16:32:45 -0700323 bool mResizeTransationPending;
Mathias Agopian9a112062009-04-17 19:36:26 -0700324
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800325 // protected by mStateLock (but we could use another lock)
326 Tokenizer mTokens;
Mathias Agopianf9d93272009-06-19 17:00:27 -0700327 DefaultKeyedVector<ClientID, sp<Client> > mClientsMap;
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700328 DefaultKeyedVector<SurfaceID, sp<LayerBaseClient> > mLayerMap;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800329 GraphicPlane mGraphicPlanes[1];
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700330 bool mLayersRemoved;
Mathias Agopianf9d93272009-06-19 17:00:27 -0700331 Vector< sp<Client> > mDisconnectedClients;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800332
333 // constant members (no synchronization needed for access)
Mathias Agopian7303c6b2009-07-02 18:11:53 -0700334 sp<IMemoryHeap> mServerHeap;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800335 surface_flinger_cblk_t* mServerCblk;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800336 GLuint mWormholeTexName;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800337 nsecs_t mBootTime;
Mathias Agopian375f5632009-06-15 18:24:59 -0700338 Permission mHardwareTest;
339 Permission mAccessSurfaceFlinger;
340 Permission mDump;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800341
342 // Can only accessed from the main thread, these members
343 // don't need synchronization
344 Region mDirtyRegion;
Mathias Agopian97011222009-07-28 10:57:27 -0700345 Region mDirtyRegionRemovedLayer;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800346 Region mInvalidRegion;
347 Region mWormholeRegion;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800348 bool mVisibleRegionsDirty;
349 bool mDeferReleaseConsole;
350 bool mFreezeDisplay;
351 int32_t mFreezeCount;
352 nsecs_t mFreezeDisplayTime;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800353
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800354 // don't use a lock for these, we don't care
355 int mDebugRegion;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800356 int mDebugBackground;
Mathias Agopian9795c422009-08-26 16:36:26 -0700357 volatile nsecs_t mDebugInSwapBuffers;
358 nsecs_t mLastSwapBufferTime;
359 volatile nsecs_t mDebugInTransaction;
360 nsecs_t mLastTransactionTime;
Mathias Agopian3330b202009-10-05 17:07:12 -0700361 bool mBootFinished;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800362
363 // these are thread safe
364 mutable Barrier mReadyToRunBarrier;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800365
366 // atomic variables
367 enum {
368 eConsoleReleased = 1,
369 eConsoleAcquired = 2
370 };
371 volatile int32_t mConsoleSignals;
372
373 // only written in the main thread, only read in other threads
374 volatile int32_t mSecureFrameBuffer;
375};
376
377// ---------------------------------------------------------------------------
378
379class FreezeLock : public LightRefBase<FreezeLock> {
380 SurfaceFlinger* mFlinger;
381public:
382 FreezeLock(SurfaceFlinger* flinger)
383 : mFlinger(flinger) {
384 mFlinger->incFreezeCount();
385 }
386 ~FreezeLock() {
387 mFlinger->decFreezeCount();
388 }
389};
390
391// ---------------------------------------------------------------------------
392
393class BClient : public BnSurfaceFlingerClient
394{
395public:
396 BClient(SurfaceFlinger *flinger, ClientID cid,
Mathias Agopian7303c6b2009-07-02 18:11:53 -0700397 const sp<IMemoryHeap>& cblk);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800398 ~BClient();
399
400 // ISurfaceFlingerClient interface
Mathias Agopian7303c6b2009-07-02 18:11:53 -0700401 virtual sp<IMemoryHeap> getControlBlock() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800402
403 virtual sp<ISurface> createSurface(
Mathias Agopian285dbde2010-03-01 16:09:43 -0800404 surface_data_t* params, int pid, const String8& name,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800405 DisplayID display, uint32_t w, uint32_t h,PixelFormat format,
406 uint32_t flags);
407
408 virtual status_t destroySurface(SurfaceID surfaceId);
409 virtual status_t setState(int32_t count, const layer_state_t* states);
410
411private:
412 ClientID mId;
413 SurfaceFlinger* mFlinger;
Mathias Agopian7303c6b2009-07-02 18:11:53 -0700414 sp<IMemoryHeap> mCblk;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800415};
416
417// ---------------------------------------------------------------------------
418}; // namespace android
419
420#endif // ANDROID_SURFACE_FLINGER_H