SurfaceFlinger.h revision c8e387edfcead55b6e6fb1d05db279c264b644fa
1edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project/* 2edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project 3edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * 4edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 5edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * you may not use this file except in compliance with the License. 6edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * You may obtain a copy of the License at 7edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * 8edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 9edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * 10edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 11edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 12edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * See the License for the specific language governing permissions and 14edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project * limitations under the License. 15edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project */ 16edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 17edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#ifndef ANDROID_SURFACE_FLINGER_H 18edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#define ANDROID_SURFACE_FLINGER_H 19edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 2087670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#include <memory> 21edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <stdint.h> 22edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <sys/types.h> 23edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 24921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian#include <EGL/egl.h> 253f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian 263f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian/* 273f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian * NOTE: Make sure this file doesn't include anything from <gl/ > or <gl2/ > 283f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian */ 29921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 3099ed22412db547c59d3da08114d9d5a586442b30Glenn Kasten#include <cutils/compiler.h> 3199ed22412db547c59d3da08114d9d5a586442b30Glenn Kasten 32edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/Atomic.h> 33edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/Errors.h> 3499b49840d309727678b77403d6cc9f920111623fMathias Agopian#include <utils/KeyedVector.h> 35076b1cc3a9b90aa5b381a1ed268ca0b548444c9bMathias Agopian#include <utils/RefBase.h> 3699b49840d309727678b77403d6cc9f920111623fMathias Agopian#include <utils/SortedVector.h> 3799b49840d309727678b77403d6cc9f920111623fMathias Agopian#include <utils/threads.h> 38edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 393d4039d7a291cd9b6f2dd4b46fcdb576f2db3356Brian Anderson#include <ui/FenceTime.h> 40edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <ui/PixelFormat.h> 411d77b719d51a01cbd6954a048fb64e79d50a950eMathias Agopian#include <math/mat4.h> 42921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 430a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson#include <gui/FrameTimestamps.h> 4490ac799241f077a7b7e6c1875fd933864c8dd2a7Mathias Agopian#include <gui/ISurfaceComposer.h> 4590ac799241f077a7b7e6c1875fd933864c8dd2a7Mathias Agopian#include <gui/ISurfaceComposerClient.h> 46e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza#include <gui/OccupancyTracker.h> 47edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 488630320433bd15aca239522e54e711ef6372ab07Mathias Agopian#include <hardware/hwcomposer_defs.h> 498630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 5028f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright#include <system/graphics.h> 5128f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright 52921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian#include <private/gui/LayerState.h> 53edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 54921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian#include "Barrier.h" 5592a979a92c34b7de609ce2b1662c73bb8a2728b9Mathias Agopian#include "DisplayDevice.h" 56faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis#include "DispSync.h" 574b0eba949cc026ffb2c75313042d8a7bcb3fcf86Jamie Gennis#include "FrameTracker.h" 582047fae0cfed99c425dc7333f31d309e5b8ee1baRobert Carr#include "LayerVector.h" 594b0eba949cc026ffb2c75313042d8a7bcb3fcf86Jamie Gennis#include "MessageQueue.h" 60468051e20be19130572231266db306396a56402bIrvel#include "SurfaceInterceptor.h" 61b254fa3a9eccd5ad7d853d687cf50a68dd8ee41cWei Wang#include "StartBootAnimThread.h" 62f1d8e87b09abf963cd5b6a026194c1940fadb7b4Mathias Agopian 638630320433bd15aca239522e54e711ef6372ab07Mathias Agopian#include "DisplayHardware/HWComposer.h" 64ff2ed70fa30f04b90dd1a2c06ec2319e157152d7Mathias Agopian#include "Effects/Daltonizer.h" 658630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 66e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza#include <map> 670a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson#include <mutex> 680a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson#include <queue> 69e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza#include <string> 700a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson#include <utility> 71e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 72edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectnamespace android { 73edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 74edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// --------------------------------------------------------------------------- 75edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 76edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectclass Client; 77d0566bc26fcf6ca396118701fa11900b627f2c09Mathias Agopianclass DisplayEventConnection; 78d0566bc26fcf6ca396118701fa11900b627f2c09Mathias Agopianclass EventThread; 79f8b4ca51111cd2e566d1774ac464da859db78976Romain Guyclass IGraphicBufferAlloc; 80edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectclass Layer; 81b7e930db175c192464cebdeb49eb56cf6dd60114Mathias Agopianclass LayerDim; 82e3c697fb929c856b59fa56a8e05a2a7eba187c3dMathias Agopianclass Surface; 83875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopianclass RenderEngine; 84d1700756ec9520c3fba22f9a14fd064a6e288810Jamie Gennisclass EventControlThread; 85c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanjuclass VSyncSource; 86c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanjuclass InjectVSyncSource; 8787670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaarclass VrStateCallbacks; 8887670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar 8987670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaarnamespace dvr { 9087670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaarclass VrFlinger; 9187670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar} // namespace dvr 92edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 93edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// --------------------------------------------------------------------------- 94edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 95edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectenum { 96e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian eTransactionNeeded = 0x01, 97e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian eTraversalNeeded = 0x02, 98e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian eDisplayTransactionNeeded = 0x04, 99e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian eTransactionMask = 0x07 100edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project}; 101edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 1024f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopianclass SurfaceFlinger : public BnSurfaceComposer, 103921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian private IBinder::DeathRecipient, 1048630320433bd15aca239522e54e711ef6372ab07Mathias Agopian private HWComposer::EventHandler 105edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project{ 106edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectpublic: 1070cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard 1080cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // This is the phase offset in nanoseconds of the software vsync event 1090cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // relative to the vsync event reported by HWComposer. The software vsync 1100cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // event is when SurfaceFlinger and Choreographer-based applications run each 1110cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // frame. 1120cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // 1130cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // This phase offset allows adjustment of the minimum latency from application 1140cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // wake-up time (by Choreographer) to the time at which the resulting window 1150cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // image is displayed. This value may be either positive (after the HW vsync) 1160cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // or negative (before the HW vsync). Setting it to 0 will result in a lower 1170cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // latency bound of two vsync periods because the app and SurfaceFlinger 1180cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // will run just after the HW vsync. Setting it to a positive number will 1190cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // result in the minimum latency being: 1200cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // 1210cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // (2 * VSYNC_PERIOD - (vsyncPhaseOffsetNs % VSYNC_PERIOD)) 1220cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // 1230cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // Note that reducing this latency makes it more likely for the applications 1240cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // to not have their window content image ready in time. When this happens 1250cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // the latency will end up being an additional vsync period, and animations 1260cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // will hiccup. Therefore, this latency should be tuned somewhat 1270cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard // conservatively (or at least with awareness of the trade-off being made). 1280cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard static int64_t vsyncPhaseOffsetNs; 1290cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard static int64_t sfVsyncPhaseOffsetNs; 1300cc1938871edd6659d6783404a3523abc6b98d92Fabien Sanglard 131c93afd54a05497c4ae42db99ea0310ee69cca492Fabien Sanglard // Instruct the Render Engine to use EGL_IMG_context_priority is available. 132c93afd54a05497c4ae42db99ea0310ee69cca492Fabien Sanglard static bool useContextPriority; 133c93afd54a05497c4ae42db99ea0310ee69cca492Fabien Sanglard 134c45a7d9dfdefa07512c5acc07bcbee5362b34e3dFabien Sanglard // The offset in nanoseconds to use when DispSync timestamps present fence 135c45a7d9dfdefa07512c5acc07bcbee5362b34e3dFabien Sanglard // signaling time. 136c45a7d9dfdefa07512c5acc07bcbee5362b34e3dFabien Sanglard static int64_t dispSyncPresentTimeOffset; 137c45a7d9dfdefa07512c5acc07bcbee5362b34e3dFabien Sanglard 138a34ed639c3057b99da0fb703beb12827e30aa508Fabien Sanglard // Some hardware can do RGB->YUV conversion more efficiently in hardware 139a34ed639c3057b99da0fb703beb12827e30aa508Fabien Sanglard // controlled by HWC than in hardware controlled by the video encoder. 140a34ed639c3057b99da0fb703beb12827e30aa508Fabien Sanglard // This instruct VirtualDisplaySurface to use HWC for such conversion on 141a34ed639c3057b99da0fb703beb12827e30aa508Fabien Sanglard // GL composition. 142a34ed639c3057b99da0fb703beb12827e30aa508Fabien Sanglard static bool useHwcForRgbToYuv; 143a34ed639c3057b99da0fb703beb12827e30aa508Fabien Sanglard 144c8e387edfcead55b6e6fb1d05db279c264b644faFabien Sanglard // Maximum dimension supported by HWC for virtual display. 145c8e387edfcead55b6e6fb1d05db279c264b644faFabien Sanglard // Equal to min(max_height, max_width). 146c8e387edfcead55b6e6fb1d05db279c264b644faFabien Sanglard static uint64_t maxVirtualDisplaySize; 147c8e387edfcead55b6e6fb1d05db279c264b644faFabien Sanglard 148b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian static char const* getServiceName() ANDROID_API { 149921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian return "SurfaceFlinger"; 150921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian } 151118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 152b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian SurfaceFlinger() ANDROID_API; 15399ce5cdeb383216dee95af4d90e47406b0948ea1Mathias Agopian 1544f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian // must be called before clients can connect 1554f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian void init() ANDROID_API; 1564f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian 1574f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian // starts SurfaceFlinger main loop in the current thread 1584f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian void run() ANDROID_API; 1594f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian 1608630320433bd15aca239522e54e711ef6372ab07Mathias Agopian enum { 1618630320433bd15aca239522e54e711ef6372ab07Mathias Agopian EVENT_VSYNC = HWC_EVENT_VSYNC 1628630320433bd15aca239522e54e711ef6372ab07Mathias Agopian }; 1638630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 164921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // post an asynchronous message to the main thread 1653f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian status_t postMessageAsync(const sp<MessageBase>& msg, nsecs_t reltime = 0, uint32_t flags = 0); 166118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 167921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // post a synchronous message to the main thread 1683f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian status_t postMessageSync(const sp<MessageBase>& msg, nsecs_t reltime = 0, uint32_t flags = 0); 169118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 170921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // force full composition on all displays 171921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void repaintEverything(); 172b7e930db175c192464cebdeb49eb56cf6dd60114Mathias Agopian 173921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // returns the default Display 1744297734c1156fd8ede7e9c61b1e439f9e1c18cd9Mathias Agopian sp<const DisplayDevice> getDefaultDisplayDevice() const { 175692c723e84e6f2747447d871d468ff50e5c73f19Jesse Hall return getDisplayDevice(mBuiltinDisplays[DisplayDevice::DISPLAY_PRIMARY]); 176921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian } 177118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 1788630320433bd15aca239522e54e711ef6372ab07Mathias Agopian // utility function to delete a texture on the main thread 1793f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void deleteTextureAsync(uint32_t texture); 1808630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 1818630320433bd15aca239522e54e711ef6372ab07Mathias Agopian // enable/disable h/w composer event 1828630320433bd15aca239522e54e711ef6372ab07Mathias Agopian // TODO: this should be made accessible only to EventThread 1839d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifdef USE_HWC2 1849e56aa0fdb5f7121b9b975c6c16db103ea4d2fe9Dan Stoza void setVsyncEnabled(int disp, int enabled); 1859d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#else 1869d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard void eventControl(int disp, int event, int enabled); 1879d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 1888630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 189921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // called on the main thread by MessageQueue when an internal message 190921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // is received 191921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // TODO: this should be made accessible only to MessageQueue 192921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void onMessageReceived(int32_t what); 193118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 194cb55857bbde34a06c19dde3db5064d1717a0173eMathias Agopian // for debugging only 195cb55857bbde34a06c19dde3db5064d1717a0173eMathias Agopian // TODO: this should be made accessible only to HWComposer 19648bc05b56df9919fc39c5f2e3ea6535560eec98fJesse Hall const Vector< sp<Layer> >& getLayerSortedByZForHwcDisplay(int id); 197cb55857bbde34a06c19dde3db5064d1717a0173eMathias Agopian 198875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian RenderEngine& getRenderEngine() const { 199875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian return *mRenderEngine; 20029c3f352797d9d2ddf055d8f888e7694ef8b3947Jesse Hall } 20129c3f352797d9d2ddf055d8f888e7694ef8b3947Jesse Hall 2020d48072f6047140119ff194c1194ce402fca2c0bRobert Carr bool authenticateSurfaceTextureLocked( 2030d48072f6047140119ff194c1194ce402fca2c0bRobert Carr const sp<IGraphicBufferProducer>& bufferProducer) const; 2040d48072f6047140119ff194c1194ce402fca2c0bRobert Carr 2051f339ff3875afad128a8e16ee6395c5fad295826Mathias Agopianprivate: 20696f0819f81293076e652792794a961543e6750d7Mathias Agopian friend class Client; 207d0566bc26fcf6ca396118701fa11900b627f2c09Mathias Agopian friend class DisplayEventConnection; 208468051e20be19130572231266db306396a56402bIrvel friend class EventThread; 209edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project friend class Layer; 210b9b088375d33a87b201cdbe18be71802e2607717Dan Stoza friend class MonitoredProducer; 21187670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar friend class VrStateCallbacks; 212edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 2136547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis // This value is specified in number of frames. Log frame stats at most 2146547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis // every half hour. 2156547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis enum { LOG_FRAME_STATS_PERIOD = 30*60*60 }; 2166547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis 2177d89d06a6fe1bfadfe277f19dbb7e4aa021444e0Dan Stoza static const size_t MAX_LAYERS = 4096; 2187d89d06a6fe1bfadfe277f19dbb7e4aa021444e0Dan Stoza 219921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // We're reference counted, never destroy SurfaceFlinger directly 220921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual ~SurfaceFlinger(); 221edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 222921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 223921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Internal data structures 224921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 225118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 2262047fae0cfed99c425dc7333f31d309e5b8ee1baRobert Carr class State { 227edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project public: 228921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian LayerVector layersSortedByZ; 229e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian DefaultKeyedVector< wp<IBinder>, DisplayDeviceState> displays; 2302047fae0cfed99c425dc7333f31d309e5b8ee1baRobert Carr 2312047fae0cfed99c425dc7333f31d309e5b8ee1baRobert Carr void traverseInZOrder(const std::function<void(Layer*)>& consume) const; 2322047fae0cfed99c425dc7333f31d309e5b8ee1baRobert Carr void traverseInReverseZOrder(const std::function<void(Layer*)>& consume) const; 233edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project }; 234edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 235921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 236921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * IBinder interface 237921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 238921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual status_t onTransact(uint32_t code, const Parcel& data, 239921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian Parcel* reply, uint32_t flags); 240921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual status_t dump(int fd, const Vector<String16>& args); 241edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 242921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 243921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * ISurfaceComposer interface 244921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 245921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual sp<ISurfaceComposerClient> createConnection(); 2461db73f66624e7d151710483dd58e03eed672f064Robert Carr virtual sp<ISurfaceComposerClient> createScopedConnection(const sp<IGraphicBufferProducer>& gbp); 247f8b4ca51111cd2e566d1774ac464da859db78976Romain Guy virtual sp<IGraphicBufferAlloc> createGraphicBufferAlloc(); 248dd3cb84cfbe8068790c6233b5829fae9c4a0ee93Jamie Gennis virtual sp<IBinder> createDisplay(const String8& displayName, bool secure); 2496c913be9ca95fd6b556d056e165a4ba6dc69795bJesse Hall virtual void destroyDisplay(const sp<IBinder>& display); 250e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian virtual sp<IBinder> getBuiltInDisplay(int32_t id); 251921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual void setTransactionState(const Vector<ComposerState>& state, 2528b33f032327f8de0dcc0e6d0d43ed80f834b51f6Mathias Agopian const Vector<DisplayState>& displays, uint32_t flags); 25392a979a92c34b7de609ce2b1662c73bb8a2728b9Mathias Agopian virtual void bootFinished(); 254921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual bool authenticateSurfaceTexture( 2552adaf04fab35cf47c824d74d901b54094e01ccd3Andy McFadden const sp<IGraphicBufferProducer>& bufferProducer) const; 256069b365163470d2736eb6f591c354d208b5da23bBrian Anderson virtual status_t getSupportedFrameTimestamps( 2573890c3995c4a52439844faeb80b5503d42b977d8Brian Anderson std::vector<FrameEvent>* outSupported) const; 258921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual sp<IDisplayEventConnection> createDisplayEventConnection(); 2592a9fc493dfdba67108e4335bb1fe931bc1e2a025Mathias Agopian virtual status_t captureScreen(const sp<IBinder>& display, 2602a9fc493dfdba67108e4335bb1fe931bc1e2a025Mathias Agopian const sp<IGraphicBufferProducer>& producer, 261c18790018be5d7ea7061ccbc81f3044e74adc823Dan Stoza Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight, 262ae0608381b2b4699218febd6d45ad9d307544d55Robert Carr int32_t minLayerZ, int32_t maxLayerZ, 263c3ebe66b49cfba035e1fd0e160a13db38eb81b0eRiley Andrews bool useIdentityTransform, ISurfaceComposer::Rotation rotation); 26467d8bd66aaf04805cb8f2616ba964141b865e3b9Lajos Molnar virtual status_t getDisplayStats(const sp<IBinder>& display, 26567d8bd66aaf04805cb8f2616ba964141b865e3b9Lajos Molnar DisplayStatInfo* stats); 2667f7da32569f8e0b3d383a40b95f8ac1d55afd801Dan Stoza virtual status_t getDisplayConfigs(const sp<IBinder>& display, 2677f7da32569f8e0b3d383a40b95f8ac1d55afd801Dan Stoza Vector<DisplayInfo>* configs); 2687f7da32569f8e0b3d383a40b95f8ac1d55afd801Dan Stoza virtual int getActiveConfig(const sp<IBinder>& display); 26928f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright virtual status_t getDisplayColorModes(const sp<IBinder>& display, 27028f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright Vector<android_color_mode_t>* configs); 27128f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright virtual android_color_mode_t getActiveColorMode(const sp<IBinder>& display); 27228f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright virtual status_t setActiveColorMode(const sp<IBinder>& display, android_color_mode_t colorMode); 2732c9b11f0291210c9b9513a1a0cce6afebd361b3bPrashant Malani virtual void setPowerMode(const sp<IBinder>& display, int mode); 2747f7da32569f8e0b3d383a40b95f8ac1d55afd801Dan Stoza virtual status_t setActiveConfig(const sp<IBinder>& display, int id); 275d85084b2b65828442eafaff9b811e9b6c9ca9fadSvetoslav virtual status_t clearAnimationFrameStats(); 276d85084b2b65828442eafaff9b811e9b6c9ca9fadSvetoslav virtual status_t getAnimationFrameStats(FrameStats* outStats) const; 277c4f471e75a8ec64ec34e3f2944a5a756215d0becDan Stoza virtual status_t getHdrCapabilities(const sp<IBinder>& display, 278c4f471e75a8ec64ec34e3f2944a5a756215d0becDan Stoza HdrCapabilities* outCapabilities) const; 279c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju virtual status_t enableVSyncInjections(bool enable); 280c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju virtual status_t injectVSync(nsecs_t when); 281c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju 2821b03149f3533db04e72e088d3fdd09d0087ca594Mathias Agopian 283921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 284921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * DeathRecipient interface 285921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 286921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual void binderDied(const wp<IBinder>& who); 28799ce5cdeb383216dee95af4d90e47406b0948ea1Mathias Agopian 288921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 2894f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian * RefBase interface 290921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 291921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual void onFirstRef(); 292921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 293921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 2948630320433bd15aca239522e54e711ef6372ab07Mathias Agopian * HWComposer::EventHandler interface 2958630320433bd15aca239522e54e711ef6372ab07Mathias Agopian */ 2963cfac28462910d3f976aebac54ac7301aca7e434Steven Thomas virtual void onVSyncReceived(HWComposer* composer, int type, nsecs_t timestamp); 297148994e5f33ce240ff24ceb5bc0500b7f2001959Mathias Agopian virtual void onHotplugReceived(int disp, bool connected); 2983cfac28462910d3f976aebac54ac7301aca7e434Steven Thomas virtual void onInvalidateReceived(HWComposer* composer); 2998630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 3008630320433bd15aca239522e54e711ef6372ab07Mathias Agopian /* ------------------------------------------------------------------------ 301921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Message handling 302921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 303921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void waitForEvent(); 304921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void signalTransaction(); 305921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void signalLayerUpdate(); 306921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void signalRefresh(); 307921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 30813a082e160c2d1d8006b93a555a57035213d568bAndy McFadden // called on the main thread in response to initializeDisplays() 30913a082e160c2d1d8006b93a555a57035213d568bAndy McFadden void onInitializeDisplays(); 3106c9e34a98a63033b80bd1c24c7aa1304f912f10aMichael Lentine // called on the main thread in response to setActiveConfig() 3116c9e34a98a63033b80bd1c24c7aa1304f912f10aMichael Lentine void setActiveConfigInternal(const sp<DisplayDevice>& hw, int mode); 3122c9b11f0291210c9b9513a1a0cce6afebd361b3bPrashant Malani // called on the main thread in response to setPowerMode() 3132c9b11f0291210c9b9513a1a0cce6afebd361b3bPrashant Malani void setPowerModeInternal(const sp<DisplayDevice>& hw, int mode); 314921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 31528f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright // Called on the main thread in response to setActiveColorMode() 31628f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright void setActiveColorModeInternal(const sp<DisplayDevice>& hw, android_color_mode_t colorMode); 31728f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright 3186b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza // Returns whether the transaction actually modified any state 3196b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza bool handleMessageTransaction(); 3206b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza 3216b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza // Returns whether a new buffer has been latched (see handlePageFlip()) 3226b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza bool handleMessageInvalidate(); 3236b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza 324921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void handleMessageRefresh(); 325921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 32687baae104a3e4c2059990b01c393476065c558b0Mathias Agopian void handleTransaction(uint32_t transactionFlags); 32787baae104a3e4c2059990b01c393476065c558b0Mathias Agopian void handleTransactionLocked(uint32_t transactionFlags); 328921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 32903414a1cfe6c1222fd7723949bd622f9cba145aaRiley Andrews void updateCursorAsync(); 33003414a1cfe6c1222fd7723949bd622f9cba145aaRiley Andrews 3316b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza /* handlePageFlip - latch a new buffer if available and compute the dirty 3326b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza * region. Returns whether a new buffer has been latched, i.e., whether it 3336b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza * is necessary to perform a refresh during this vsync. 334921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 3356b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza bool handlePageFlip(); 336921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 337921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 338921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Transactions 339921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 340921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian uint32_t getTransactionFlags(uint32_t flags); 341c8251eb7a6ecfdd16b3e4cfbfb442aa4c789c039Fabien Sanglard uint32_t peekTransactionFlags(); 342921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian uint32_t setTransactionFlags(uint32_t flags); 343921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void commitTransaction(); 3443f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian uint32_t setClientStateLocked(const sp<Client>& client, const layer_state_t& s); 345e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian uint32_t setDisplayStateLocked(const DisplayState& s); 346921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 347921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 348921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Layer management 349921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 3504d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian status_t createLayer(const String8& name, const sp<Client>& client, 3514d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian uint32_t w, uint32_t h, PixelFormat format, uint32_t flags, 352479c60c85c40fd3536b0c88036e838dc1a4c56a0Albert Chaulk uint32_t windowType, uint32_t ownerUid, sp<IBinder>* handle, 353479c60c85c40fd3536b0c88036e838dc1a4c56a0Albert Chaulk sp<IGraphicBufferProducer>* gbp, sp<Layer>* parent); 3544d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian 3554d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian status_t createNormalLayer(const sp<Client>& client, const String8& name, 3564d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian uint32_t w, uint32_t h, uint32_t flags, PixelFormat& format, 3574d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian sp<IBinder>* outHandle, sp<IGraphicBufferProducer>* outGbp, 3584d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian sp<Layer>* outLayer); 3594d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian 3604d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian status_t createDimLayer(const sp<Client>& client, const String8& name, 3614d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian uint32_t w, uint32_t h, uint32_t flags, sp<IBinder>* outHandle, 3624d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian sp<IGraphicBufferProducer>* outGbp, sp<Layer>* outLayer); 363921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 364921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // called in response to the window-manager calling 365921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // ISurfaceComposerClient::destroySurface() 366ac9fa427d4a86745e60a5f7fd8e3ea340c4db907Mathias Agopian status_t onLayerRemoved(const sp<Client>& client, const sp<IBinder>& handle); 367921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 368921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // called when all clients have released all their references to 369921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // this layer meaning it is entirely safe to destroy all 370921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // resources associated to this layer. 37113127d8921356dff794250e04208c3ed60b3a3dfMathias Agopian status_t onLayerDestroyed(const wp<Layer>& layer); 372921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 373921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // remove a layer from SurfaceFlinger immediately 3749524cb3b37a91b5741790c77ff24fd825b02bca7Robert Carr status_t removeLayer(const sp<Layer>& layer); 375edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 376921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // add a layer to SurfaceFlinger 3777d89d06a6fe1bfadfe277f19dbb7e4aa021444e0Dan Stoza status_t addClientLayer(const sp<Client>& client, 3786710604286401d4205c27235a252dd0e5008cc08Mathias Agopian const sp<IBinder>& handle, 3796710604286401d4205c27235a252dd0e5008cc08Mathias Agopian const sp<IGraphicBufferProducer>& gbc, 3801f0a16a5d7cd00ba7fda82e7d315afa1fd1303b9Robert Carr const sp<Layer>& lbc, 3811f0a16a5d7cd00ba7fda82e7d315afa1fd1303b9Robert Carr const sp<Layer>& parent); 382921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 383921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 384921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Boot animation, on/off animations and screen capture 385921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 386921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 387921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void startBootAnim(); 388921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 389180f10de6f504d2ba56ff32ae8ed53c58bb458e9Mathias Agopian void renderScreenImplLocked( 390180f10de6f504d2ba56ff32ae8ed53c58bb458e9Mathias Agopian const sp<const DisplayDevice>& hw, 391c18790018be5d7ea7061ccbc81f3044e74adc823Dan Stoza Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight, 392ae0608381b2b4699218febd6d45ad9d307544d55Robert Carr int32_t minLayerZ, int32_t maxLayerZ, 393c3ebe66b49cfba035e1fd0e160a13db38eb81b0eRiley Andrews bool yswap, bool useIdentityTransform, Transform::orientation_flags rotation); 394180f10de6f504d2ba56ff32ae8ed53c58bb458e9Mathias Agopian 3952a9fc493dfdba67108e4335bb1fe931bc1e2a025Mathias Agopian status_t captureScreenImplLocked( 3962a9fc493dfdba67108e4335bb1fe931bc1e2a025Mathias Agopian const sp<const DisplayDevice>& hw, 397abe815dd6978b718c04f6e22e1a893d2b51d11a1Mathias Agopian const sp<IGraphicBufferProducer>& producer, 398c18790018be5d7ea7061ccbc81f3044e74adc823Dan Stoza Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight, 399ae0608381b2b4699218febd6d45ad9d307544d55Robert Carr int32_t minLayerZ, int32_t maxLayerZ, 400b5b3563058c178811d434ab6e8c4ead4a519701bPablo Ceballos bool useIdentityTransform, Transform::orientation_flags rotation, 401b5b3563058c178811d434ab6e8c4ead4a519701bPablo Ceballos bool isLocalScreenshot); 402abe815dd6978b718c04f6e22e1a893d2b51d11a1Mathias Agopian 403b254fa3a9eccd5ad7d853d687cf50a68dd8ee41cWei Wang sp<StartBootAnimThread> mStartBootAnimThread = nullptr; 404b254fa3a9eccd5ad7d853d687cf50a68dd8ee41cWei Wang 405921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 406921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * EGL 407921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 408875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian size_t getMaxTextureSize() const; 409875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian size_t getMaxViewportDims() const; 410921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 411921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 41287baae104a3e4c2059990b01c393476065c558b0Mathias Agopian * Display and layer stack management 413921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 41413a082e160c2d1d8006b93a555a57035213d568bAndy McFadden // called when starting, or restarting after system_server death 41513a082e160c2d1d8006b93a555a57035213d568bAndy McFadden void initializeDisplays(); 41613a082e160c2d1d8006b93a555a57035213d568bAndy McFadden 417692c723e84e6f2747447d871d468ff50e5c73f19Jesse Hall // Create an IBinder for a builtin display and add it to current state 418692c723e84e6f2747447d871d468ff50e5c73f19Jesse Hall void createBuiltinDisplayLocked(DisplayDevice::DisplayType type); 419692c723e84e6f2747447d871d468ff50e5c73f19Jesse Hall 420db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian // NOTE: can only be called from the main thread or with mStateLock held 4213ee454a7bef8bd3d1c9cdd9d17108eb80ebadf2aMathias Agopian sp<const DisplayDevice> getDisplayDevice(const wp<IBinder>& dpy) const { 42292a979a92c34b7de609ce2b1662c73bb8a2728b9Mathias Agopian return mDisplays.valueFor(dpy); 42392a979a92c34b7de609ce2b1662c73bb8a2728b9Mathias Agopian } 424db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian 425db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian // NOTE: can only be called from the main thread or with mStateLock held 426db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian sp<DisplayDevice> getDisplayDevice(const wp<IBinder>& dpy) { 4274297734c1156fd8ede7e9c61b1e439f9e1c18cd9Mathias Agopian return mDisplays.valueFor(dpy); 428921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian } 429921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 43028f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright int32_t getDisplayType(const sp<IBinder>& display) { 43128f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright if (!display.get()) return NAME_NOT_FOUND; 43228f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright for (int i = 0; i < DisplayDevice::NUM_BUILTIN_DISPLAY_TYPES; ++i) { 43328f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright if (display == mBuiltinDisplays[i]) { 43428f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright return i; 43528f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright } 43628f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright } 43728f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright return NAME_NOT_FOUND; 43828f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright } 43928f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright 44087baae104a3e4c2059990b01c393476065c558b0Mathias Agopian // mark a region of a layer stack dirty. this updates the dirty 44187baae104a3e4c2059990b01c393476065c558b0Mathias Agopian // region of all screens presenting this layer stack. 44287baae104a3e4c2059990b01c393476065c558b0Mathias Agopian void invalidateLayerStack(uint32_t layerStack, const Region& dirty); 44387baae104a3e4c2059990b01c393476065c558b0Mathias Agopian 4449d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifndef USE_HWC2 4459d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard int32_t allocateHwcDisplayId(DisplayDevice::DisplayType type); 4469d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 4479d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard 448921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 4498630320433bd15aca239522e54e711ef6372ab07Mathias Agopian * H/W composer 4508630320433bd15aca239522e54e711ef6372ab07Mathias Agopian */ 4518630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 4528630320433bd15aca239522e54e711ef6372ab07Mathias Agopian HWComposer& getHwComposer() const { return *mHwc; } 4538630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 454888c822c4cb6976aab9256c58bae9e17e3e55c5cMathias Agopian /* ------------------------------------------------------------------------ 455921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Compositing 456921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 457921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void invalidateHwcGeometry(); 4582047fae0cfed99c425dc7333f31d309e5b8ee1baRobert Carr void computeVisibleRegions(uint32_t layerStack, 45987baae104a3e4c2059990b01c393476065c558b0Mathias Agopian Region& dirtyRegion, Region& opaqueRegion); 460cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian 461d6927fb1143398370c0885844bfb58923ef740b7Brian Anderson void preComposition(nsecs_t refreshStartTime); 4620a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson void postComposition(nsecs_t refreshStartTime); 4630a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson void updateCompositorTiming( 4640a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson nsecs_t vsyncPhase, nsecs_t vsyncInterval, nsecs_t compositeTime, 4650a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson std::shared_ptr<FenceTime>& presentFenceTime); 466cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian void rebuildLayerStacks(); 467cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian void setUpHWComposer(); 468cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian void doComposition(); 469cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian void doDebugFlashRegions(); 470830b84704b0f33030d0e391a0ea2e7faa5646e2eFabien Sanglard void doDisplayComposition(const sp<const DisplayDevice>& displayDevice, const Region& dirtyRegion); 4713f121fc650d72d0103cef8e6a651093fb1589e0aMichael Lentine 4723f121fc650d72d0103cef8e6a651093fb1589e0aMichael Lentine // compose surfaces for display hw. this fails if using GL and the surface 4733f121fc650d72d0103cef8e6a651093fb1589e0aMichael Lentine // has been destroyed and is no longer valid. 474830b84704b0f33030d0e391a0ea2e7faa5646e2eFabien Sanglard bool doComposeSurfaces(const sp<const DisplayDevice>& displayDevice, const Region& dirty); 475cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian 476921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void postFramebuffer(); 477830b84704b0f33030d0e391a0ea2e7faa5646e2eFabien Sanglard void drawWormhole(const sp<const DisplayDevice>& displayDevice, const Region& region) const; 478921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 479921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 4800bceb84773882b796d9dacbaf96167cb15928d78Jamie Gennis * Display management 4810bceb84773882b796d9dacbaf96167cb15928d78Jamie Gennis */ 4823ee454a7bef8bd3d1c9cdd9d17108eb80ebadf2aMathias Agopian 483faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis /* ------------------------------------------------------------------------ 484faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis * VSync 485faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis */ 4860a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson void enableHardwareVsync(); 4870a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson void resyncToHardwareVsync(bool makeAvailable); 4880a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson void disableHardwareVsync(bool makeUnavailable); 4891f0a16a5d7cd00ba7fda82e7d315afa1fd1303b9Robert Carr 4904a4e4a239f034cb8af2df9a438b26c3bc088889cTim Murraypublic: 4910a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson void resyncWithRateLimit(); 4920a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson void getCompositorTiming(CompositorTiming* compositorTiming); 4934a4e4a239f034cb8af2df9a438b26c3bc088889cTim Murrayprivate: 4940bceb84773882b796d9dacbaf96167cb15928d78Jamie Gennis 4950bceb84773882b796d9dacbaf96167cb15928d78Jamie Gennis /* ------------------------------------------------------------------------ 496921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Debugging & dumpsys 497921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 4983f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void listLayersLocked(const Vector<String16>& args, size_t& index, String8& result) const; 4993f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void dumpStatsLocked(const Vector<String16>& args, size_t& index, String8& result) const; 5003f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void clearStatsLocked(const Vector<String16>& args, size_t& index, String8& result); 5013f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void dumpAllLocked(const Vector<String16>& args, size_t& index, String8& result) const; 50263f165fd6b86d04be94d4023e845e98560504a96Keun young Park bool startDdmConnection(); 50363a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard void appendSfConfigString(String8& result) const; 504d555684cb36dfb959694db76962e570184f98838Mathias Agopian void checkScreenshot(size_t w, size_t s, size_t h, void const* vaddr, 505fee2b463c5fbe8fa0132d03634ccc02ea55c1505Mathias Agopian const sp<const DisplayDevice>& hw, 506ae0608381b2b4699218febd6d45ad9d307544d55Robert Carr int32_t minLayerZ, int32_t maxLayerZ); 507921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 5086547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis void logFrameStats(); 5096547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis 510b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza void dumpStaticScreenStats(String8& result) const; 511d6927fb1143398370c0885844bfb58923ef740b7Brian Anderson // Not const because each Layer needs to query Fences and cache timestamps. 512d6927fb1143398370c0885844bfb58923ef740b7Brian Anderson void dumpFrameEventsLocked(String8& result); 513b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza 514e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza void recordBufferingStats(const char* layerName, 515e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza std::vector<OccupancyTracker::Segment>&& history); 516e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza void dumpBufferingStats(String8& result) const; 517e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 51863a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard bool isLayerTripleBufferingDisabled() const { 51963a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard return this->mLayerTripleBufferingDisabled; 52063a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard } 52187670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar 52287670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#ifdef USE_HWC2 52387670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar /* ------------------------------------------------------------------------ 52487670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar * VrFlinger 52587670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar */ 52687670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar void clearHwcLayers(const LayerVector& layers); 52787670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar void resetHwc(); 52887670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar 52987670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar // Check to see if we should change to or from vr mode, and if so, perform 53087670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar // the handoff. 53187670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar void updateVrMode(); 53287670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#endif 53387670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar 534921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 535921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Attributes 536921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 537921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 538921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // access must be protected by mStateLock 539921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian mutable Mutex mStateLock; 540921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian State mCurrentState; 541921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian volatile int32_t mTransactionFlags; 542921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian Condition mTransactionCV; 5432d5e230292c27d59f4c096bc742a0a19abf811c1Jamie Gennis bool mTransactionPending; 5442d5e230292c27d59f4c096bc742a0a19abf811c1Jamie Gennis bool mAnimTransactionPending; 5451f0a16a5d7cd00ba7fda82e7d315afa1fd1303b9Robert Carr SortedVector< sp<Layer> > mLayersPendingRemoval; 5466710604286401d4205c27235a252dd0e5008cc08Mathias Agopian SortedVector< wp<IBinder> > mGraphicBufferProducerList; 547921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 548921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // protected by mStateLock (but we could use another lock) 549921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian bool mLayersRemoved; 5501f0a16a5d7cd00ba7fda82e7d315afa1fd1303b9Robert Carr bool mLayersAdded; 551921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 552921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // access must be protected by mInvalidateLock 55387baae104a3e4c2059990b01c393476065c558b0Mathias Agopian volatile int32_t mRepaintEverything; 554921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 55587670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar // current, real and vr hardware composers. 5568630320433bd15aca239522e54e711ef6372ab07Mathias Agopian HWComposer* mHwc; 55787670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#ifdef USE_HWC2 55887670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar HWComposer* mRealHwc; 55987670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar HWComposer* mVrHwc; 56087670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#endif 56187670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar // constant members (no synchronization needed for access) 562875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian RenderEngine* mRenderEngine; 563921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian nsecs_t mBootTime; 564b4b1730abb7824dc084468c4942f010d94a7e039Mathias Agopian bool mGpuToCpuSupported; 565921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian sp<EventThread> mEventThread; 5660a645cc5a935e67a8d1effc7679a838160b971d8Jamie Gennis sp<EventThread> mSFEventThread; 567c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju sp<EventThread> mInjectorEventThread; 568c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju sp<InjectVSyncSource> mVSyncInjector; 569d1700756ec9520c3fba22f9a14fd064a6e288810Jamie Gennis sp<EventControlThread> mEventControlThread; 570921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian EGLContext mEGLContext; 57134a09ba1efd706323a15633da5044b352988eb5fJesse Hall EGLDisplay mEGLDisplay; 5729e663de4fe1dcc872373ee530c60a375624671c3Jesse Hall sp<IBinder> mBuiltinDisplays[DisplayDevice::NUM_BUILTIN_DISPLAY_TYPES]; 573921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 57487670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#ifdef USE_HWC2 57587670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar std::unique_ptr<dvr::VrFlinger> mVrFlinger; 57687670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#endif 57787670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar 578921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // Can only accessed from the main thread, these members 579921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // don't need synchronization 580921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian State mDrawingState; 581921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian bool mVisibleRegionsDirty; 5829d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifndef USE_HWC2 5839d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard bool mHwWorkListDirty; 5849d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#else 5859e56aa0fdb5f7121b9b975c6c16db103ea4d2fe9Dan Stoza bool mGeometryInvalid; 5869d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 5874b0eba949cc026ffb2c75313042d8a7bcb3fcf86Jamie Gennis bool mAnimCompositionPending; 5889d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifdef USE_HWC2 5899e56aa0fdb5f7121b9b975c6c16db103ea4d2fe9Dan Stoza std::vector<sp<Layer>> mLayersWithQueuedFrames; 59005dacfb68af895fce3cc8ebb0b4aa06c6c336e26Dan Stoza sp<Fence> mPreviousPresentFence = Fence::NO_FENCE; 59105dacfb68af895fce3cc8ebb0b4aa06c6c336e26Dan Stoza bool mHadClientComposition = false; 5929d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 5933d4039d7a291cd9b6f2dd4b46fcdb576f2db3356Brian Anderson FenceTimeline mGlCompositionDoneTimeline; 5943d4039d7a291cd9b6f2dd4b46fcdb576f2db3356Brian Anderson FenceTimeline mDisplayTimeline; 595db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian 596db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian // this may only be written from the main thread with mStateLock held 597db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian // it may be read from other threads with mStateLock held 5983ee454a7bef8bd3d1c9cdd9d17108eb80ebadf2aMathias Agopian DefaultKeyedVector< wp<IBinder>, sp<DisplayDevice> > mDisplays; 599921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 600921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // don't use a lock for these, we don't care 6013a8f794471815e6419caefe254adf2bbb19a8a53Mark Urbanus int mVrModeSupported; 602921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian int mDebugRegion; 603921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian int mDebugDDMS; 604921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian int mDebugDisableHWC; 605921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian int mDebugDisableTransformHint; 606921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian volatile nsecs_t mDebugInSwapBuffers; 607921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian nsecs_t mLastSwapBufferTime; 608921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian volatile nsecs_t mDebugInTransaction; 609921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian nsecs_t mLastTransactionTime; 610921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian bool mBootFinished; 611ee44edd0acccbf5eaa918d75737c3b65ee04fff7Dan Stoza bool mForceFullDamage; 6129d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifdef USE_HWC2 613c5da271eec001da9e11a2786f2618a45257439c3Dan Stoza bool mPropagateBackpressure = true; 6149d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 615468051e20be19130572231266db306396a56402bIrvel SurfaceInterceptor mInterceptor; 616642b23d70f7b513e88680c1d8400c1c1cfe6edd3Fabien Sanglard bool mUseHwcVirtualDisplays = false; 617921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 61863a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard // Restrict layers to use two buffers in their bufferqueues. 61963a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard bool mLayerTripleBufferingDisabled = false; 62063a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard 621921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // these are thread safe 622921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian mutable MessageQueue mEventQueue; 6234b0eba949cc026ffb2c75313042d8a7bcb3fcf86Jamie Gennis FrameTracker mAnimFrameTracker; 624faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis DispSync mPrimaryDispSync; 625921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 626921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // protected by mDestroyedLayerLock; 627921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian mutable Mutex mDestroyedLayerLock; 62813127d8921356dff794250e04208c3ed60b3a3dfMathias Agopian Vector<Layer const *> mDestroyedLayers; 629921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 630faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis // protected by mHWVsyncLock 631faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis Mutex mHWVsyncLock; 632faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis bool mPrimaryHWVsyncEnabled; 633948fe0ce74c13e1bbff233883c158519fa8fb293Jesse Hall bool mHWVsyncAvailable; 634faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis 6350a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson // protected by mCompositorTimingLock; 6360a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson mutable std::mutex mCompositeTimingLock; 6370a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson CompositorTiming mCompositorTiming; 6380a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson 6390a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson // Only accessed from the main thread. 6400a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson struct CompositePresentTime { 6410a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson nsecs_t composite { -1 }; 6420a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson std::shared_ptr<FenceTime> display { FenceTime::NO_FENCE }; 6430a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson }; 6440a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson std::queue<CompositePresentTime> mCompositePresentTimes; 6450a61b0c813f5991bf462e36a2314dda062727a10Brian Anderson 646921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 647921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Feature prototyping 648921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 649921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 650c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju bool mInjectVSyncs; 651c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju 652ff2ed70fa30f04b90dd1a2c06ec2319e157152d7Mathias Agopian Daltonizer mDaltonizer; 6539d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifndef USE_HWC2 6549d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard bool mDaltonize; 6559d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 6569c5a3335110769993d3fe997bdf1d594954d4304Alan Viverette 6579f26a9c8be6f00f55cbc30b93adf4895c6a093aaDan Stoza mat4 mPreviousColorMatrix; 6589c5a3335110769993d3fe997bdf1d594954d4304Alan Viverette mat4 mColorMatrix; 6599c5a3335110769993d3fe997bdf1d594954d4304Alan Viverette bool mHasColorMatrix; 660b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza 661b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza // Static screen stats 662b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza bool mHasPoweredOff; 663b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza static const size_t NUM_BUCKETS = 8; // < 1-7, 7+ 664b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza nsecs_t mFrameBuckets[NUM_BUCKETS]; 665b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza nsecs_t mTotalTime; 6664a4e4a239f034cb8af2df9a438b26c3bc088889cTim Murray std::atomic<nsecs_t> mLastSwapTime; 667e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 6681f0a16a5d7cd00ba7fda82e7d315afa1fd1303b9Robert Carr size_t mNumLayers; 6691f0a16a5d7cd00ba7fda82e7d315afa1fd1303b9Robert Carr 670e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // Double- vs. triple-buffering stats 671e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza struct BufferingStats { 672e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza BufferingStats() 673e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza : numSegments(0), 674e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza totalTime(0), 675e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza twoBufferTime(0), 676e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza doubleBufferedTime(0), 677e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza tripleBufferedTime(0) {} 678e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 679e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza size_t numSegments; 680e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza nsecs_t totalTime; 681e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 682e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // "Two buffer" means that a third buffer was never used, whereas 683e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // "double-buffered" means that on average the segment only used two 684e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // buffers (though it may have used a third for some part of the 685e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // segment) 686e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza nsecs_t twoBufferTime; 687e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza nsecs_t doubleBufferedTime; 688e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza nsecs_t tripleBufferedTime; 689e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza }; 690e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza mutable Mutex mBufferingStatsMutex; 691e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza std::unordered_map<std::string, BufferingStats> mBufferingStats; 6926e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard 6936e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard // Verify that transaction is being called by an approved process: 6946e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard // either AID_GRAPHICS or AID_SYSTEM. 6956e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard status_t CheckTransactCodeCredentials(uint32_t code); 69687670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar 69787670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#ifdef USE_HWC2 69887670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar sp<VrStateCallbacks> mVrStateCallbacks; 69987670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar 70087670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar std::atomic<bool> mEnterVrMode; 70187670ffe26079eb50b62f698eb0f7bfa8ee51debHendrik Wagenaar#endif 7026e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard }; 703edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project}; // namespace android 704edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 705edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#endif // ANDROID_SURFACE_FLINGER_H 706