blob: c8b9512e973083c31db3be35ddb218f740786627 [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>
Mathias Agopiana1e6bc82010-07-14 18:41:18 -070032#include <binder/BinderService.h>
Mathias Agopian375f5632009-06-15 18:24:59 -070033
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080034#include <ui/PixelFormat.h>
Mathias Agopian9cce3252010-02-09 17:46:37 -080035#include <surfaceflinger/ISurfaceComposer.h>
Mathias Agopian7e27f052010-05-28 14:22:23 -070036#include <surfaceflinger/ISurfaceComposerClient.h>
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080037
38#include "Barrier.h"
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080039#include "Layer.h"
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080040
Mathias Agopianf1d8e872009-04-20 19:39:12 -070041#include "MessageQueue.h"
42
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080043namespace android {
44
45// ---------------------------------------------------------------------------
46
47class Client;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080048class DisplayHardware;
49class FreezeLock;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080050class Layer;
Mathias Agopianb7e930d2010-06-01 15:12:58 -070051class LayerBlur;
52class LayerDim;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080053class LayerBuffer;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080054
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080055#define LIKELY( exp ) (__builtin_expect( (exp) != 0, true ))
56#define UNLIKELY( exp ) (__builtin_expect( (exp) != 0, false ))
57
58// ---------------------------------------------------------------------------
59
Mathias Agopian96f08192010-06-02 23:28:45 -070060class Client : public BnSurfaceComposerClient
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080061{
62public:
Mathias Agopian96f08192010-06-02 23:28:45 -070063 Client(const sp<SurfaceFlinger>& flinger);
64 ~Client();
65
66 status_t initCheck() const;
67
68 // protected by SurfaceFlinger::mStateLock
69 ssize_t attachLayer(const sp<LayerBaseClient>& layer);
Mathias Agopianb7e930d2010-06-01 15:12:58 -070070 void detachLayer(const LayerBaseClient* layer);
Mathias Agopian96f08192010-06-02 23:28:45 -070071 sp<LayerBaseClient> getLayerUser(int32_t i) const;
Mathias Agopian96f08192010-06-02 23:28:45 -070072
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -080073private:
Mathias Agopian96f08192010-06-02 23:28:45 -070074
75 // ISurfaceComposerClient interface
76 virtual sp<IMemoryHeap> getControlBlock() const;
Mathias Agopianb7e930d2010-06-01 15:12:58 -070077 virtual ssize_t getTokenForSurface(const sp<ISurface>& sur) const;
Mathias Agopian96f08192010-06-02 23:28:45 -070078 virtual sp<ISurface> createSurface(
79 surface_data_t* params, int pid, const String8& name,
80 DisplayID display, uint32_t w, uint32_t h,PixelFormat format,
81 uint32_t flags);
82 virtual status_t destroySurface(SurfaceID surfaceId);
83 virtual status_t setState(int32_t count, const layer_state_t* states);
84
Mathias Agopian96f08192010-06-02 23:28:45 -070085 DefaultKeyedVector< size_t, wp<LayerBaseClient> > mLayers;
Mathias Agopianb7e930d2010-06-01 15:12:58 -070086 sp<SurfaceFlinger> mFlinger;
87 int32_t mNameGenerator;
88};
89
90class UserClient : public BnSurfaceComposerClient
91{
92public:
93 // pointer to this client's control block
94 SharedClient* ctrlblk;
95
96public:
97 UserClient(const sp<SurfaceFlinger>& flinger);
98 ~UserClient();
99
100 status_t initCheck() const;
101
102 // protected by SurfaceFlinger::mStateLock
103 void detachLayer(const Layer* layer);
104
105private:
106
107 // ISurfaceComposerClient interface
108 virtual sp<IMemoryHeap> getControlBlock() const;
109 virtual ssize_t getTokenForSurface(const sp<ISurface>& sur) const;
110 virtual sp<ISurface> createSurface(
111 surface_data_t* params, int pid, const String8& name,
112 DisplayID display, uint32_t w, uint32_t h,PixelFormat format,
113 uint32_t flags);
114 virtual status_t destroySurface(SurfaceID surfaceId);
115 virtual status_t setState(int32_t count, const layer_state_t* states);
116
117 // atomic-ops
118 mutable volatile int32_t mBitmap;
119
Mathias Agopian96f08192010-06-02 23:28:45 -0700120 sp<IMemoryHeap> mCblkHeap;
121 sp<SurfaceFlinger> mFlinger;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800122};
123
124// ---------------------------------------------------------------------------
125
126class GraphicPlane
127{
128public:
129 static status_t orientationToTransfrom(int orientation, int w, int h,
130 Transform* tr);
131
132 GraphicPlane();
133 ~GraphicPlane();
134
135 bool initialized() const;
136
137 void setDisplayHardware(DisplayHardware *);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800138 status_t setOrientation(int orientation);
Mathias Agopian0d1318b2009-03-27 17:58:20 -0700139 int getOrientation() const { return mOrientation; }
Mathias Agopian2b92d892010-02-08 15:49:35 -0800140 int getWidth() const;
141 int getHeight() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800142
143 const DisplayHardware& displayHardware() const;
144 const Transform& transform() const;
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700145 EGLDisplay getEGLDisplay() const;
146
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800147private:
148 GraphicPlane(const GraphicPlane&);
149 GraphicPlane operator = (const GraphicPlane&);
150
151 DisplayHardware* mHw;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800152 Transform mGlobalTransform;
Mathias Agopian2b92d892010-02-08 15:49:35 -0800153 Transform mDisplayTransform;
Mathias Agopian0d1318b2009-03-27 17:58:20 -0700154 int mOrientation;
Mathias Agopian2b92d892010-02-08 15:49:35 -0800155 float mDisplayWidth;
156 float mDisplayHeight;
157 int mWidth;
158 int mHeight;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800159};
160
161// ---------------------------------------------------------------------------
162
163enum {
164 eTransactionNeeded = 0x01,
165 eTraversalNeeded = 0x02
166};
167
Mathias Agopiana1e6bc82010-07-14 18:41:18 -0700168class SurfaceFlinger :
169 public BinderService<SurfaceFlinger>,
170 public BnSurfaceComposer,
171 protected Thread
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800172{
173public:
Mathias Agopiana1e6bc82010-07-14 18:41:18 -0700174 static char const* getServiceName() { return "SurfaceFlinger"; }
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800175
176 SurfaceFlinger();
177 virtual ~SurfaceFlinger();
178 void init();
179
180 virtual status_t onTransact(
181 uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags);
182
183 virtual status_t dump(int fd, const Vector<String16>& args);
184
185 // ISurfaceComposer interface
Mathias Agopian7e27f052010-05-28 14:22:23 -0700186 virtual sp<ISurfaceComposerClient> createConnection();
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700187 virtual sp<ISurfaceComposerClient> createClientConnection();
Mathias Agopian7303c6b2009-07-02 18:11:53 -0700188 virtual sp<IMemoryHeap> getCblk() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800189 virtual void bootFinished();
190 virtual void openGlobalTransaction();
191 virtual void closeGlobalTransaction();
192 virtual status_t freezeDisplay(DisplayID dpy, uint32_t flags);
193 virtual status_t unfreezeDisplay(DisplayID dpy, uint32_t flags);
Mathias Agopianc08731e2009-03-27 18:11:38 -0700194 virtual int setOrientation(DisplayID dpy, int orientation, uint32_t flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800195 virtual void signal() const;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800196
197 void screenReleased(DisplayID dpy);
198 void screenAcquired(DisplayID dpy);
199
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800200 overlay_control_device_t* getOverlayEngine() const;
201
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700202 status_t removeLayer(const sp<LayerBase>& layer);
203 status_t addLayer(const sp<LayerBase>& layer);
204 status_t invalidateLayerVisibility(const sp<LayerBase>& layer);
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700205
206 sp<Layer> getLayer(const sp<ISurface>& sur) const;
207
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800208private:
Mathias Agopian96f08192010-06-02 23:28:45 -0700209 friend class Client;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800210 friend class LayerBase;
211 friend class LayerBuffer;
212 friend class LayerBaseClient;
Mathias Agopian1df3bbb2009-07-06 19:04:03 -0700213 friend class LayerBaseClient::Surface;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800214 friend class Layer;
215 friend class LayerBlur;
Mathias Agopian945ebbf2009-06-18 18:48:39 -0700216 friend class LayerDim;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800217
Mathias Agopian96f08192010-06-02 23:28:45 -0700218 sp<ISurface> createSurface(const sp<Client>& client,
219 int pid, const String8& name,
Mathias Agopian7e27f052010-05-28 14:22:23 -0700220 ISurfaceComposerClient::surface_data_t* params,
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800221 DisplayID display, uint32_t w, uint32_t h, PixelFormat format,
222 uint32_t flags);
223
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700224 sp<Layer> createNormalSurface(
Mathias Agopianf9d93272009-06-19 17:00:27 -0700225 const sp<Client>& client, DisplayID display,
Mathias Agopian96f08192010-06-02 23:28:45 -0700226 uint32_t w, uint32_t h, uint32_t flags,
Mathias Agopian1c97d2e2009-08-19 17:46:26 -0700227 PixelFormat& format);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800228
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700229 sp<LayerBlur> createBlurSurface(
Mathias Agopianf9d93272009-06-19 17:00:27 -0700230 const sp<Client>& client, DisplayID display,
Mathias Agopian96f08192010-06-02 23:28:45 -0700231 uint32_t w, uint32_t h, uint32_t flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800232
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700233 sp<LayerDim> createDimSurface(
Mathias Agopianf9d93272009-06-19 17:00:27 -0700234 const sp<Client>& client, DisplayID display,
Mathias Agopian96f08192010-06-02 23:28:45 -0700235 uint32_t w, uint32_t h, uint32_t flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800236
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700237 sp<LayerBuffer> createPushBuffersSurface(
Mathias Agopianf9d93272009-06-19 17:00:27 -0700238 const sp<Client>& client, DisplayID display,
Mathias Agopian96f08192010-06-02 23:28:45 -0700239 uint32_t w, uint32_t h, uint32_t flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800240
Mathias Agopian96f08192010-06-02 23:28:45 -0700241 status_t removeSurface(const sp<Client>& client, SurfaceID sid);
Mathias Agopian9a112062009-04-17 19:36:26 -0700242 status_t destroySurface(const sp<LayerBaseClient>& layer);
Mathias Agopian96f08192010-06-02 23:28:45 -0700243 status_t setClientState(const sp<Client>& client,
244 int32_t count, const layer_state_t* states);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800245
246
247 class LayerVector {
248 public:
249 inline LayerVector() { }
250 LayerVector(const LayerVector&);
251 inline size_t size() const { return layers.size(); }
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700252 inline sp<LayerBase> const* array() const { return layers.array(); }
253 ssize_t add(const sp<LayerBase>&, Vector< sp<LayerBase> >::compar_t);
254 ssize_t remove(const sp<LayerBase>&);
255 ssize_t reorder(const sp<LayerBase>&, Vector< sp<LayerBase> >::compar_t);
256 ssize_t indexOf(const sp<LayerBase>& key, size_t guess=0) const;
257 inline sp<LayerBase> operator [] (size_t i) const { return layers[i]; }
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800258 private:
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700259 KeyedVector< sp<LayerBase> , size_t> lookup;
260 Vector< sp<LayerBase> > layers;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800261 };
262
263 struct State {
264 State() {
265 orientation = ISurfaceComposer::eOrientationDefault;
266 freezeDisplay = 0;
267 }
268 LayerVector layersSortedByZ;
269 uint8_t orientation;
Mathias Agopianc08731e2009-03-27 18:11:38 -0700270 uint8_t orientationType;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800271 uint8_t freezeDisplay;
272 };
273
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800274 virtual bool threadLoop();
275 virtual status_t readyToRun();
276 virtual void onFirstRef();
277
Andy McFadden550a1142009-10-29 10:19:34 -0700278public: // hack to work around gcc 4.0.3 bug
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800279 const GraphicPlane& graphicPlane(int dpy) const;
280 GraphicPlane& graphicPlane(int dpy);
Andy McFadden550a1142009-10-29 10:19:34 -0700281private:
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800282
283 void waitForEvent();
Andy McFadden2944a2b2009-09-21 14:33:20 -0700284public: // hack to work around gcc 4.0.3 bug
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800285 void signalEvent();
Andy McFadden2944a2b2009-09-21 14:33:20 -0700286private:
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800287 void handleConsoleEvents();
288 void handleTransaction(uint32_t transactionFlags);
Mathias Agopian3d579642009-06-04 18:46:21 -0700289 void handleTransactionLocked(
290 uint32_t transactionFlags,
291 Vector< sp<LayerBase> >& ditchedLayers);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800292
293 void computeVisibleRegions(
294 LayerVector& currentLayers,
295 Region& dirtyRegion,
296 Region& wormholeRegion);
297
298 void handlePageFlip();
299 bool lockPageFlip(const LayerVector& currentLayers);
300 void unlockPageFlip(const LayerVector& currentLayers);
301 void handleRepaint();
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800302 void postFramebuffer();
303 void composeSurfaces(const Region& dirty);
304 void unlockClients();
305
306
Mathias Agopian96f08192010-06-02 23:28:45 -0700307 ssize_t addClientLayer(const sp<Client>& client,
308 const sp<LayerBaseClient>& lbc);
Mathias Agopian076b1cc2009-04-10 14:24:30 -0700309 status_t addLayer_l(const sp<LayerBase>& layer);
310 status_t removeLayer_l(const sp<LayerBase>& layer);
Mathias Agopian9a112062009-04-17 19:36:26 -0700311 status_t purgatorizeLayer_l(const sp<LayerBase>& layer);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800312
313 uint32_t getTransactionFlags(uint32_t flags);
Mathias Agopianbb641242010-05-18 17:06:55 -0700314 uint32_t setTransactionFlags(uint32_t flags);
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800315 void commitTransaction();
316
317
318 friend class FreezeLock;
319 sp<FreezeLock> getFreezeLock() const;
Mathias Agopian04087722009-12-01 17:23:28 -0800320 inline void incFreezeCount() {
321 if (mFreezeCount == 0)
322 mFreezeDisplayTime = 0;
323 mFreezeCount++;
324 }
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800325 inline void decFreezeCount() { if (mFreezeCount > 0) mFreezeCount--; }
326 inline bool hasFreezeRequest() const { return mFreezeDisplay; }
327 inline bool isFrozen() const {
Mathias Agopian3330b202009-10-05 17:07:12 -0700328 return (mFreezeDisplay || mFreezeCount>0) && mBootFinished;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800329 }
330
331
332 void debugFlashRegions();
333 void debugShowFPS() const;
334 void drawWormhole() const;
335
Mathias Agopianf1d8e872009-04-20 19:39:12 -0700336
337 mutable MessageQueue mEventQueue;
Mathias Agopianbb641242010-05-18 17:06:55 -0700338
339 status_t postMessageAsync(const sp<MessageBase>& msg,
340 nsecs_t reltime=0, uint32_t flags = 0);
341
342 status_t postMessageSync(const sp<MessageBase>& msg,
343 nsecs_t reltime=0, uint32_t flags = 0);
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700344
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800345 // access must be protected by mStateLock
346 mutable Mutex mStateLock;
347 State mCurrentState;
348 State mDrawingState;
349 volatile int32_t mTransactionFlags;
350 volatile int32_t mTransactionCount;
351 Condition mTransactionCV;
Mathias Agopiancbb288b2009-09-07 16:32:45 -0700352 bool mResizeTransationPending;
Mathias Agopian96f08192010-06-02 23:28:45 -0700353
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800354 // protected by mStateLock (but we could use another lock)
Mathias Agopian96f08192010-06-02 23:28:45 -0700355 GraphicPlane mGraphicPlanes[1];
356 bool mLayersRemoved;
Mathias Agopianb7e930d2010-06-01 15:12:58 -0700357 DefaultKeyedVector< wp<IBinder>, wp<Layer> > mLayerMap;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800358
359 // constant members (no synchronization needed for access)
Mathias Agopian7303c6b2009-07-02 18:11:53 -0700360 sp<IMemoryHeap> mServerHeap;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800361 surface_flinger_cblk_t* mServerCblk;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800362 GLuint mWormholeTexName;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800363 nsecs_t mBootTime;
Mathias Agopian375f5632009-06-15 18:24:59 -0700364 Permission mHardwareTest;
365 Permission mAccessSurfaceFlinger;
366 Permission mDump;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800367
368 // Can only accessed from the main thread, these members
369 // don't need synchronization
370 Region mDirtyRegion;
Mathias Agopian97011222009-07-28 10:57:27 -0700371 Region mDirtyRegionRemovedLayer;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800372 Region mInvalidRegion;
373 Region mWormholeRegion;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800374 bool mVisibleRegionsDirty;
375 bool mDeferReleaseConsole;
376 bool mFreezeDisplay;
377 int32_t mFreezeCount;
378 nsecs_t mFreezeDisplayTime;
Mathias Agopian4da75192010-08-10 17:19:56 -0700379 Vector< sp<LayerBase> > mVisibleLayersSortedByZ;
380
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800381
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800382 // don't use a lock for these, we don't care
383 int mDebugRegion;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800384 int mDebugBackground;
Mathias Agopian9795c422009-08-26 16:36:26 -0700385 volatile nsecs_t mDebugInSwapBuffers;
386 nsecs_t mLastSwapBufferTime;
387 volatile nsecs_t mDebugInTransaction;
388 nsecs_t mLastTransactionTime;
Mathias Agopian3330b202009-10-05 17:07:12 -0700389 bool mBootFinished;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800390
391 // these are thread safe
392 mutable Barrier mReadyToRunBarrier;
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800393
394 // atomic variables
395 enum {
396 eConsoleReleased = 1,
397 eConsoleAcquired = 2
398 };
399 volatile int32_t mConsoleSignals;
400
401 // only written in the main thread, only read in other threads
402 volatile int32_t mSecureFrameBuffer;
403};
404
405// ---------------------------------------------------------------------------
406
407class FreezeLock : public LightRefBase<FreezeLock> {
408 SurfaceFlinger* mFlinger;
409public:
410 FreezeLock(SurfaceFlinger* flinger)
411 : mFlinger(flinger) {
412 mFlinger->incFreezeCount();
413 }
414 ~FreezeLock() {
415 mFlinger->decFreezeCount();
416 }
417};
418
419// ---------------------------------------------------------------------------
The Android Open Source Projectedbf3b62009-03-03 19:31:44 -0800420}; // namespace android
421
422#endif // ANDROID_SURFACE_FLINGER_H