SurfaceFlinger.h revision ae0608381b2b4699218febd6d45ad9d307544d55
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 20edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <stdint.h> 21edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <sys/types.h> 22edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 23921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian#include <EGL/egl.h> 243f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian 253f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian/* 263f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian * NOTE: Make sure this file doesn't include anything from <gl/ > or <gl2/ > 273f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian */ 28921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 2999ed22412db547c59d3da08114d9d5a586442b30Glenn Kasten#include <cutils/compiler.h> 3099ed22412db547c59d3da08114d9d5a586442b30Glenn Kasten 31edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/Atomic.h> 32edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <utils/Errors.h> 3399b49840d309727678b77403d6cc9f920111623fMathias Agopian#include <utils/KeyedVector.h> 34076b1cc3a9b90aa5b381a1ed268ca0b548444c9bMathias Agopian#include <utils/RefBase.h> 3599b49840d309727678b77403d6cc9f920111623fMathias Agopian#include <utils/SortedVector.h> 3699b49840d309727678b77403d6cc9f920111623fMathias Agopian#include <utils/threads.h> 37edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 3899b49840d309727678b77403d6cc9f920111623fMathias Agopian#include <binder/IMemory.h> 39375f56363a8737119ce2222dcfaacbe1cf733fc0Mathias Agopian 403d4039d7a291cd9b6f2dd4b46fcdb576f2db3356Brian Anderson#include <ui/FenceTime.h> 41edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#include <ui/PixelFormat.h> 429c5a3335110769993d3fe997bdf1d594954d4304Alan Viverette#include <ui/mat4.h> 43921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 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" 584b0eba949cc026ffb2c75313042d8a7bcb3fcf86Jamie Gennis#include "MessageQueue.h" 59468051e20be19130572231266db306396a56402bIrvel#include "SurfaceInterceptor.h" 60f1d8e87b09abf963cd5b6a026194c1940fadb7b4Mathias Agopian 618630320433bd15aca239522e54e711ef6372ab07Mathias Agopian#include "DisplayHardware/HWComposer.h" 62ff2ed70fa30f04b90dd1a2c06ec2319e157152d7Mathias Agopian#include "Effects/Daltonizer.h" 638630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 64e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza#include <map> 65e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza#include <string> 66e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 67edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectnamespace android { 68edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 69edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// --------------------------------------------------------------------------- 70edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 71edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectclass Client; 72d0566bc26fcf6ca396118701fa11900b627f2c09Mathias Agopianclass DisplayEventConnection; 73d0566bc26fcf6ca396118701fa11900b627f2c09Mathias Agopianclass EventThread; 74f33e4b6f13bc3ee2d2a4e1abd1ada171c70d3492Mathias Agopianclass IGraphicBufferAlloc; 75edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectclass Layer; 76b7e930db175c192464cebdeb49eb56cf6dd60114Mathias Agopianclass LayerDim; 77e3c697fb929c856b59fa56a8e05a2a7eba187c3dMathias Agopianclass Surface; 78875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopianclass RenderEngine; 79d1700756ec9520c3fba22f9a14fd064a6e288810Jamie Gennisclass EventControlThread; 80c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanjuclass VSyncSource; 81c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanjuclass InjectVSyncSource; 82edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 83edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project// --------------------------------------------------------------------------- 84edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 85edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectenum { 86e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian eTransactionNeeded = 0x01, 87e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian eTraversalNeeded = 0x02, 88e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian eDisplayTransactionNeeded = 0x04, 89e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian eTransactionMask = 0x07 90edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project}; 91edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 924f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopianclass SurfaceFlinger : public BnSurfaceComposer, 93921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian private IBinder::DeathRecipient, 948630320433bd15aca239522e54e711ef6372ab07Mathias Agopian private HWComposer::EventHandler 95edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project{ 96edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Projectpublic: 97b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian static char const* getServiceName() ANDROID_API { 98921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian return "SurfaceFlinger"; 99921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian } 100118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 101b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian SurfaceFlinger() ANDROID_API; 10299ce5cdeb383216dee95af4d90e47406b0948ea1Mathias Agopian 1034f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian // must be called before clients can connect 1044f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian void init() ANDROID_API; 1054f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian 1064f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian // starts SurfaceFlinger main loop in the current thread 1074f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian void run() ANDROID_API; 1084f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian 1098630320433bd15aca239522e54e711ef6372ab07Mathias Agopian enum { 1108630320433bd15aca239522e54e711ef6372ab07Mathias Agopian EVENT_VSYNC = HWC_EVENT_VSYNC 1118630320433bd15aca239522e54e711ef6372ab07Mathias Agopian }; 1128630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 113921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // post an asynchronous message to the main thread 1143f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian status_t postMessageAsync(const sp<MessageBase>& msg, nsecs_t reltime = 0, uint32_t flags = 0); 115118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 116921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // post a synchronous message to the main thread 1173f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian status_t postMessageSync(const sp<MessageBase>& msg, nsecs_t reltime = 0, uint32_t flags = 0); 118118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 119921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // force full composition on all displays 120921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void repaintEverything(); 121b7e930db175c192464cebdeb49eb56cf6dd60114Mathias Agopian 122921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // returns the default Display 1234297734c1156fd8ede7e9c61b1e439f9e1c18cd9Mathias Agopian sp<const DisplayDevice> getDefaultDisplayDevice() const { 124692c723e84e6f2747447d871d468ff50e5c73f19Jesse Hall return getDisplayDevice(mBuiltinDisplays[DisplayDevice::DISPLAY_PRIMARY]); 125921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian } 126118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 1278630320433bd15aca239522e54e711ef6372ab07Mathias Agopian // utility function to delete a texture on the main thread 1283f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void deleteTextureAsync(uint32_t texture); 1298630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 1308630320433bd15aca239522e54e711ef6372ab07Mathias Agopian // enable/disable h/w composer event 1318630320433bd15aca239522e54e711ef6372ab07Mathias Agopian // TODO: this should be made accessible only to EventThread 1329d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifdef USE_HWC2 1339e56aa0fdb5f7121b9b975c6c16db103ea4d2fe9Dan Stoza void setVsyncEnabled(int disp, int enabled); 1349d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#else 1359d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard void eventControl(int disp, int event, int enabled); 1369d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 1378630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 138921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // called on the main thread by MessageQueue when an internal message 139921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // is received 140921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // TODO: this should be made accessible only to MessageQueue 141921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void onMessageReceived(int32_t what); 142118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 143cb55857bbde34a06c19dde3db5064d1717a0173eMathias Agopian // for debugging only 144cb55857bbde34a06c19dde3db5064d1717a0173eMathias Agopian // TODO: this should be made accessible only to HWComposer 14548bc05b56df9919fc39c5f2e3ea6535560eec98fJesse Hall const Vector< sp<Layer> >& getLayerSortedByZForHwcDisplay(int id); 146cb55857bbde34a06c19dde3db5064d1717a0173eMathias Agopian 147875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian RenderEngine& getRenderEngine() const { 148875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian return *mRenderEngine; 14929c3f352797d9d2ddf055d8f888e7694ef8b3947Jesse Hall } 15029c3f352797d9d2ddf055d8f888e7694ef8b3947Jesse Hall 1511f339ff3875afad128a8e16ee6395c5fad295826Mathias Agopianprivate: 15296f0819f81293076e652792794a961543e6750d7Mathias Agopian friend class Client; 153d0566bc26fcf6ca396118701fa11900b627f2c09Mathias Agopian friend class DisplayEventConnection; 154468051e20be19130572231266db306396a56402bIrvel friend class EventThread; 155edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project friend class Layer; 156b9b088375d33a87b201cdbe18be71802e2607717Dan Stoza friend class MonitoredProducer; 157edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 1586547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis // This value is specified in number of frames. Log frame stats at most 1596547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis // every half hour. 1606547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis enum { LOG_FRAME_STATS_PERIOD = 30*60*60 }; 1616547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis 1627d89d06a6fe1bfadfe277f19dbb7e4aa021444e0Dan Stoza static const size_t MAX_LAYERS = 4096; 1637d89d06a6fe1bfadfe277f19dbb7e4aa021444e0Dan Stoza 164921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // We're reference counted, never destroy SurfaceFlinger directly 165921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual ~SurfaceFlinger(); 166edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 167921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 168921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Internal data structures 169921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 170118d0245ee0a3b107055782aa8b555404b6f0280Mathias Agopian 17113127d8921356dff794250e04208c3ed60b3a3dfMathias Agopian class LayerVector : public SortedVector< sp<Layer> > { 172edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project public: 173921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian LayerVector(); 174921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian LayerVector(const LayerVector& rhs); 175921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual int do_compare(const void* lhs, const void* rhs) const; 176edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project }; 177edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 178edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project struct State { 179921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian LayerVector layersSortedByZ; 180e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian DefaultKeyedVector< wp<IBinder>, DisplayDeviceState> displays; 181edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project }; 182edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 183921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 184921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * IBinder interface 185921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 186921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual status_t onTransact(uint32_t code, const Parcel& data, 187921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian Parcel* reply, uint32_t flags); 188921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual status_t dump(int fd, const Vector<String16>& args); 189edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 190921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 191921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * ISurfaceComposer interface 192921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 193921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual sp<ISurfaceComposerClient> createConnection(); 194921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual sp<IGraphicBufferAlloc> createGraphicBufferAlloc(); 195dd3cb84cfbe8068790c6233b5829fae9c4a0ee93Jamie Gennis virtual sp<IBinder> createDisplay(const String8& displayName, bool secure); 1966c913be9ca95fd6b556d056e165a4ba6dc69795bJesse Hall virtual void destroyDisplay(const sp<IBinder>& display); 197e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian virtual sp<IBinder> getBuiltInDisplay(int32_t id); 198921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual void setTransactionState(const Vector<ComposerState>& state, 1998b33f032327f8de0dcc0e6d0d43ed80f834b51f6Mathias Agopian const Vector<DisplayState>& displays, uint32_t flags); 20092a979a92c34b7de609ce2b1662c73bb8a2728b9Mathias Agopian virtual void bootFinished(); 201921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual bool authenticateSurfaceTexture( 2022adaf04fab35cf47c824d74d901b54094e01ccd3Andy McFadden const sp<IGraphicBufferProducer>& bufferProducer) const; 203069b365163470d2736eb6f591c354d208b5da23bBrian Anderson virtual status_t getSupportedFrameTimestamps( 2043890c3995c4a52439844faeb80b5503d42b977d8Brian Anderson std::vector<FrameEvent>* outSupported) const; 205921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual sp<IDisplayEventConnection> createDisplayEventConnection(); 2062a9fc493dfdba67108e4335bb1fe931bc1e2a025Mathias Agopian virtual status_t captureScreen(const sp<IBinder>& display, 2072a9fc493dfdba67108e4335bb1fe931bc1e2a025Mathias Agopian const sp<IGraphicBufferProducer>& producer, 208c18790018be5d7ea7061ccbc81f3044e74adc823Dan Stoza Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight, 209ae0608381b2b4699218febd6d45ad9d307544d55Robert Carr int32_t minLayerZ, int32_t maxLayerZ, 210c3ebe66b49cfba035e1fd0e160a13db38eb81b0eRiley Andrews bool useIdentityTransform, ISurfaceComposer::Rotation rotation); 21167d8bd66aaf04805cb8f2616ba964141b865e3b9Lajos Molnar virtual status_t getDisplayStats(const sp<IBinder>& display, 21267d8bd66aaf04805cb8f2616ba964141b865e3b9Lajos Molnar DisplayStatInfo* stats); 2137f7da32569f8e0b3d383a40b95f8ac1d55afd801Dan Stoza virtual status_t getDisplayConfigs(const sp<IBinder>& display, 2147f7da32569f8e0b3d383a40b95f8ac1d55afd801Dan Stoza Vector<DisplayInfo>* configs); 2157f7da32569f8e0b3d383a40b95f8ac1d55afd801Dan Stoza virtual int getActiveConfig(const sp<IBinder>& display); 21628f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright virtual status_t getDisplayColorModes(const sp<IBinder>& display, 21728f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright Vector<android_color_mode_t>* configs); 21828f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright virtual android_color_mode_t getActiveColorMode(const sp<IBinder>& display); 21928f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright virtual status_t setActiveColorMode(const sp<IBinder>& display, android_color_mode_t colorMode); 2202c9b11f0291210c9b9513a1a0cce6afebd361b3bPrashant Malani virtual void setPowerMode(const sp<IBinder>& display, int mode); 2217f7da32569f8e0b3d383a40b95f8ac1d55afd801Dan Stoza virtual status_t setActiveConfig(const sp<IBinder>& display, int id); 222d85084b2b65828442eafaff9b811e9b6c9ca9fadSvetoslav virtual status_t clearAnimationFrameStats(); 223d85084b2b65828442eafaff9b811e9b6c9ca9fadSvetoslav virtual status_t getAnimationFrameStats(FrameStats* outStats) const; 224c4f471e75a8ec64ec34e3f2944a5a756215d0becDan Stoza virtual status_t getHdrCapabilities(const sp<IBinder>& display, 225c4f471e75a8ec64ec34e3f2944a5a756215d0becDan Stoza HdrCapabilities* outCapabilities) const; 226c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju virtual status_t enableVSyncInjections(bool enable); 227c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju virtual status_t injectVSync(nsecs_t when); 228c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju 2291b03149f3533db04e72e088d3fdd09d0087ca594Mathias Agopian 230921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 231921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * DeathRecipient interface 232921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 233921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual void binderDied(const wp<IBinder>& who); 23499ce5cdeb383216dee95af4d90e47406b0948ea1Mathias Agopian 235921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 2364f4f0943489d9113c66ac22b58cfba8c21dfa879Mathias Agopian * RefBase interface 237921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 238921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian virtual void onFirstRef(); 239921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 240921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 2418630320433bd15aca239522e54e711ef6372ab07Mathias Agopian * HWComposer::EventHandler interface 2428630320433bd15aca239522e54e711ef6372ab07Mathias Agopian */ 2433ee454a7bef8bd3d1c9cdd9d17108eb80ebadf2aMathias Agopian virtual void onVSyncReceived(int type, nsecs_t timestamp); 244148994e5f33ce240ff24ceb5bc0500b7f2001959Mathias Agopian virtual void onHotplugReceived(int disp, bool connected); 2458630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 2468630320433bd15aca239522e54e711ef6372ab07Mathias Agopian /* ------------------------------------------------------------------------ 247921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Message handling 248921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 249921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void waitForEvent(); 250921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void signalTransaction(); 251921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void signalLayerUpdate(); 252921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void signalRefresh(); 253921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 25413a082e160c2d1d8006b93a555a57035213d568bAndy McFadden // called on the main thread in response to initializeDisplays() 25513a082e160c2d1d8006b93a555a57035213d568bAndy McFadden void onInitializeDisplays(); 2566c9e34a98a63033b80bd1c24c7aa1304f912f10aMichael Lentine // called on the main thread in response to setActiveConfig() 2576c9e34a98a63033b80bd1c24c7aa1304f912f10aMichael Lentine void setActiveConfigInternal(const sp<DisplayDevice>& hw, int mode); 2582c9b11f0291210c9b9513a1a0cce6afebd361b3bPrashant Malani // called on the main thread in response to setPowerMode() 2592c9b11f0291210c9b9513a1a0cce6afebd361b3bPrashant Malani void setPowerModeInternal(const sp<DisplayDevice>& hw, int mode); 260921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 26128f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright // Called on the main thread in response to setActiveColorMode() 26228f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright void setActiveColorModeInternal(const sp<DisplayDevice>& hw, android_color_mode_t colorMode); 26328f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright 2646b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza // Returns whether the transaction actually modified any state 2656b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza bool handleMessageTransaction(); 2666b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza 2676b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza // Returns whether a new buffer has been latched (see handlePageFlip()) 2686b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza bool handleMessageInvalidate(); 2696b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza 270921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void handleMessageRefresh(); 271921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 27287baae104a3e4c2059990b01c393476065c558b0Mathias Agopian void handleTransaction(uint32_t transactionFlags); 27387baae104a3e4c2059990b01c393476065c558b0Mathias Agopian void handleTransactionLocked(uint32_t transactionFlags); 274921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 27503414a1cfe6c1222fd7723949bd622f9cba145aaRiley Andrews void updateCursorAsync(); 27603414a1cfe6c1222fd7723949bd622f9cba145aaRiley Andrews 2776b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza /* handlePageFlip - latch a new buffer if available and compute the dirty 2786b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza * region. Returns whether a new buffer has been latched, i.e., whether it 2796b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza * is necessary to perform a refresh during this vsync. 280921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 2816b9454d1fee0347711af1746642aa7820b1ea04dDan Stoza bool handlePageFlip(); 282921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 283921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 284921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Transactions 285921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 286921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian uint32_t getTransactionFlags(uint32_t flags); 287c8251eb7a6ecfdd16b3e4cfbfb442aa4c789c039Fabien Sanglard uint32_t peekTransactionFlags(); 288921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian uint32_t setTransactionFlags(uint32_t flags); 289921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void commitTransaction(); 2903f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian uint32_t setClientStateLocked(const sp<Client>& client, const layer_state_t& s); 291e57f292595bec48f65c8088b00ff6beea01217e9Mathias Agopian uint32_t setDisplayStateLocked(const DisplayState& s); 292921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 293921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 294921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Layer management 295921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 2964d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian status_t createLayer(const String8& name, const sp<Client>& client, 2974d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian uint32_t w, uint32_t h, PixelFormat format, uint32_t flags, 2984d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian sp<IBinder>* handle, sp<IGraphicBufferProducer>* gbp); 2994d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian 3004d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian status_t createNormalLayer(const sp<Client>& client, const String8& name, 3014d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian uint32_t w, uint32_t h, uint32_t flags, PixelFormat& format, 3024d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian sp<IBinder>* outHandle, sp<IGraphicBufferProducer>* outGbp, 3034d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian sp<Layer>* outLayer); 3044d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian 3054d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian status_t createDimLayer(const sp<Client>& client, const String8& name, 3064d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian uint32_t w, uint32_t h, uint32_t flags, sp<IBinder>* outHandle, 3074d9b822e2c18142e55fe2611aa6cd7dc7d4a62c6Mathias Agopian sp<IGraphicBufferProducer>* outGbp, sp<Layer>* outLayer); 308921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 309921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // called in response to the window-manager calling 310921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // ISurfaceComposerClient::destroySurface() 311ac9fa427d4a86745e60a5f7fd8e3ea340c4db907Mathias Agopian status_t onLayerRemoved(const sp<Client>& client, const sp<IBinder>& handle); 312921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 313921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // called when all clients have released all their references to 314921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // this layer meaning it is entirely safe to destroy all 315921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // resources associated to this layer. 31613127d8921356dff794250e04208c3ed60b3a3dfMathias Agopian status_t onLayerDestroyed(const wp<Layer>& layer); 317921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 318921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // remove a layer from SurfaceFlinger immediately 31922851c3ba2cf5ccb0c3a0aa6c5b94ae123a5616aDan Stoza status_t removeLayer(const wp<Layer>& layer); 320edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 321921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // add a layer to SurfaceFlinger 3227d89d06a6fe1bfadfe277f19dbb7e4aa021444e0Dan Stoza status_t addClientLayer(const sp<Client>& client, 3236710604286401d4205c27235a252dd0e5008cc08Mathias Agopian const sp<IBinder>& handle, 3246710604286401d4205c27235a252dd0e5008cc08Mathias Agopian const sp<IGraphicBufferProducer>& gbc, 3256710604286401d4205c27235a252dd0e5008cc08Mathias Agopian const sp<Layer>& lbc); 326921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 327921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 328921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Boot animation, on/off animations and screen capture 329921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 330921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 331921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void startBootAnim(); 332921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 333180f10de6f504d2ba56ff32ae8ed53c58bb458e9Mathias Agopian void renderScreenImplLocked( 334180f10de6f504d2ba56ff32ae8ed53c58bb458e9Mathias Agopian const sp<const DisplayDevice>& hw, 335c18790018be5d7ea7061ccbc81f3044e74adc823Dan Stoza Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight, 336ae0608381b2b4699218febd6d45ad9d307544d55Robert Carr int32_t minLayerZ, int32_t maxLayerZ, 337c3ebe66b49cfba035e1fd0e160a13db38eb81b0eRiley Andrews bool yswap, bool useIdentityTransform, Transform::orientation_flags rotation); 338180f10de6f504d2ba56ff32ae8ed53c58bb458e9Mathias Agopian 3392a9fc493dfdba67108e4335bb1fe931bc1e2a025Mathias Agopian status_t captureScreenImplLocked( 3402a9fc493dfdba67108e4335bb1fe931bc1e2a025Mathias Agopian const sp<const DisplayDevice>& hw, 341abe815dd6978b718c04f6e22e1a893d2b51d11a1Mathias Agopian const sp<IGraphicBufferProducer>& producer, 342c18790018be5d7ea7061ccbc81f3044e74adc823Dan Stoza Rect sourceCrop, uint32_t reqWidth, uint32_t reqHeight, 343ae0608381b2b4699218febd6d45ad9d307544d55Robert Carr int32_t minLayerZ, int32_t maxLayerZ, 344b5b3563058c178811d434ab6e8c4ead4a519701bPablo Ceballos bool useIdentityTransform, Transform::orientation_flags rotation, 345b5b3563058c178811d434ab6e8c4ead4a519701bPablo Ceballos bool isLocalScreenshot); 346abe815dd6978b718c04f6e22e1a893d2b51d11a1Mathias Agopian 347921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 348921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * EGL 349921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 350875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian size_t getMaxTextureSize() const; 351875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian size_t getMaxViewportDims() const; 352921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 353921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 35487baae104a3e4c2059990b01c393476065c558b0Mathias Agopian * Display and layer stack management 355921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 35613a082e160c2d1d8006b93a555a57035213d568bAndy McFadden // called when starting, or restarting after system_server death 35713a082e160c2d1d8006b93a555a57035213d568bAndy McFadden void initializeDisplays(); 35813a082e160c2d1d8006b93a555a57035213d568bAndy McFadden 359692c723e84e6f2747447d871d468ff50e5c73f19Jesse Hall // Create an IBinder for a builtin display and add it to current state 360692c723e84e6f2747447d871d468ff50e5c73f19Jesse Hall void createBuiltinDisplayLocked(DisplayDevice::DisplayType type); 361692c723e84e6f2747447d871d468ff50e5c73f19Jesse Hall 362db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian // NOTE: can only be called from the main thread or with mStateLock held 3633ee454a7bef8bd3d1c9cdd9d17108eb80ebadf2aMathias Agopian sp<const DisplayDevice> getDisplayDevice(const wp<IBinder>& dpy) const { 36492a979a92c34b7de609ce2b1662c73bb8a2728b9Mathias Agopian return mDisplays.valueFor(dpy); 36592a979a92c34b7de609ce2b1662c73bb8a2728b9Mathias Agopian } 366db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian 367db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian // NOTE: can only be called from the main thread or with mStateLock held 368db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian sp<DisplayDevice> getDisplayDevice(const wp<IBinder>& dpy) { 3694297734c1156fd8ede7e9c61b1e439f9e1c18cd9Mathias Agopian return mDisplays.valueFor(dpy); 370921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian } 371921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 37228f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright int32_t getDisplayType(const sp<IBinder>& display) { 37328f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright if (!display.get()) return NAME_NOT_FOUND; 37428f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright for (int i = 0; i < DisplayDevice::NUM_BUILTIN_DISPLAY_TYPES; ++i) { 37528f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright if (display == mBuiltinDisplays[i]) { 37628f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright return i; 37728f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright } 37828f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright } 37928f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright return NAME_NOT_FOUND; 38028f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright } 38128f24d0ab481bd9c6fd5618414fee694e837c5c6Michael Wright 38287baae104a3e4c2059990b01c393476065c558b0Mathias Agopian // mark a region of a layer stack dirty. this updates the dirty 38387baae104a3e4c2059990b01c393476065c558b0Mathias Agopian // region of all screens presenting this layer stack. 38487baae104a3e4c2059990b01c393476065c558b0Mathias Agopian void invalidateLayerStack(uint32_t layerStack, const Region& dirty); 38587baae104a3e4c2059990b01c393476065c558b0Mathias Agopian 3869d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifndef USE_HWC2 3879d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard int32_t allocateHwcDisplayId(DisplayDevice::DisplayType type); 3889d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 3899d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard 390921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 3918630320433bd15aca239522e54e711ef6372ab07Mathias Agopian * H/W composer 3928630320433bd15aca239522e54e711ef6372ab07Mathias Agopian */ 3938630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 3948630320433bd15aca239522e54e711ef6372ab07Mathias Agopian HWComposer& getHwComposer() const { return *mHwc; } 3958630320433bd15aca239522e54e711ef6372ab07Mathias Agopian 396888c822c4cb6976aab9256c58bae9e17e3e55c5cMathias Agopian /* ------------------------------------------------------------------------ 397921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Compositing 398921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 399921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void invalidateHwcGeometry(); 400ce3a0a541c3dde1330551bd7a048cd9d92335c00Mathias Agopian static void computeVisibleRegions( 401ce3a0a541c3dde1330551bd7a048cd9d92335c00Mathias Agopian const LayerVector& currentLayers, uint32_t layerStack, 40287baae104a3e4c2059990b01c393476065c558b0Mathias Agopian Region& dirtyRegion, Region& opaqueRegion); 403cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian 404d6927fb1143398370c0885844bfb58923ef740b7Brian Anderson void preComposition(nsecs_t refreshStartTime); 405d6927fb1143398370c0885844bfb58923ef740b7Brian Anderson void postComposition(); 406cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian void rebuildLayerStacks(); 407cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian void setUpHWComposer(); 408cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian void doComposition(); 409cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian void doDebugFlashRegions(); 410830b84704b0f33030d0e391a0ea2e7faa5646e2eFabien Sanglard void doDisplayComposition(const sp<const DisplayDevice>& displayDevice, const Region& dirtyRegion); 4113f121fc650d72d0103cef8e6a651093fb1589e0aMichael Lentine 4123f121fc650d72d0103cef8e6a651093fb1589e0aMichael Lentine // compose surfaces for display hw. this fails if using GL and the surface 4133f121fc650d72d0103cef8e6a651093fb1589e0aMichael Lentine // has been destroyed and is no longer valid. 414830b84704b0f33030d0e391a0ea2e7faa5646e2eFabien Sanglard bool doComposeSurfaces(const sp<const DisplayDevice>& displayDevice, const Region& dirty); 415cd60f99aba9e750700a967db30b74a29145739cfMathias Agopian 416921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian void postFramebuffer(); 417830b84704b0f33030d0e391a0ea2e7faa5646e2eFabien Sanglard void drawWormhole(const sp<const DisplayDevice>& displayDevice, const Region& region) const; 418921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 419921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 4200bceb84773882b796d9dacbaf96167cb15928d78Jamie Gennis * Display management 4210bceb84773882b796d9dacbaf96167cb15928d78Jamie Gennis */ 4223ee454a7bef8bd3d1c9cdd9d17108eb80ebadf2aMathias Agopian 423faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis /* ------------------------------------------------------------------------ 424faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis * VSync 425faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis */ 426faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis void enableHardwareVsync(); 42767264e930992e43ef3351b04692d4ca59cbb01adDan Stoza void resyncToHardwareVsync(bool makeAvailable); 4284a4e4a239f034cb8af2df9a438b26c3bc088889cTim Murray void disableHardwareVsync(bool makeUnavailable); 4294a4e4a239f034cb8af2df9a438b26c3bc088889cTim Murraypublic: 4304a4e4a239f034cb8af2df9a438b26c3bc088889cTim Murray void resyncWithRateLimit(); 4314a4e4a239f034cb8af2df9a438b26c3bc088889cTim Murrayprivate: 4320bceb84773882b796d9dacbaf96167cb15928d78Jamie Gennis 4330bceb84773882b796d9dacbaf96167cb15928d78Jamie Gennis /* ------------------------------------------------------------------------ 434921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Debugging & dumpsys 435921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 4363f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void listLayersLocked(const Vector<String16>& args, size_t& index, String8& result) const; 4373f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void dumpStatsLocked(const Vector<String16>& args, size_t& index, String8& result) const; 4383f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void clearStatsLocked(const Vector<String16>& args, size_t& index, String8& result); 4393f84483382be2d528918cc1a6fbc6a7d68e0b181Mathias Agopian void dumpAllLocked(const Vector<String16>& args, size_t& index, String8& result) const; 44063f165fd6b86d04be94d4023e845e98560504a96Keun young Park bool startDdmConnection(); 44163a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard void appendSfConfigString(String8& result) const; 442d555684cb36dfb959694db76962e570184f98838Mathias Agopian void checkScreenshot(size_t w, size_t s, size_t h, void const* vaddr, 443fee2b463c5fbe8fa0132d03634ccc02ea55c1505Mathias Agopian const sp<const DisplayDevice>& hw, 444ae0608381b2b4699218febd6d45ad9d307544d55Robert Carr int32_t minLayerZ, int32_t maxLayerZ); 445921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 4466547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis void logFrameStats(); 4476547ff4327aa320fbc9635668d3fc66db7dd78f6Jamie Gennis 448b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza void dumpStaticScreenStats(String8& result) const; 449d6927fb1143398370c0885844bfb58923ef740b7Brian Anderson // Not const because each Layer needs to query Fences and cache timestamps. 450d6927fb1143398370c0885844bfb58923ef740b7Brian Anderson void dumpFrameEventsLocked(String8& result); 451b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza 452e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza void recordBufferingStats(const char* layerName, 453e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza std::vector<OccupancyTracker::Segment>&& history); 454e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza void dumpBufferingStats(String8& result) const; 455e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 45663a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard bool isLayerTripleBufferingDisabled() const { 45763a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard return this->mLayerTripleBufferingDisabled; 45863a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard } 459921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 460921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Attributes 461921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 462921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 463921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // access must be protected by mStateLock 464921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian mutable Mutex mStateLock; 465921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian State mCurrentState; 466921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian volatile int32_t mTransactionFlags; 467921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian Condition mTransactionCV; 4682d5e230292c27d59f4c096bc742a0a19abf811c1Jamie Gennis bool mTransactionPending; 4692d5e230292c27d59f4c096bc742a0a19abf811c1Jamie Gennis bool mAnimTransactionPending; 47013127d8921356dff794250e04208c3ed60b3a3dfMathias Agopian Vector< sp<Layer> > mLayersPendingRemoval; 4716710604286401d4205c27235a252dd0e5008cc08Mathias Agopian SortedVector< wp<IBinder> > mGraphicBufferProducerList; 472921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 473921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // protected by mStateLock (but we could use another lock) 474921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian bool mLayersRemoved; 475921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 476921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // access must be protected by mInvalidateLock 47787baae104a3e4c2059990b01c393476065c558b0Mathias Agopian volatile int32_t mRepaintEverything; 478921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 479921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // constant members (no synchronization needed for access) 4808630320433bd15aca239522e54e711ef6372ab07Mathias Agopian HWComposer* mHwc; 481875d8e1323536e16dcfc90c9674d7ad32116a69aMathias Agopian RenderEngine* mRenderEngine; 482921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian nsecs_t mBootTime; 483b4b1730abb7824dc084468c4942f010d94a7e039Mathias Agopian bool mGpuToCpuSupported; 484921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian sp<EventThread> mEventThread; 4850a645cc5a935e67a8d1effc7679a838160b971d8Jamie Gennis sp<EventThread> mSFEventThread; 486c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju sp<EventThread> mInjectorEventThread; 487c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju sp<InjectVSyncSource> mVSyncInjector; 488d1700756ec9520c3fba22f9a14fd064a6e288810Jamie Gennis sp<EventControlThread> mEventControlThread; 489921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian EGLContext mEGLContext; 49034a09ba1efd706323a15633da5044b352988eb5fJesse Hall EGLDisplay mEGLDisplay; 4919e663de4fe1dcc872373ee530c60a375624671c3Jesse Hall sp<IBinder> mBuiltinDisplays[DisplayDevice::NUM_BUILTIN_DISPLAY_TYPES]; 492921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 493921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // Can only accessed from the main thread, these members 494921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // don't need synchronization 495921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian State mDrawingState; 496921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian bool mVisibleRegionsDirty; 4979d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifndef USE_HWC2 4989d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard bool mHwWorkListDirty; 4999d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#else 5009e56aa0fdb5f7121b9b975c6c16db103ea4d2fe9Dan Stoza bool mGeometryInvalid; 5019d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 5024b0eba949cc026ffb2c75313042d8a7bcb3fcf86Jamie Gennis bool mAnimCompositionPending; 5039d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifdef USE_HWC2 5049e56aa0fdb5f7121b9b975c6c16db103ea4d2fe9Dan Stoza std::vector<sp<Layer>> mLayersWithQueuedFrames; 50505dacfb68af895fce3cc8ebb0b4aa06c6c336e26Dan Stoza sp<Fence> mPreviousPresentFence = Fence::NO_FENCE; 50605dacfb68af895fce3cc8ebb0b4aa06c6c336e26Dan Stoza bool mHadClientComposition = false; 5079d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 5083d4039d7a291cd9b6f2dd4b46fcdb576f2db3356Brian Anderson FenceTimeline mGlCompositionDoneTimeline; 5093d4039d7a291cd9b6f2dd4b46fcdb576f2db3356Brian Anderson FenceTimeline mDisplayTimeline; 510db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian 511db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian // this may only be written from the main thread with mStateLock held 512db9b41fd157279d1b988a854e0d7c5b43c2fac38Mathias Agopian // it may be read from other threads with mStateLock held 5133ee454a7bef8bd3d1c9cdd9d17108eb80ebadf2aMathias Agopian DefaultKeyedVector< wp<IBinder>, sp<DisplayDevice> > mDisplays; 514921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 515921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // don't use a lock for these, we don't care 516921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian int mDebugRegion; 517921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian int mDebugDDMS; 518921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian int mDebugDisableHWC; 519921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian int mDebugDisableTransformHint; 520921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian volatile nsecs_t mDebugInSwapBuffers; 521921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian nsecs_t mLastSwapBufferTime; 522921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian volatile nsecs_t mDebugInTransaction; 523921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian nsecs_t mLastTransactionTime; 524921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian bool mBootFinished; 525ee44edd0acccbf5eaa918d75737c3b65ee04fff7Dan Stoza bool mForceFullDamage; 5269d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifdef USE_HWC2 527c5da271eec001da9e11a2786f2618a45257439c3Dan Stoza bool mPropagateBackpressure = true; 5289d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 529468051e20be19130572231266db306396a56402bIrvel SurfaceInterceptor mInterceptor; 5308cf150a0341768133b37cd9c6f2369bf6f79a943Dan Stoza bool mUseHwcVirtualDisplays = true; 531921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 53263a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard // Restrict layers to use two buffers in their bufferqueues. 53363a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard bool mLayerTripleBufferingDisabled = false; 53463a5fcd2aa55c8eb0ccba621517a4215d8504df6Fabien Sanglard 535921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // these are thread safe 536921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian mutable MessageQueue mEventQueue; 5374b0eba949cc026ffb2c75313042d8a7bcb3fcf86Jamie Gennis FrameTracker mAnimFrameTracker; 538faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis DispSync mPrimaryDispSync; 539921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 540921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian // protected by mDestroyedLayerLock; 541921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian mutable Mutex mDestroyedLayerLock; 54213127d8921356dff794250e04208c3ed60b3a3dfMathias Agopian Vector<Layer const *> mDestroyedLayers; 543921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 544faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis // protected by mHWVsyncLock 545faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis Mutex mHWVsyncLock; 546faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis bool mPrimaryHWVsyncEnabled; 547948fe0ce74c13e1bbff233883c158519fa8fb293Jesse Hall bool mHWVsyncAvailable; 548faf77cce9d9ec0238d6999b3bd0d40c71ff403c5Jamie Gennis 549921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian /* ------------------------------------------------------------------------ 550921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian * Feature prototyping 551921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian */ 552921e6ac4b7610a178285898d191eb0e3afe906c0Mathias Agopian 553c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju bool mInjectVSyncs; 554c1ba5c4649554e744844b07cfe402b42fbe12ff3Sahil Dhanju 555ff2ed70fa30f04b90dd1a2c06ec2319e157152d7Mathias Agopian Daltonizer mDaltonizer; 5569d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#ifndef USE_HWC2 5579d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard bool mDaltonize; 5589d96de49673cb6c916bfb797aad4f4e024ea73caFabien Sanglard#endif 5599c5a3335110769993d3fe997bdf1d594954d4304Alan Viverette 5609f26a9c8be6f00f55cbc30b93adf4895c6a093aaDan Stoza mat4 mPreviousColorMatrix; 5619c5a3335110769993d3fe997bdf1d594954d4304Alan Viverette mat4 mColorMatrix; 5629c5a3335110769993d3fe997bdf1d594954d4304Alan Viverette bool mHasColorMatrix; 563b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza 564b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza // Static screen stats 565b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza bool mHasPoweredOff; 566b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza static const size_t NUM_BUCKETS = 8; // < 1-7, 7+ 567b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza nsecs_t mFrameBuckets[NUM_BUCKETS]; 568b90cf07f8b3a8fe76e40b997924c2509d04575f4Dan Stoza nsecs_t mTotalTime; 5694a4e4a239f034cb8af2df9a438b26c3bc088889cTim Murray std::atomic<nsecs_t> mLastSwapTime; 570e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 571e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // Double- vs. triple-buffering stats 572e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza struct BufferingStats { 573e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza BufferingStats() 574e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza : numSegments(0), 575e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza totalTime(0), 576e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza twoBufferTime(0), 577e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza doubleBufferedTime(0), 578e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza tripleBufferedTime(0) {} 579e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 580e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza size_t numSegments; 581e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza nsecs_t totalTime; 582e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza 583e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // "Two buffer" means that a third buffer was never used, whereas 584e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // "double-buffered" means that on average the segment only used two 585e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // buffers (though it may have used a third for some part of the 586e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza // segment) 587e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza nsecs_t twoBufferTime; 588e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza nsecs_t doubleBufferedTime; 589e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza nsecs_t tripleBufferedTime; 590e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza }; 591e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza mutable Mutex mBufferingStatsMutex; 592e77c7669bee30b7c0099172cf0c38cef92412040Dan Stoza std::unordered_map<std::string, BufferingStats> mBufferingStats; 5936e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard 5946e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard // Verify that transaction is being called by an approved process: 5956e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard // either AID_GRAPHICS or AID_SYSTEM. 5966e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard status_t CheckTransactCodeCredentials(uint32_t code); 5976e8e98a23592c2522396b673145814a4bbee69dbFabien Sanglard }; 598edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 599edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project}; // namespace android 600edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project 601edbf3b6af777b721cd2a1ef461947e51e88241e1The Android Open Source Project#endif // ANDROID_SURFACE_FLINGER_H 602