diff options
| author | 2011-03-07 18:00:20 -0800 | |
|---|---|---|
| committer | 2011-03-07 18:00:20 -0800 | |
| commit | f4e1ef0794e3ebde4ecbe46d717247b309cc6fa6 (patch) | |
| tree | 9fcac6b291dfa649884e075864ffe867c1483e7b /services/surfaceflinger/LayerBase.cpp | |
| parent | 8cb531d3c909cdf0963a8e9e0aee1b83bb46b494 (diff) | |
| parent | ee65ac8a71c24fc154b513faa13d24b4d4dfee4f (diff) | |
Merge "Fix [3513017] in lockscreen but showing empty launcher (live wallpaper) only" into gingerbread
Diffstat (limited to 'services/surfaceflinger/LayerBase.cpp')
| -rw-r--r-- | services/surfaceflinger/LayerBase.cpp | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/services/surfaceflinger/LayerBase.cpp b/services/surfaceflinger/LayerBase.cpp index 916d420ca4..0f02c6d3da 100644 --- a/services/surfaceflinger/LayerBase.cpp +++ b/services/surfaceflinger/LayerBase.cpp @@ -527,7 +527,9 @@ int32_t LayerBaseClient::sIdentity = 1; LayerBaseClient::LayerBaseClient(SurfaceFlinger* flinger, DisplayID display, const sp<Client>& client) - : LayerBase(flinger, display), mClientRef(client), + : LayerBase(flinger, display), + mHasSurface(false), + mClientRef(client), mIdentity(uint32_t(android_atomic_inc(&sIdentity))) { } @@ -544,14 +546,20 @@ sp<LayerBaseClient::Surface> LayerBaseClient::getSurface() { sp<Surface> s; Mutex::Autolock _l(mLock); - s = mClientSurface.promote(); - if (s == 0) { - s = createSurface(); - mClientSurface = s; - } + + LOG_ALWAYS_FATAL_IF(mHasSurface, + "LayerBaseClient::getSurface() has already been called"); + + mHasSurface = true; + s = createSurface(); + mClientSurfaceBinder = s->asBinder(); return s; } +wp<IBinder> LayerBaseClient::getSurfaceBinder() const { + return mClientSurfaceBinder; +} + sp<LayerBaseClient::Surface> LayerBaseClient::createSurface() const { return new Surface(mFlinger, mIdentity, |