blob: efb6ef0043f6858c55d17b7161fd5c61d36e9d25 [file] [log] [blame]
Mathias Agopian3f844832013-08-07 21:24:32 -07001/*
2 * Copyright 2013 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
Peiyong Lin7e219eb2018-12-03 05:40:42 -080017#ifndef SF_GLESRENDERENGINE_H_
18#define SF_GLESRENDERENGINE_H_
Mathias Agopian3f844832013-08-07 21:24:32 -070019
Alec Mouri554d06e2018-12-20 00:15:33 -080020#include <android-base/thread_annotations.h>
Mathias Agopian3f844832013-08-07 21:24:32 -070021#include <stdint.h>
22#include <sys/types.h>
Alec Mouri554d06e2018-12-20 00:15:33 -080023#include <condition_variable>
Alec Mourida4cf3b2019-02-12 15:33:01 -080024#include <deque>
Alec Mouri554d06e2018-12-20 00:15:33 -080025#include <mutex>
26#include <queue>
27#include <thread>
Alec Mourida4cf3b2019-02-12 15:33:01 -080028#include <unordered_map>
Mathias Agopian3f844832013-08-07 21:24:32 -070029
Peiyong Linf11f39b2018-09-05 14:37:41 -070030#include <EGL/egl.h>
31#include <EGL/eglext.h>
Mathias Agopian3f844832013-08-07 21:24:32 -070032#include <GLES2/gl2.h>
Peiyong Lincbc184f2018-08-22 13:24:10 -070033#include <renderengine/RenderEngine.h>
Peiyong Lin833074a2018-08-28 11:53:54 -070034#include <renderengine/private/Description.h>
Mathias Agopian3f844832013-08-07 21:24:32 -070035
Peiyong Linf11f39b2018-09-05 14:37:41 -070036#define EGL_NO_CONFIG ((EGLConfig)0)
37
Mathias Agopian3f844832013-08-07 21:24:32 -070038namespace android {
Mathias Agopian3f844832013-08-07 21:24:32 -070039
Peiyong Lin833074a2018-08-28 11:53:54 -070040namespace renderengine {
41
Mathias Agopian3f844832013-08-07 21:24:32 -070042class Mesh;
Mathias Agopian49457ac2013-08-14 18:20:17 -070043class Texture;
Mathias Agopian3f844832013-08-07 21:24:32 -070044
Peiyong Lin833074a2018-08-28 11:53:54 -070045namespace gl {
Lloyd Pique144e1162017-12-20 16:44:52 -080046
Peiyong Linf1bada92018-08-29 09:39:31 -070047class GLImage;
Peiyong Linf1bada92018-08-29 09:39:31 -070048
Peiyong Lin7e219eb2018-12-03 05:40:42 -080049class GLESRenderEngine : public impl::RenderEngine {
Mathias Agopian3f844832013-08-07 21:24:32 -070050public:
Alec Mourida4cf3b2019-02-12 15:33:01 -080051 static std::unique_ptr<GLESRenderEngine> create(int hwcFormat, uint32_t featureFlags,
52 uint32_t imageCacheSize);
Peiyong Linf11f39b2018-09-05 14:37:41 -070053 static EGLConfig chooseEglConfig(EGLDisplay display, int format, bool logConfig);
54
Peiyong Lin7e219eb2018-12-03 05:40:42 -080055 GLESRenderEngine(uint32_t featureFlags, // See RenderEngine::FeatureFlag
Peiyong Linfb530cf2018-12-15 05:07:38 +000056 EGLDisplay display, EGLConfig config, EGLContext ctxt, EGLSurface dummy,
Alec Mourida4cf3b2019-02-12 15:33:01 -080057 EGLContext protectedContext, EGLSurface protectedDummy,
58 uint32_t imageCacheSize);
Alec Mourid43ccab2019-03-13 12:23:45 -070059 ~GLESRenderEngine() override EXCLUDES(mRenderingMutex);
Mathias Agopian3f844832013-08-07 21:24:32 -070060
Peiyong Line5a9a7f2018-08-30 15:32:13 -070061 std::unique_ptr<Framebuffer> createFramebuffer() override;
Peiyong Line5a9a7f2018-08-30 15:32:13 -070062 std::unique_ptr<Image> createImage() override;
Peiyong Linf1bada92018-08-29 09:39:31 -070063
64 void primeCache() const override;
Peiyong Lin60bedb52018-09-05 10:47:31 -070065 bool isCurrent() const override;
Peiyong Lin60bedb52018-09-05 10:47:31 -070066 base::unique_fd flush() override;
67 bool finish() override;
68 bool waitFence(base::unique_fd fenceFd) override;
69 void clearWithColor(float red, float green, float blue, float alpha) override;
Chia-I Wu28e3a252018-09-07 12:05:02 -070070 void fillRegionWithColor(const Region& region, float red, float green, float blue,
71 float alpha) override;
Alec Mouri05483a02018-09-10 21:03:42 +000072 void setScissor(const Rect& region) override;
Peiyong Lin60bedb52018-09-05 10:47:31 -070073 void disableScissor() override;
74 void genTextures(size_t count, uint32_t* names) override;
75 void deleteTextures(size_t count, uint32_t const* names) override;
Peiyong Line5a9a7f2018-08-30 15:32:13 -070076 void bindExternalTextureImage(uint32_t texName, const Image& image) override;
Alec Mourif0497272019-03-11 15:53:11 -070077 status_t bindExternalTextureBuffer(uint32_t texName, sp<GraphicBuffer> buffer, sp<Fence> fence)
78 EXCLUDES(mRenderingMutex);
79 void unbindExternalTextureBuffer(uint64_t bufferId) EXCLUDES(mRenderingMutex);
Peiyong Line5a9a7f2018-08-30 15:32:13 -070080 status_t bindFrameBuffer(Framebuffer* framebuffer) override;
81 void unbindFrameBuffer(Framebuffer* framebuffer) override;
Peiyong Lin60bedb52018-09-05 10:47:31 -070082 void checkErrors() const override;
Peiyong Linf1bada92018-08-29 09:39:31 -070083
Peiyong Linfb530cf2018-12-15 05:07:38 +000084 bool isProtected() const override { return mInProtectedContext; }
85 bool supportsProtectedContent() const override;
86 bool useProtectedContext(bool useProtectedContext) override;
Alec Mouri1089aed2018-10-25 21:33:57 -070087 status_t drawLayers(const DisplaySettings& display, const std::vector<LayerSettings>& layers,
Alec Mouri6338c9d2019-02-07 16:57:51 -080088 ANativeWindowBuffer* buffer, base::unique_fd&& bufferFence,
Alec Mourif0497272019-03-11 15:53:11 -070089 base::unique_fd* drawFence) EXCLUDES(mRenderingMutex) override;
Alec Mouri6e57f682018-09-29 20:45:08 -070090
Peiyong Linf11f39b2018-09-05 14:37:41 -070091 // internal to RenderEngine
92 EGLDisplay getEGLDisplay() const { return mEGLDisplay; }
93 EGLConfig getEGLConfig() const { return mEGLConfig; }
Alec Mourida4cf3b2019-02-12 15:33:01 -080094 // Creates an output image for rendering to
95 EGLImageKHR createFramebufferImageIfNeeded(ANativeWindowBuffer* nativeBuffer, bool isProtected);
Peiyong Linf11f39b2018-09-05 14:37:41 -070096
Alec Mourid43ccab2019-03-13 12:23:45 -070097 // Test-only methods
98 // Returns true iff mImageCache contains an image keyed by bufferId
99 bool isImageCachedForTesting(uint64_t bufferId) EXCLUDES(mRenderingMutex);
100 // Returns true iff mFramebufferImageCache contains an image keyed by bufferId
101 bool isFramebufferImageCachedForTesting(uint64_t bufferId) EXCLUDES(mRenderingMutex);
102
Mathias Agopian3f844832013-08-07 21:24:32 -0700103protected:
Alec Mouri820c7402019-01-23 13:02:39 -0800104 Framebuffer* getFramebufferForDrawing() override;
Yiwei Zhang5434a782018-12-05 18:06:32 -0800105 void dump(std::string& result) override;
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700106 void setViewportAndProjection(size_t vpw, size_t vph, Rect sourceCrop,
107 ui::Transform::orientation_flags rotation) override;
108 void setupLayerBlending(bool premultipliedAlpha, bool opaque, bool disableTexture,
Lucas Dupin1b6531c2018-07-05 17:18:21 -0700109 const half4& color, float cornerRadius) override;
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700110 void setupLayerTexturing(const Texture& texture) override;
111 void setupLayerBlackedOut() override;
112 void setupFillWithColor(float r, float g, float b, float a) override;
Peiyong Lind3788632018-09-18 16:01:31 -0700113 void setColorTransform(const mat4& colorTransform) override;
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700114 void disableTexturing() override;
115 void disableBlending() override;
Lucas Dupin1b6531c2018-07-05 17:18:21 -0700116 void setupCornerRadiusCropSize(float width, float height) override;
Mathias Agopian3f844832013-08-07 21:24:32 -0700117
Peiyong Linf11f39b2018-09-05 14:37:41 -0700118 // HDR and color management related functions and state
119 void setSourceY410BT2020(bool enable) override;
120 void setSourceDataSpace(ui::Dataspace source) override;
121 void setOutputDataSpace(ui::Dataspace dataspace) override;
122 void setDisplayMaxLuminance(const float maxLuminance) override;
123
124 // drawing
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700125 void drawMesh(const Mesh& mesh) override;
Mathias Agopian3f844832013-08-07 21:24:32 -0700126
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700127 size_t getMaxTextureSize() const override;
128 size_t getMaxViewportDims() const override;
129
130private:
Peiyong Linf11f39b2018-09-05 14:37:41 -0700131 enum GlesVersion {
132 GLES_VERSION_1_0 = 0x10000,
133 GLES_VERSION_1_1 = 0x10001,
134 GLES_VERSION_2_0 = 0x20000,
135 GLES_VERSION_3_0 = 0x30000,
136 };
137
138 static GlesVersion parseGlesVersion(const char* str);
Peiyong Lina5e9f1b2018-11-27 22:49:37 -0800139 static EGLContext createEglContext(EGLDisplay display, EGLConfig config,
Peiyong Linfb530cf2018-12-15 05:07:38 +0000140 EGLContext shareContext, bool useContextPriority,
141 Protection protection);
Peiyong Lina5e9f1b2018-11-27 22:49:37 -0800142 static EGLSurface createDummyEglPbufferSurface(EGLDisplay display, EGLConfig config,
Peiyong Linfb530cf2018-12-15 05:07:38 +0000143 int hwcFormat, Protection protection);
Alec Mouri554d06e2018-12-20 00:15:33 -0800144 bool waitSync(EGLSyncKHR sync, EGLint flags);
Peiyong Linf11f39b2018-09-05 14:37:41 -0700145
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700146 // A data space is considered HDR data space if it has BT2020 color space
147 // with PQ or HLG transfer function.
148 bool isHdrDataSpace(const ui::Dataspace dataSpace) const;
149 bool needsXYZTransformMatrix() const;
Alec Mouri1089aed2018-10-25 21:33:57 -0700150 // Defines the viewport, and sets the projection matrix to the projection
151 // defined by the clip.
152 void setViewportAndProjection(Rect viewport, Rect clip);
Alec Mouri539319f2018-12-19 17:56:23 -0800153 // Evicts stale images from the buffer cache.
154 void evictImages(const std::vector<LayerSettings>& layers);
Alec Mouri7c94edb2018-12-03 21:23:26 -0800155 // Computes the cropping window for the layer and sets up cropping
156 // coordinates for the mesh.
157 FloatRect setupLayerCropping(const LayerSettings& layer, Mesh& mesh);
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700158
Peiyong Linf11f39b2018-09-05 14:37:41 -0700159 EGLDisplay mEGLDisplay;
160 EGLConfig mEGLConfig;
161 EGLContext mEGLContext;
Alec Mouri0a9c7b82018-11-16 13:05:25 -0800162 EGLSurface mDummySurface;
Peiyong Linfb530cf2018-12-15 05:07:38 +0000163 EGLContext mProtectedEGLContext;
164 EGLSurface mProtectedDummySurface;
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700165 GLuint mProtectedTexName;
166 GLint mMaxViewportDims[2];
167 GLint mMaxTextureSize;
168 GLuint mVpWidth;
169 GLuint mVpHeight;
170 Description mState;
171
Peiyong Lin70b26ce2018-09-18 19:02:39 -0700172 mat4 mSrgbToXyz;
Peiyong Lin70b26ce2018-09-18 19:02:39 -0700173 mat4 mDisplayP3ToXyz;
Valerie Haueb8e0762018-11-06 10:10:42 -0800174 mat4 mBt2020ToXyz;
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700175 mat4 mXyzToSrgb;
176 mat4 mXyzToDisplayP3;
177 mat4 mXyzToBt2020;
Valerie Haueb8e0762018-11-06 10:10:42 -0800178 mat4 mSrgbToDisplayP3;
179 mat4 mSrgbToBt2020;
180 mat4 mDisplayP3ToSrgb;
181 mat4 mDisplayP3ToBt2020;
182 mat4 mBt2020ToSrgb;
183 mat4 mBt2020ToDisplayP3;
Peiyong Line5a9a7f2018-08-30 15:32:13 -0700184
Peiyong Linfb530cf2018-12-15 05:07:38 +0000185 bool mInProtectedContext = false;
Alec Mouri554d06e2018-12-20 00:15:33 -0800186 // If set to true, then enables tracing flush() and finish() to systrace.
187 bool mTraceGpuCompletion = false;
Alec Mouri05483a02018-09-10 21:03:42 +0000188 int32_t mFboHeight = 0;
Alec Mourida4cf3b2019-02-12 15:33:01 -0800189 // Maximum size of mFramebufferImageCache. If more images would be cached, then (approximately)
190 // the last recently used buffer should be kicked out.
191 uint32_t mFramebufferImageCacheSize = 0;
192
193 // Cache of output images, keyed by corresponding GraphicBuffer ID.
194 std::deque<std::pair<uint64_t, EGLImageKHR>> mFramebufferImageCache;
Peiyong Linfb069302018-04-25 14:34:31 -0700195
196 // Current dataspace of layer being rendered
197 ui::Dataspace mDataSpace = ui::Dataspace::UNKNOWN;
198
199 // Current output dataspace of the render engine
200 ui::Dataspace mOutputDataSpace = ui::Dataspace::UNKNOWN;
201
Peiyong Lin13effd12018-07-24 17:01:47 -0700202 // Whether device supports color management, currently color management
203 // supports sRGB, DisplayP3 color spaces.
204 const bool mUseColorManagement = false;
Alec Mouri554d06e2018-12-20 00:15:33 -0800205
Alec Mouri539319f2018-12-19 17:56:23 -0800206 // Cache of GL images that we'll store per GraphicBuffer ID
Alec Mourif0497272019-03-11 15:53:11 -0700207 std::unordered_map<uint64_t, std::unique_ptr<Image>> mImageCache GUARDED_BY(mRenderingMutex);
208 // Mutex guarding rendering operations, so that:
209 // 1. GL operations aren't interleaved, and
210 // 2. Internal state related to rendering that is potentially modified by
211 // multiple threads is guaranteed thread-safe.
212 std::mutex mRenderingMutex;
213
214 // See bindExternalTextureBuffer above, but requiring that mRenderingMutex
215 // is held.
216 status_t bindExternalTextureBufferLocked(uint32_t texName, sp<GraphicBuffer> buffer,
217 sp<Fence> fence) REQUIRES(mRenderingMutex);
Alec Mouri539319f2018-12-19 17:56:23 -0800218
Alec Mouri820c7402019-01-23 13:02:39 -0800219 std::unique_ptr<Framebuffer> mDrawingBuffer;
220
Alec Mouri554d06e2018-12-20 00:15:33 -0800221 class FlushTracer {
222 public:
223 FlushTracer(GLESRenderEngine* engine);
224 ~FlushTracer();
225 void queueSync(EGLSyncKHR sync) EXCLUDES(mMutex);
226
227 struct QueueEntry {
228 EGLSyncKHR mSync = nullptr;
229 uint64_t mFrameNum = 0;
230 };
231
232 private:
233 void loop();
234 GLESRenderEngine* const mEngine;
235 std::thread mThread;
236 std::condition_variable_any mCondition;
237 std::mutex mMutex;
238 std::queue<QueueEntry> mQueue GUARDED_BY(mMutex);
239 uint64_t mFramesQueued GUARDED_BY(mMutex) = 0;
240 bool mRunning = true;
241 };
242 friend class FlushTracer;
243 std::unique_ptr<FlushTracer> mFlushTracer;
Mathias Agopian3f844832013-08-07 21:24:32 -0700244};
245
Peiyong Lin46080ef2018-10-26 18:43:14 -0700246} // namespace gl
247} // namespace renderengine
248} // namespace android
Mathias Agopian3f844832013-08-07 21:24:32 -0700249
Peiyong Lin7e219eb2018-12-03 05:40:42 -0800250#endif /* SF_GLESRENDERENGINE_H_ */