blob: d407877bf00a940429d9f5883e6e37f47d6ea412 [file] [log] [blame]
Mathias Agopiana350ff92010-08-10 17:14:02 -07001/*
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
Dan Stoza9e56aa02015-11-02 13:00:03 -080017#ifndef USE_HWC2
18#include "HWComposer_hwc1.h"
19#else
20
Mathias Agopiana350ff92010-08-10 17:14:02 -070021#ifndef ANDROID_SF_HWCOMPOSER_H
22#define ANDROID_SF_HWCOMPOSER_H
23
Dan Stoza9e56aa02015-11-02 13:00:03 -080024#include "HWC2.h"
25
Mathias Agopiana350ff92010-08-10 17:14:02 -070026#include <stdint.h>
27#include <sys/types.h>
28
Jamie Gennis2ec3e072012-11-11 16:24:33 -080029#include <ui/Fence.h>
30
31#include <utils/BitSet.h>
Mathias Agopian921e6ac2012-07-23 23:11:29 -070032#include <utils/Condition.h>
33#include <utils/Mutex.h>
Mathias Agopianc7d14e22011-08-01 16:32:21 -070034#include <utils/StrongPointer.h>
Mathias Agopian921e6ac2012-07-23 23:11:29 -070035#include <utils/Thread.h>
36#include <utils/Timers.h>
Mathias Agopian22da60c2011-09-09 00:49:11 -070037#include <utils/Vector.h>
Mathias Agopianc7d14e22011-08-01 16:32:21 -070038
Dan Stoza9e56aa02015-11-02 13:00:03 -080039#include <memory>
40#include <set>
41#include <vector>
42
Mathias Agopian3eb38cb2012-04-03 22:09:52 -070043extern "C" int clock_nanosleep(clockid_t clock_id, int flags,
44 const struct timespec *request,
45 struct timespec *remain);
46
Mathias Agopian8b736f12012-08-13 17:54:26 -070047struct framebuffer_device_t;
Mathias Agopian3e8b8532012-05-13 20:42:01 -070048
Dan Stoza9e56aa02015-11-02 13:00:03 -080049namespace HWC2 {
50 class Device;
51 class Display;
52}
53
Mathias Agopiana350ff92010-08-10 17:14:02 -070054namespace android {
55// ---------------------------------------------------------------------------
56
Dan Stoza9e56aa02015-11-02 13:00:03 -080057class DisplayDevice;
Mathias Agopianda27af92012-09-13 18:17:13 -070058class Fence;
Mathias Agopian6b442672013-07-09 21:24:52 -070059class FloatRect;
Jesse Hall399184a2014-03-03 15:42:54 -080060class GraphicBuffer;
Dan Stoza9e56aa02015-11-02 13:00:03 -080061class HWC2On1Adapter;
Jesse Hall399184a2014-03-03 15:42:54 -080062class NativeHandle;
Jamie Gennis1a4d8832012-08-02 20:11:05 -070063class Region;
Mathias Agopian83727852010-09-23 18:13:21 -070064class String8;
Mathias Agopianc7d14e22011-08-01 16:32:21 -070065class SurfaceFlinger;
Mathias Agopian83727852010-09-23 18:13:21 -070066
Mathias Agopiana350ff92010-08-10 17:14:02 -070067class HWComposer
68{
69public:
Mathias Agopian3eb38cb2012-04-03 22:09:52 -070070 class EventHandler {
71 friend class HWComposer;
Dan Stoza9e56aa02015-11-02 13:00:03 -080072 virtual void onVSyncReceived(int32_t disp, nsecs_t timestamp) = 0;
73 virtual void onHotplugReceived(int32_t disp, bool connected) = 0;
Mathias Agopian3eb38cb2012-04-03 22:09:52 -070074 protected:
75 virtual ~EventHandler() {}
76 };
Mathias Agopiana350ff92010-08-10 17:14:02 -070077
Dan Stoza9e56aa02015-11-02 13:00:03 -080078 HWComposer(const sp<SurfaceFlinger>& flinger);
Mathias Agopian8b736f12012-08-13 17:54:26 -070079
Mathias Agopiana350ff92010-08-10 17:14:02 -070080 ~HWComposer();
81
Dan Stoza9e56aa02015-11-02 13:00:03 -080082 void setEventHandler(EventHandler* handler);
Mathias Agopiana350ff92010-08-10 17:14:02 -070083
Dan Stoza9e56aa02015-11-02 13:00:03 -080084 // Attempts to allocate a virtual display. If the virtual display is created
85 // on the HWC device, outId will contain its HWC ID.
86 status_t allocateVirtualDisplay(uint32_t width, uint32_t height,
87 int32_t* outId);
Mathias Agopiane60b0682012-08-21 23:34:09 -070088
Dan Stoza9e56aa02015-11-02 13:00:03 -080089 // Attempts to create a new layer on this display
90 std::shared_ptr<HWC2::Layer> createLayer(int32_t displayId);
Mathias Agopiane60b0682012-08-21 23:34:09 -070091
Mathias Agopiana350ff92010-08-10 17:14:02 -070092 // Asks the HAL what it can do
Dan Stoza9e56aa02015-11-02 13:00:03 -080093 status_t prepare(DisplayDevice& displayDevice);
Mathias Agopiana350ff92010-08-10 17:14:02 -070094
Dan Stoza9e56aa02015-11-02 13:00:03 -080095 status_t setClientTarget(int32_t displayId, const sp<Fence>& acquireFence,
96 const sp<GraphicBuffer>& target, android_dataspace_t dataspace);
97
98 // Finalize the layers and present them
99 status_t commit(int32_t displayId);
Mathias Agopiana350ff92010-08-10 17:14:02 -0700100
Prashant Malani2c9b11f2014-05-25 01:36:31 -0700101 // set power mode
Dan Stoza9e56aa02015-11-02 13:00:03 -0800102 status_t setPowerMode(int32_t displayId, int mode);
Colin Cross10fbdb62012-07-12 17:56:34 -0700103
Michael Lentine6c9e34a2014-07-14 13:48:55 -0700104 // set active config
Dan Stoza9e56aa02015-11-02 13:00:03 -0800105 status_t setActiveConfig(int32_t displayId, size_t configId);
Michael Lentine6c9e34a2014-07-14 13:48:55 -0700106
Andy McFadden27ec5732012-10-02 19:04:45 -0700107 // reset state when an external, non-virtual display is disconnected
Dan Stoza9e56aa02015-11-02 13:00:03 -0800108 void disconnectDisplay(int32_t displayId);
Mathias Agopianda27af92012-09-13 18:17:13 -0700109
Mathias Agopiane60b0682012-08-21 23:34:09 -0700110 // does this display have layers handled by HWC
Dan Stoza9e56aa02015-11-02 13:00:03 -0800111 bool hasDeviceComposition(int32_t displayId) const;
Mathias Agopiane60b0682012-08-21 23:34:09 -0700112
113 // does this display have layers handled by GLES
Dan Stoza9e56aa02015-11-02 13:00:03 -0800114 bool hasClientComposition(int32_t displayId) const;
Mathias Agopian9c6e2972011-09-20 17:21:56 -0700115
Dan Stoza9e56aa02015-11-02 13:00:03 -0800116 // get the retire fence for the previous frame (i.e., corresponding to the
117 // last call to presentDisplay
118 sp<Fence> getRetireFence(int32_t displayId) const;
Mathias Agopianda27af92012-09-13 18:17:13 -0700119
Dan Stoza9e56aa02015-11-02 13:00:03 -0800120 // Get last release fence for the given layer
121 sp<Fence> getLayerReleaseFence(int32_t displayId,
122 const std::shared_ptr<HWC2::Layer>& layer) const;
Andy McFaddenb0d1dd32012-09-10 14:08:09 -0700123
Jesse Hall851cfe82013-03-20 13:44:00 -0700124 // Set the output buffer and acquire fence for a virtual display.
Dan Stoza9e56aa02015-11-02 13:00:03 -0800125 // Returns INVALID_OPERATION if displayId is not a virtual display.
126 status_t setOutputBuffer(int32_t displayId, const sp<Fence>& acquireFence,
Jesse Hall851cfe82013-03-20 13:44:00 -0700127 const sp<GraphicBuffer>& buf);
128
Dan Stoza9e56aa02015-11-02 13:00:03 -0800129 // After SurfaceFlinger has retrieved the release fences for all the frames,
130 // it can call this to clear the shared pointers in the release fence map
131 void clearReleaseFences(int32_t displayId);
Mathias Agopian3e8b8532012-05-13 20:42:01 -0700132
Dan Stozac4f471e2016-03-24 09:31:08 -0700133 // Returns the HDR capabilities of the given display
134 std::unique_ptr<HdrCapabilities> getHdrCapabilities(int32_t displayId);
135
Mathias Agopian3eb38cb2012-04-03 22:09:52 -0700136 // Events handling ---------------------------------------------------------
137
Dan Stoza9e56aa02015-11-02 13:00:03 -0800138 void setVsyncEnabled(int32_t disp, HWC2::Vsync enabled);
Mathias Agopian3eb38cb2012-04-03 22:09:52 -0700139
Dan Stoza7f7da322014-05-02 15:26:25 -0700140 struct DisplayConfig {
141 uint32_t width;
142 uint32_t height;
143 float xdpi;
144 float ydpi;
145 nsecs_t refresh;
Dan Stozaf2699fc2015-08-31 12:06:48 -0700146 int colorTransform;
Dan Stoza7f7da322014-05-02 15:26:25 -0700147 };
148
Andy McFaddenb0d1dd32012-09-10 14:08:09 -0700149 // Query display parameters. Pass in a display index (e.g.
150 // HWC_DISPLAY_PRIMARY).
Dan Stoza9e56aa02015-11-02 13:00:03 -0800151 nsecs_t getRefreshTimestamp(int32_t disp) const;
152 bool isConnected(int32_t disp) const;
Dan Stoza7f7da322014-05-02 15:26:25 -0700153
Dan Stoza9e56aa02015-11-02 13:00:03 -0800154 // Non-const because it can update configMap inside of mDisplayData
155 std::vector<std::shared_ptr<const HWC2::Display::Config>>
156 getConfigs(int32_t displayId) const;
Dan Stoza7f7da322014-05-02 15:26:25 -0700157
Dan Stoza9e56aa02015-11-02 13:00:03 -0800158 std::shared_ptr<const HWC2::Display::Config>
159 getActiveConfig(int32_t displayId) const;
Mathias Agopian3eb38cb2012-04-03 22:09:52 -0700160
161 // for debugging ----------------------------------------------------------
Mathias Agopian74d211a2013-04-22 16:55:35 +0200162 void dump(String8& out) const;
Mathias Agopian83727852010-09-23 18:13:21 -0700163
Mathias Agopiana350ff92010-08-10 17:14:02 -0700164private:
Dan Stoza9e56aa02015-11-02 13:00:03 -0800165 static const int32_t VIRTUAL_DISPLAY_ID_BASE = 2;
Jesse Hallb685c542012-07-31 14:32:56 -0700166
Dan Stoza9e56aa02015-11-02 13:00:03 -0800167 void loadHwcModule();
168
169 bool isValidDisplay(int32_t displayId) const;
170 static void validateChange(HWC2::Composition from, HWC2::Composition to);
Mathias Agopian31d28432012-04-03 16:31:39 -0700171
Mathias Agopian3e8b8532012-05-13 20:42:01 -0700172 struct cb_context;
Mathias Agopian31d28432012-04-03 16:31:39 -0700173
Dan Stoza9e56aa02015-11-02 13:00:03 -0800174 void invalidate(const std::shared_ptr<HWC2::Display>& display);
175 void vsync(const std::shared_ptr<HWC2::Display>& display,
Jesse Hallbbd164a2012-08-21 12:05:09 -0700176 int64_t timestamp);
Dan Stoza9e56aa02015-11-02 13:00:03 -0800177 void hotplug(const std::shared_ptr<HWC2::Display>& display,
178 HWC2::Connection connected);
Mathias Agopianda27af92012-09-13 18:17:13 -0700179
Mathias Agopiane60b0682012-08-21 23:34:09 -0700180 struct DisplayData {
Jesse Halla9a1b002013-02-27 16:39:25 -0800181 DisplayData();
182 ~DisplayData();
Dan Stoza9e56aa02015-11-02 13:00:03 -0800183 void reset();
184
185 bool hasClientComposition;
186 bool hasDeviceComposition;
187 std::shared_ptr<HWC2::Display> hwcDisplay;
188 HWC2::DisplayRequest displayRequests;
Jamie Gennis2ec3e072012-11-11 16:24:33 -0800189 sp<Fence> lastRetireFence; // signals when the last set op retires
Dan Stoza9e56aa02015-11-02 13:00:03 -0800190 std::unordered_map<std::shared_ptr<HWC2::Layer>, sp<Fence>>
191 releaseFences;
Jesse Hall851cfe82013-03-20 13:44:00 -0700192 buffer_handle_t outbufHandle;
193 sp<Fence> outbufAcquireFence;
Dan Stoza9e56aa02015-11-02 13:00:03 -0800194 mutable std::unordered_map<int32_t,
195 std::shared_ptr<const HWC2::Display::Config>> configMap;
Jamie Gennis2ec3e072012-11-11 16:24:33 -0800196
Dan Stoza9e56aa02015-11-02 13:00:03 -0800197 // protected by mVsyncLock
198 HWC2::Vsync vsyncEnabled;
Mathias Agopiane60b0682012-08-21 23:34:09 -0700199 };
200
Jesse Hall5880cc52012-06-05 23:40:32 -0700201 sp<SurfaceFlinger> mFlinger;
Dan Stoza9e56aa02015-11-02 13:00:03 -0800202 std::unique_ptr<HWC2On1Adapter> mAdapter;
203 std::unique_ptr<HWC2::Device> mHwcDevice;
204 std::vector<DisplayData> mDisplayData;
205 std::set<size_t> mFreeDisplaySlots;
206 std::unordered_map<hwc2_display_t, int32_t> mHwcDisplaySlots;
Manoj Kumar AVMe04e4ed2015-06-11 14:18:14 -0700207 // protect mDisplayData from races between prepare and dump
208 mutable Mutex mDisplayLock;
Mathias Agopian1e260872012-08-08 18:35:12 -0700209
Jesse Hall5880cc52012-06-05 23:40:32 -0700210 cb_context* mCBContext;
Dan Stoza9e56aa02015-11-02 13:00:03 -0800211 EventHandler* mEventHandler;
Mathias Agopianbef42c52013-08-21 17:45:46 -0700212 size_t mVSyncCounts[HWC_NUM_PHYSICAL_DISPLAY_TYPES];
Dan Stoza9e56aa02015-11-02 13:00:03 -0800213 uint32_t mRemainingHwcVirtualDisplays;
Mathias Agopiand3ee2312012-08-02 14:01:42 -0700214
215 // protected by mLock
216 mutable Mutex mLock;
Dan Stoza9e56aa02015-11-02 13:00:03 -0800217 mutable std::unordered_map<int32_t, nsecs_t> mLastHwVSync;
Mathias Agopian81cd5d32012-10-04 02:34:38 -0700218
219 // thread-safe
Dan Stoza9e56aa02015-11-02 13:00:03 -0800220 mutable Mutex mVsyncLock;
Mathias Agopiana350ff92010-08-10 17:14:02 -0700221};
222
Mathias Agopiana350ff92010-08-10 17:14:02 -0700223// ---------------------------------------------------------------------------
224}; // namespace android
225
226#endif // ANDROID_SF_HWCOMPOSER_H
Dan Stoza9e56aa02015-11-02 13:00:03 -0800227
228#endif // #ifdef USE_HWC2