Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2010 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_SF_HWCOMPOSER_H |
| 18 | #define ANDROID_SF_HWCOMPOSER_H |
| 19 | |
| 20 | #include <stdint.h> |
| 21 | #include <sys/types.h> |
| 22 | |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 23 | #include <hardware/hwcomposer_defs.h> |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 24 | |
Mathias Agopian | 921e6ac | 2012-07-23 23:11:29 -0700 | [diff] [blame] | 25 | #include <utils/Condition.h> |
| 26 | #include <utils/Mutex.h> |
Mathias Agopian | c7d14e2 | 2011-08-01 16:32:21 -0700 | [diff] [blame] | 27 | #include <utils/StrongPointer.h> |
Mathias Agopian | 921e6ac | 2012-07-23 23:11:29 -0700 | [diff] [blame] | 28 | #include <utils/Thread.h> |
| 29 | #include <utils/Timers.h> |
Mathias Agopian | 22da60c | 2011-09-09 00:49:11 -0700 | [diff] [blame] | 30 | #include <utils/Vector.h> |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 31 | #include <utils/BitSet.h> |
Mathias Agopian | c7d14e2 | 2011-08-01 16:32:21 -0700 | [diff] [blame] | 32 | |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 33 | extern "C" int clock_nanosleep(clockid_t clock_id, int flags, |
| 34 | const struct timespec *request, |
| 35 | struct timespec *remain); |
| 36 | |
Jesse Hall | 5880cc5 | 2012-06-05 23:40:32 -0700 | [diff] [blame] | 37 | struct hwc_composer_device_1; |
Jesse Hall | b685c54 | 2012-07-31 14:32:56 -0700 | [diff] [blame] | 38 | struct hwc_display_contents_1; |
Mathias Agopian | da27af9 | 2012-09-13 18:17:13 -0700 | [diff] [blame] | 39 | struct hwc_layer_1; |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 40 | struct hwc_procs; |
Mathias Agopian | 8b736f1 | 2012-08-13 17:54:26 -0700 | [diff] [blame] | 41 | struct framebuffer_device_t; |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 42 | |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 43 | namespace android { |
| 44 | // --------------------------------------------------------------------------- |
| 45 | |
Mathias Agopian | 921e6ac | 2012-07-23 23:11:29 -0700 | [diff] [blame] | 46 | class GraphicBuffer; |
Mathias Agopian | da27af9 | 2012-09-13 18:17:13 -0700 | [diff] [blame] | 47 | class Fence; |
Mathias Agopian | 921e6ac | 2012-07-23 23:11:29 -0700 | [diff] [blame] | 48 | class LayerBase; |
Jamie Gennis | 1a4d883 | 2012-08-02 20:11:05 -0700 | [diff] [blame] | 49 | class Region; |
Mathias Agopian | 8372785 | 2010-09-23 18:13:21 -0700 | [diff] [blame] | 50 | class String8; |
Mathias Agopian | c7d14e2 | 2011-08-01 16:32:21 -0700 | [diff] [blame] | 51 | class SurfaceFlinger; |
Mathias Agopian | 8372785 | 2010-09-23 18:13:21 -0700 | [diff] [blame] | 52 | |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 53 | class HWComposer |
| 54 | { |
| 55 | public: |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 56 | class EventHandler { |
| 57 | friend class HWComposer; |
Jesse Hall | 1bd20e0 | 2012-08-29 10:47:52 -0700 | [diff] [blame] | 58 | virtual void onVSyncReceived(int disp, nsecs_t timestamp) = 0; |
Mathias Agopian | 148994e | 2012-09-19 17:31:36 -0700 | [diff] [blame] | 59 | virtual void onHotplugReceived(int disp, bool connected) = 0; |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 60 | protected: |
| 61 | virtual ~EventHandler() {} |
| 62 | }; |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 63 | |
Mathias Agopian | 1e26087 | 2012-08-08 18:35:12 -0700 | [diff] [blame] | 64 | enum { |
Jesse Hall | 8f971ff | 2012-08-22 11:50:00 -0700 | [diff] [blame] | 65 | MAX_DISPLAYS = HWC_NUM_DISPLAY_TYPES + 1 |
Mathias Agopian | 1e26087 | 2012-08-08 18:35:12 -0700 | [diff] [blame] | 66 | }; |
| 67 | |
Mathias Agopian | 8b736f1 | 2012-08-13 17:54:26 -0700 | [diff] [blame] | 68 | HWComposer( |
| 69 | const sp<SurfaceFlinger>& flinger, |
Andy McFadden | b0d1dd3 | 2012-09-10 14:08:09 -0700 | [diff] [blame] | 70 | EventHandler& handler); |
Mathias Agopian | 8b736f1 | 2012-08-13 17:54:26 -0700 | [diff] [blame] | 71 | |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 72 | ~HWComposer(); |
| 73 | |
| 74 | status_t initCheck() const; |
| 75 | |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 76 | // returns a display ID starting at MAX_DISPLAYS, this ID |
| 77 | // is to be used with createWorkList (and all other |
| 78 | // methods requiring an ID below). |
| 79 | // IDs below MAX_DISPLAY are pre-defined and therefore are always valid. |
| 80 | // returns a negative error code if an ID cannot be allocated |
| 81 | int32_t allocateDisplayId(); |
| 82 | |
| 83 | // recycles the given ID and frees the associated worklist. |
| 84 | // IDs below MAX_DISPLAYS are not recycled |
| 85 | status_t freeDisplayId(int32_t id); |
| 86 | |
| 87 | |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 88 | // Asks the HAL what it can do |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 89 | status_t prepare(); |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 90 | |
| 91 | // commits the list |
Mathias Agopian | 30bcc61 | 2012-08-22 15:39:48 -0700 | [diff] [blame] | 92 | status_t commit(); |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 93 | |
Colin Cross | 10fbdb6 | 2012-07-12 17:56:34 -0700 | [diff] [blame] | 94 | // release hardware resources and blank screen |
Mathias Agopian | 81cd5d3 | 2012-10-04 02:34:38 -0700 | [diff] [blame] | 95 | status_t release(int disp); |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 96 | |
Colin Cross | 10fbdb6 | 2012-07-12 17:56:34 -0700 | [diff] [blame] | 97 | // acquire hardware resources and unblank screen |
Mathias Agopian | 81cd5d3 | 2012-10-04 02:34:38 -0700 | [diff] [blame] | 98 | status_t acquire(int disp); |
Colin Cross | 10fbdb6 | 2012-07-12 17:56:34 -0700 | [diff] [blame] | 99 | |
Andy McFadden | 27ec573 | 2012-10-02 19:04:45 -0700 | [diff] [blame] | 100 | // reset state when an external, non-virtual display is disconnected |
| 101 | void disconnectDisplay(int disp); |
| 102 | |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 103 | // create a work list for numLayers layer. sets HWC_GEOMETRY_CHANGED. |
Mathias Agopian | 1e26087 | 2012-08-08 18:35:12 -0700 | [diff] [blame] | 104 | status_t createWorkList(int32_t id, size_t numLayers); |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 105 | |
Mathias Agopian | da27af9 | 2012-09-13 18:17:13 -0700 | [diff] [blame] | 106 | bool supportsFramebufferTarget() const; |
| 107 | |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 108 | // does this display have layers handled by HWC |
| 109 | bool hasHwcComposition(int32_t id) const; |
| 110 | |
| 111 | // does this display have layers handled by GLES |
| 112 | bool hasGlesComposition(int32_t id) const; |
Mathias Agopian | 9c6e297 | 2011-09-20 17:21:56 -0700 | [diff] [blame] | 113 | |
Mathias Agopian | da27af9 | 2012-09-13 18:17:13 -0700 | [diff] [blame] | 114 | // get the releaseFence file descriptor for the given display |
| 115 | // the release fence is only valid after commit() |
| 116 | int getAndResetReleaseFenceFd(int32_t id); |
| 117 | |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 118 | // needed forward declarations |
| 119 | class LayerListIterator; |
| 120 | |
Mathias Agopian | cde87a3 | 2012-09-13 14:09:01 -0700 | [diff] [blame] | 121 | // return the visual id to be used to find a suitable EGLConfig for |
| 122 | // *ALL* displays. |
| 123 | int getVisualID() const; |
| 124 | |
Andy McFadden | b0d1dd3 | 2012-09-10 14:08:09 -0700 | [diff] [blame] | 125 | // Forwarding to FB HAL for pre-HWC-1.1 code (see FramebufferSurface). |
Mathias Agopian | da27af9 | 2012-09-13 18:17:13 -0700 | [diff] [blame] | 126 | int fbPost(int32_t id, const sp<Fence>& acquireFence, const sp<GraphicBuffer>& buf); |
Andy McFadden | b0d1dd3 | 2012-09-10 14:08:09 -0700 | [diff] [blame] | 127 | int fbCompositionComplete(); |
| 128 | void fbDump(String8& result); |
| 129 | |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 130 | /* |
| 131 | * Interface to hardware composer's layers functionality. |
| 132 | * This abstracts the HAL interface to layers which can evolve in |
| 133 | * incompatible ways from one release to another. |
| 134 | * The idea is that we could extend this interface as we add |
| 135 | * features to h/w composer. |
| 136 | */ |
| 137 | class HWCLayerInterface { |
| 138 | protected: |
| 139 | virtual ~HWCLayerInterface() { } |
| 140 | public: |
| 141 | virtual int32_t getCompositionType() const = 0; |
| 142 | virtual uint32_t getHints() const = 0; |
Jesse Hall | ef19414 | 2012-06-14 14:45:17 -0700 | [diff] [blame] | 143 | virtual int getAndResetReleaseFenceFd() = 0; |
Mathias Agopian | ee932d0 | 2012-11-14 14:41:42 -0800 | [diff] [blame^] | 144 | virtual void setPerFrameDefaultState() = 0; |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 145 | virtual void setDefaultState() = 0; |
| 146 | virtual void setSkip(bool skip) = 0; |
| 147 | virtual void setBlending(uint32_t blending) = 0; |
| 148 | virtual void setTransform(uint32_t transform) = 0; |
| 149 | virtual void setFrame(const Rect& frame) = 0; |
| 150 | virtual void setCrop(const Rect& crop) = 0; |
| 151 | virtual void setVisibleRegionScreen(const Region& reg) = 0; |
| 152 | virtual void setBuffer(const sp<GraphicBuffer>& buffer) = 0; |
Jesse Hall | dc5b485 | 2012-06-29 15:21:18 -0700 | [diff] [blame] | 153 | virtual void setAcquireFenceFd(int fenceFd) = 0; |
Mathias Agopian | c397360 | 2012-08-31 17:51:25 -0700 | [diff] [blame] | 154 | virtual void onDisplayed() = 0; |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 155 | }; |
| 156 | |
| 157 | /* |
| 158 | * Interface used to implement an iterator to a list |
| 159 | * of HWCLayer. |
| 160 | */ |
| 161 | class HWCLayer : public HWCLayerInterface { |
| 162 | friend class LayerListIterator; |
| 163 | // select the layer at the given index |
| 164 | virtual status_t setLayer(size_t index) = 0; |
| 165 | virtual HWCLayer* dup() = 0; |
| 166 | static HWCLayer* copy(HWCLayer *rhs) { |
| 167 | return rhs ? rhs->dup() : NULL; |
| 168 | } |
| 169 | protected: |
| 170 | virtual ~HWCLayer() { } |
| 171 | }; |
| 172 | |
| 173 | /* |
| 174 | * Iterator through a HWCLayer list. |
| 175 | * This behaves more or less like a forward iterator. |
| 176 | */ |
| 177 | class LayerListIterator { |
| 178 | friend struct HWComposer; |
| 179 | HWCLayer* const mLayerList; |
| 180 | size_t mIndex; |
| 181 | |
| 182 | LayerListIterator() : mLayerList(NULL), mIndex(0) { } |
| 183 | |
| 184 | LayerListIterator(HWCLayer* layer, size_t index) |
| 185 | : mLayerList(layer), mIndex(index) { } |
| 186 | |
| 187 | // we don't allow assignment, because we don't need it for now |
| 188 | LayerListIterator& operator = (const LayerListIterator& rhs); |
| 189 | |
| 190 | public: |
| 191 | // copy operators |
| 192 | LayerListIterator(const LayerListIterator& rhs) |
| 193 | : mLayerList(HWCLayer::copy(rhs.mLayerList)), mIndex(rhs.mIndex) { |
| 194 | } |
| 195 | |
| 196 | ~LayerListIterator() { delete mLayerList; } |
| 197 | |
| 198 | // pre-increment |
| 199 | LayerListIterator& operator++() { |
| 200 | mLayerList->setLayer(++mIndex); |
| 201 | return *this; |
| 202 | } |
| 203 | |
| 204 | // dereference |
| 205 | HWCLayerInterface& operator * () { return *mLayerList; } |
| 206 | HWCLayerInterface* operator -> () { return mLayerList; } |
| 207 | |
| 208 | // comparison |
| 209 | bool operator == (const LayerListIterator& rhs) const { |
| 210 | return mIndex == rhs.mIndex; |
| 211 | } |
| 212 | bool operator != (const LayerListIterator& rhs) const { |
| 213 | return !operator==(rhs); |
| 214 | } |
| 215 | }; |
| 216 | |
| 217 | // Returns an iterator to the beginning of the layer list |
Mathias Agopian | 1e26087 | 2012-08-08 18:35:12 -0700 | [diff] [blame] | 218 | LayerListIterator begin(int32_t id); |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 219 | |
| 220 | // Returns an iterator to the end of the layer list |
Mathias Agopian | 1e26087 | 2012-08-08 18:35:12 -0700 | [diff] [blame] | 221 | LayerListIterator end(int32_t id); |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 222 | |
| 223 | |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 224 | // Events handling --------------------------------------------------------- |
| 225 | |
| 226 | enum { |
| 227 | EVENT_VSYNC = HWC_EVENT_VSYNC |
| 228 | }; |
| 229 | |
Mathias Agopian | 81cd5d3 | 2012-10-04 02:34:38 -0700 | [diff] [blame] | 230 | void eventControl(int disp, int event, int enabled); |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 231 | |
Andy McFadden | b0d1dd3 | 2012-09-10 14:08:09 -0700 | [diff] [blame] | 232 | // Query display parameters. Pass in a display index (e.g. |
| 233 | // HWC_DISPLAY_PRIMARY). |
| 234 | nsecs_t getRefreshPeriod(int disp) const; |
| 235 | nsecs_t getRefreshTimestamp(int disp) const; |
Jesse Hall | db27621 | 2012-09-07 11:20:56 -0700 | [diff] [blame] | 236 | uint32_t getWidth(int disp) const; |
| 237 | uint32_t getHeight(int disp) const; |
Andy McFadden | b0d1dd3 | 2012-09-10 14:08:09 -0700 | [diff] [blame] | 238 | uint32_t getFormat(int disp) const; |
| 239 | float getDpiX(int disp) const; |
| 240 | float getDpiY(int disp) const; |
Mathias Agopian | f5a3392 | 2012-09-19 18:16:22 -0700 | [diff] [blame] | 241 | bool isConnected(int disp) const; |
Mathias Agopian | d3ee231 | 2012-08-02 14:01:42 -0700 | [diff] [blame] | 242 | |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 243 | // this class is only used to fake the VSync event on systems that don't |
| 244 | // have it. |
| 245 | class VSyncThread : public Thread { |
| 246 | HWComposer& mHwc; |
| 247 | mutable Mutex mLock; |
| 248 | Condition mCondition; |
| 249 | bool mEnabled; |
| 250 | mutable nsecs_t mNextFakeVSync; |
| 251 | nsecs_t mRefreshPeriod; |
Mathias Agopian | 2965b26 | 2012-04-08 15:13:32 -0700 | [diff] [blame] | 252 | virtual void onFirstRef(); |
| 253 | virtual bool threadLoop(); |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 254 | public: |
Mathias Agopian | 2965b26 | 2012-04-08 15:13:32 -0700 | [diff] [blame] | 255 | VSyncThread(HWComposer& hwc); |
| 256 | void setEnabled(bool enabled); |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 257 | }; |
| 258 | |
| 259 | friend class VSyncThread; |
| 260 | |
| 261 | // for debugging ---------------------------------------------------------- |
Mathias Agopian | cb55857 | 2012-10-04 15:58:54 -0700 | [diff] [blame] | 262 | void dump(String8& out, char* scratch, size_t SIZE) const; |
Mathias Agopian | 8372785 | 2010-09-23 18:13:21 -0700 | [diff] [blame] | 263 | |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 264 | private: |
Andy McFadden | b0d1dd3 | 2012-09-10 14:08:09 -0700 | [diff] [blame] | 265 | void loadHwcModule(); |
| 266 | void loadFbHalModule(); |
Jesse Hall | b685c54 | 2012-07-31 14:32:56 -0700 | [diff] [blame] | 267 | |
Mathias Agopian | 1e26087 | 2012-08-08 18:35:12 -0700 | [diff] [blame] | 268 | LayerListIterator getLayerIterator(int32_t id, size_t index); |
Mathias Agopian | 31d2843 | 2012-04-03 16:31:39 -0700 | [diff] [blame] | 269 | |
Mathias Agopian | 3e8b853 | 2012-05-13 20:42:01 -0700 | [diff] [blame] | 270 | struct cb_context; |
Mathias Agopian | 31d2843 | 2012-04-03 16:31:39 -0700 | [diff] [blame] | 271 | |
Jesse Hall | bbd164a | 2012-08-21 12:05:09 -0700 | [diff] [blame] | 272 | static void hook_invalidate(const struct hwc_procs* procs); |
Jesse Hall | 1bd20e0 | 2012-08-29 10:47:52 -0700 | [diff] [blame] | 273 | static void hook_vsync(const struct hwc_procs* procs, int disp, |
Jesse Hall | bbd164a | 2012-08-21 12:05:09 -0700 | [diff] [blame] | 274 | int64_t timestamp); |
Jesse Hall | 1bd20e0 | 2012-08-29 10:47:52 -0700 | [diff] [blame] | 275 | static void hook_hotplug(const struct hwc_procs* procs, int disp, |
| 276 | int connected); |
Mathias Agopian | 31d2843 | 2012-04-03 16:31:39 -0700 | [diff] [blame] | 277 | |
Mathias Agopian | 3eb38cb | 2012-04-03 22:09:52 -0700 | [diff] [blame] | 278 | inline void invalidate(); |
Jesse Hall | 1bd20e0 | 2012-08-29 10:47:52 -0700 | [diff] [blame] | 279 | inline void vsync(int disp, int64_t timestamp); |
| 280 | inline void hotplug(int disp, int connected); |
Mathias Agopian | c7d14e2 | 2011-08-01 16:32:21 -0700 | [diff] [blame] | 281 | |
Mathias Agopian | 1604f77 | 2012-09-18 21:54:42 -0700 | [diff] [blame] | 282 | status_t queryDisplayProperties(int disp); |
Mathias Agopian | 1e26087 | 2012-08-08 18:35:12 -0700 | [diff] [blame] | 283 | |
Mathias Agopian | da27af9 | 2012-09-13 18:17:13 -0700 | [diff] [blame] | 284 | status_t setFramebufferTarget(int32_t id, |
| 285 | const sp<Fence>& acquireFence, const sp<GraphicBuffer>& buf); |
| 286 | |
| 287 | |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 288 | struct DisplayData { |
| 289 | DisplayData() : xdpi(0), ydpi(0), refresh(0), |
Mathias Agopian | f5a3392 | 2012-09-19 18:16:22 -0700 | [diff] [blame] | 290 | connected(false), hasFbComp(false), hasOvComp(false), |
Mathias Agopian | da27af9 | 2012-09-13 18:17:13 -0700 | [diff] [blame] | 291 | capacity(0), list(NULL), |
Mathias Agopian | 81cd5d3 | 2012-10-04 02:34:38 -0700 | [diff] [blame] | 292 | framebufferTarget(NULL), fbTargetHandle(NULL), events(0) { } |
Mathias Agopian | f435863 | 2012-08-22 17:16:19 -0700 | [diff] [blame] | 293 | ~DisplayData() { |
| 294 | free(list); |
| 295 | } |
Jesse Hall | db27621 | 2012-09-07 11:20:56 -0700 | [diff] [blame] | 296 | uint32_t width; |
| 297 | uint32_t height; |
Andy McFadden | b0d1dd3 | 2012-09-10 14:08:09 -0700 | [diff] [blame] | 298 | uint32_t format; // pixel format from FB hal, for pre-hwc-1.1 |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 299 | float xdpi; |
| 300 | float ydpi; |
| 301 | nsecs_t refresh; |
Mathias Agopian | f5a3392 | 2012-09-19 18:16:22 -0700 | [diff] [blame] | 302 | bool connected; |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 303 | bool hasFbComp; |
| 304 | bool hasOvComp; |
Mathias Agopian | f435863 | 2012-08-22 17:16:19 -0700 | [diff] [blame] | 305 | size_t capacity; |
| 306 | hwc_display_contents_1* list; |
Mathias Agopian | da27af9 | 2012-09-13 18:17:13 -0700 | [diff] [blame] | 307 | hwc_layer_1* framebufferTarget; |
| 308 | buffer_handle_t fbTargetHandle; |
Mathias Agopian | 81cd5d3 | 2012-10-04 02:34:38 -0700 | [diff] [blame] | 309 | // protected by mEventControlLock |
| 310 | int32_t events; |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 311 | }; |
| 312 | |
Jesse Hall | 5880cc5 | 2012-06-05 23:40:32 -0700 | [diff] [blame] | 313 | sp<SurfaceFlinger> mFlinger; |
Andy McFadden | b0d1dd3 | 2012-09-10 14:08:09 -0700 | [diff] [blame] | 314 | framebuffer_device_t* mFbDev; |
Jesse Hall | 5880cc5 | 2012-06-05 23:40:32 -0700 | [diff] [blame] | 315 | struct hwc_composer_device_1* mHwc; |
Jesse Hall | b685c54 | 2012-07-31 14:32:56 -0700 | [diff] [blame] | 316 | // invariant: mLists[0] != NULL iff mHwc != NULL |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 317 | // mLists[i>0] can be NULL. that display is to be ignored |
Jesse Hall | b685c54 | 2012-07-31 14:32:56 -0700 | [diff] [blame] | 318 | struct hwc_display_contents_1* mLists[MAX_DISPLAYS]; |
Mathias Agopian | e60b068 | 2012-08-21 23:34:09 -0700 | [diff] [blame] | 319 | DisplayData mDisplayData[MAX_DISPLAYS]; |
Jesse Hall | 8f971ff | 2012-08-22 11:50:00 -0700 | [diff] [blame] | 320 | size_t mNumDisplays; |
Mathias Agopian | 1e26087 | 2012-08-08 18:35:12 -0700 | [diff] [blame] | 321 | |
Jesse Hall | 5880cc5 | 2012-06-05 23:40:32 -0700 | [diff] [blame] | 322 | cb_context* mCBContext; |
| 323 | EventHandler& mEventHandler; |
Jesse Hall | 5880cc5 | 2012-06-05 23:40:32 -0700 | [diff] [blame] | 324 | size_t mVSyncCount; |
| 325 | sp<VSyncThread> mVSyncThread; |
| 326 | bool mDebugForceFakeVSync; |
Mathias Agopian | f435863 | 2012-08-22 17:16:19 -0700 | [diff] [blame] | 327 | BitSet32 mAllocatedDisplayIDs; |
Mathias Agopian | d3ee231 | 2012-08-02 14:01:42 -0700 | [diff] [blame] | 328 | |
| 329 | // protected by mLock |
| 330 | mutable Mutex mLock; |
| 331 | mutable nsecs_t mLastHwVSync; |
Mathias Agopian | 81cd5d3 | 2012-10-04 02:34:38 -0700 | [diff] [blame] | 332 | |
| 333 | // thread-safe |
| 334 | mutable Mutex mEventControlLock; |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 335 | }; |
| 336 | |
Mathias Agopian | a350ff9 | 2010-08-10 17:14:02 -0700 | [diff] [blame] | 337 | // --------------------------------------------------------------------------- |
| 338 | }; // namespace android |
| 339 | |
| 340 | #endif // ANDROID_SF_HWCOMPOSER_H |