2009-03-04 03:31:44 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2007 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ANDROID_LAYER_H
|
|
|
|
#define ANDROID_LAYER_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
2012-02-26 02:48:35 +00:00
|
|
|
#include <utils/Timers.h>
|
|
|
|
|
2009-10-06 00:07:12 +00:00
|
|
|
#include <ui/GraphicBuffer.h>
|
2009-03-04 03:31:44 +00:00
|
|
|
#include <ui/PixelFormat.h>
|
|
|
|
|
2012-02-26 02:48:35 +00:00
|
|
|
#include <gui/ISurfaceComposerClient.h>
|
|
|
|
|
2009-04-10 21:24:30 +00:00
|
|
|
#include <EGL/egl.h>
|
|
|
|
#include <EGL/eglext.h>
|
|
|
|
#include <GLES/gl.h>
|
|
|
|
#include <GLES/glext.h>
|
|
|
|
|
2012-12-05 00:51:15 +00:00
|
|
|
#include "SurfaceFlingerConsumer.h"
|
2012-11-09 03:23:28 +00:00
|
|
|
#include "FrameTracker.h"
|
2009-03-04 03:31:44 +00:00
|
|
|
#include "LayerBase.h"
|
2011-04-20 21:20:59 +00:00
|
|
|
#include "SurfaceTextureLayer.h"
|
2009-03-04 03:31:44 +00:00
|
|
|
#include "Transform.h"
|
|
|
|
|
|
|
|
namespace android {
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class Client;
|
2010-06-26 01:02:21 +00:00
|
|
|
class GLExtensions;
|
2009-03-04 03:31:44 +00:00
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
2013-01-09 00:06:15 +00:00
|
|
|
/*
|
|
|
|
* The Layer class is essentially a LayerBase combined with a BufferQueue.
|
|
|
|
* A new BufferQueue and a new SurfaceFlingerConsumer are created when the
|
|
|
|
* Layer is first referenced.
|
|
|
|
*
|
|
|
|
* This also implements onFrameAvailable(), which notifies SurfaceFlinger
|
|
|
|
* that new data has arrived.
|
|
|
|
*/
|
2012-10-29 20:36:11 +00:00
|
|
|
class Layer : public LayerBaseClient,
|
2012-12-05 00:51:15 +00:00
|
|
|
public SurfaceFlingerConsumer::FrameAvailableListener
|
2009-03-04 03:31:44 +00:00
|
|
|
{
|
2010-05-11 03:06:11 +00:00
|
|
|
public:
|
2013-01-09 00:06:15 +00:00
|
|
|
Layer(SurfaceFlinger* flinger, const sp<Client>& client);
|
2010-06-01 22:12:58 +00:00
|
|
|
virtual ~Layer();
|
2009-03-04 03:31:44 +00:00
|
|
|
|
2010-06-01 22:12:58 +00:00
|
|
|
virtual const char* getTypeId() const { return "Layer"; }
|
2009-03-04 03:31:44 +00:00
|
|
|
|
2010-06-01 22:12:58 +00:00
|
|
|
// the this layer's size and format
|
fix [2068105] implement queueBuffer/lockBuffer/dequeueBuffer properly
Rewrote SurfaceFlinger's buffer management from the ground-up.
The design now support an arbitrary number of buffers per surface, however the current implementation is limited to four. Currently only 2 buffers are used in practice.
The main new feature is to be able to dequeue all buffers at once (very important when there are only two).
A client can dequeue all buffers until there are none available, it can lock all buffers except the last one that is used for composition. The client will block then, until a new buffer is enqueued.
The current implementation requires that buffers are locked in the same order they are dequeued and enqueued in the same order they are locked. Only one buffer can be locked at a time.
eg. Allowed sequence: DQ, DQ, LOCK, Q, LOCK, Q
eg. Forbidden sequence: DQ, DQ, LOCK, LOCK, Q, Q
2009-09-07 23:32:45 +00:00
|
|
|
status_t setBuffers(uint32_t w, uint32_t h,
|
|
|
|
PixelFormat format, uint32_t flags=0);
|
2009-03-04 03:31:44 +00:00
|
|
|
|
2010-05-22 00:24:35 +00:00
|
|
|
bool isFixedSize() const;
|
2009-03-04 03:31:44 +00:00
|
|
|
|
2010-06-01 22:12:58 +00:00
|
|
|
// LayerBase interface
|
2012-08-05 07:40:46 +00:00
|
|
|
virtual void setGeometry(const sp<const DisplayDevice>& hw,
|
2012-06-29 21:12:52 +00:00
|
|
|
HWComposer::HWCLayerInterface& layer);
|
2012-08-05 07:40:46 +00:00
|
|
|
virtual void setPerFrameData(const sp<const DisplayDevice>& hw,
|
2012-08-02 21:01:42 +00:00
|
|
|
HWComposer::HWCLayerInterface& layer);
|
2012-08-05 07:40:46 +00:00
|
|
|
virtual void setAcquireFence(const sp<const DisplayDevice>& hw,
|
2012-08-02 21:01:42 +00:00
|
|
|
HWComposer::HWCLayerInterface& layer);
|
2012-08-05 07:40:46 +00:00
|
|
|
virtual void onLayerDisplayed(const sp<const DisplayDevice>& hw,
|
2012-08-02 21:01:42 +00:00
|
|
|
HWComposer::HWCLayerInterface* layer);
|
|
|
|
virtual bool onPreComposition();
|
|
|
|
virtual void onPostComposition();
|
2012-06-29 21:12:52 +00:00
|
|
|
|
2012-08-05 07:40:46 +00:00
|
|
|
virtual void onDraw(const sp<const DisplayDevice>& hw, const Region& clip) const;
|
2009-03-04 03:31:44 +00:00
|
|
|
virtual uint32_t doTransaction(uint32_t transactionFlags);
|
2012-06-29 21:12:52 +00:00
|
|
|
virtual Region latchBuffer(bool& recomputeVisibleRegions);
|
2011-04-20 21:20:59 +00:00
|
|
|
virtual bool isOpaque() const;
|
2009-03-04 03:31:44 +00:00
|
|
|
virtual bool isSecure() const { return mSecure; }
|
2011-03-10 01:05:02 +00:00
|
|
|
virtual bool isProtected() const;
|
2010-05-11 03:06:11 +00:00
|
|
|
virtual void onRemoved();
|
2011-09-20 22:13:14 +00:00
|
|
|
virtual sp<Layer> getLayer() const { return const_cast<Layer*>(this); }
|
2011-09-17 00:31:54 +00:00
|
|
|
virtual void setName(const String8& name);
|
2012-09-14 01:17:13 +00:00
|
|
|
virtual bool isVisible() const;
|
2010-06-01 22:12:58 +00:00
|
|
|
|
2011-08-18 01:19:00 +00:00
|
|
|
// LayerBaseClient interface
|
|
|
|
virtual wp<IBinder> getSurfaceTextureBinder() const;
|
|
|
|
|
fix [2068105] implement queueBuffer/lockBuffer/dequeueBuffer properly
Rewrote SurfaceFlinger's buffer management from the ground-up.
The design now support an arbitrary number of buffers per surface, however the current implementation is limited to four. Currently only 2 buffers are used in practice.
The main new feature is to be able to dequeue all buffers at once (very important when there are only two).
A client can dequeue all buffers until there are none available, it can lock all buffers except the last one that is used for composition. The client will block then, until a new buffer is enqueued.
The current implementation requires that buffers are locked in the same order they are dequeued and enqueued in the same order they are locked. Only one buffer can be locked at a time.
eg. Allowed sequence: DQ, DQ, LOCK, Q, LOCK, Q
eg. Forbidden sequence: DQ, DQ, LOCK, LOCK, Q, Q
2009-09-07 23:32:45 +00:00
|
|
|
// only for debugging
|
2011-09-20 22:13:14 +00:00
|
|
|
inline const sp<GraphicBuffer>& getActiveBuffer() const { return mActiveBuffer; }
|
2010-04-21 00:55:49 +00:00
|
|
|
|
2012-12-05 00:51:15 +00:00
|
|
|
// Updates the transform hint in our SurfaceFlingerConsumer to match
|
2012-11-22 00:02:13 +00:00
|
|
|
// the current orientation of the display device.
|
|
|
|
virtual void updateTransformHint(const sp<const DisplayDevice>& hw) const;
|
2012-09-14 23:10:11 +00:00
|
|
|
|
2010-04-21 00:55:49 +00:00
|
|
|
protected:
|
2011-04-20 21:20:59 +00:00
|
|
|
virtual void onFirstRef();
|
2010-04-21 00:55:49 +00:00
|
|
|
virtual void dump(String8& result, char* scratch, size_t size) const;
|
2012-01-20 02:34:40 +00:00
|
|
|
virtual void dumpStats(String8& result, char* buffer, size_t SIZE) const;
|
2012-01-29 06:31:55 +00:00
|
|
|
virtual void clearStats();
|
2010-04-21 00:55:49 +00:00
|
|
|
|
2009-03-04 03:31:44 +00:00
|
|
|
private:
|
2013-01-09 00:06:15 +00:00
|
|
|
// Creates an instance of ISurface for this Layer.
|
2011-04-20 21:20:59 +00:00
|
|
|
virtual sp<ISurface> createSurface();
|
2013-01-09 00:06:15 +00:00
|
|
|
|
2009-10-06 00:07:12 +00:00
|
|
|
uint32_t getEffectiveUsage(uint32_t usage) const;
|
2011-04-20 21:20:59 +00:00
|
|
|
bool isCropped() const;
|
2012-05-11 03:43:55 +00:00
|
|
|
Rect computeBufferCrop() const;
|
2011-04-20 21:20:59 +00:00
|
|
|
static bool getOpacityForFormat(uint32_t format);
|
2010-06-01 22:12:58 +00:00
|
|
|
|
2012-12-05 00:51:15 +00:00
|
|
|
// Interface implementation for SurfaceFlingerConsumer::FrameAvailableListener
|
2012-10-29 20:36:11 +00:00
|
|
|
virtual void onFrameAvailable();
|
|
|
|
|
2010-06-01 22:12:58 +00:00
|
|
|
// -----------------------------------------------------------------------
|
|
|
|
|
2011-04-20 21:20:59 +00:00
|
|
|
// constants
|
2012-12-05 00:51:15 +00:00
|
|
|
sp<SurfaceFlingerConsumer> mSurfaceFlingerConsumer;
|
2011-04-20 21:20:59 +00:00
|
|
|
GLuint mTextureName;
|
2010-06-01 22:12:58 +00:00
|
|
|
|
|
|
|
// thread-safe
|
2011-04-20 21:20:59 +00:00
|
|
|
volatile int32_t mQueuedFrames;
|
2013-02-05 21:30:24 +00:00
|
|
|
FrameTracker mFrameTracker;
|
2011-04-20 21:20:59 +00:00
|
|
|
|
|
|
|
// main thread
|
|
|
|
sp<GraphicBuffer> mActiveBuffer;
|
|
|
|
Rect mCurrentCrop;
|
|
|
|
uint32_t mCurrentTransform;
|
2011-07-18 23:15:08 +00:00
|
|
|
uint32_t mCurrentScalingMode;
|
2011-04-20 21:20:59 +00:00
|
|
|
bool mCurrentOpacity;
|
2012-02-24 04:05:39 +00:00
|
|
|
bool mRefreshPending;
|
2012-01-16 02:54:57 +00:00
|
|
|
bool mFrameLatencyNeeded;
|
2010-06-01 22:12:58 +00:00
|
|
|
|
|
|
|
// constants
|
|
|
|
PixelFormat mFormat;
|
2010-06-26 01:02:21 +00:00
|
|
|
const GLExtensions& mGLExtensions;
|
2011-04-20 21:20:59 +00:00
|
|
|
bool mOpaqueLayer;
|
2010-06-01 22:12:58 +00:00
|
|
|
|
|
|
|
// page-flip thread (currently main thread)
|
2011-01-19 23:27:27 +00:00
|
|
|
bool mSecure; // no screenshots
|
|
|
|
bool mProtectedByApp; // application requires protected path to external sink
|
2009-03-04 03:31:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
}; // namespace android
|
|
|
|
|
|
|
|
#endif // ANDROID_LAYER_H
|