diff options
Diffstat (limited to 'libs/gui/include/gui/DisplayEventDispatcher.h')
-rw-r--r-- | libs/gui/include/gui/DisplayEventDispatcher.h | 37 |
1 files changed, 7 insertions, 30 deletions
diff --git a/libs/gui/include/gui/DisplayEventDispatcher.h b/libs/gui/include/gui/DisplayEventDispatcher.h index 4ade240dcf..f210c34196 100644 --- a/libs/gui/include/gui/DisplayEventDispatcher.h +++ b/libs/gui/include/gui/DisplayEventDispatcher.h @@ -19,33 +19,19 @@ #include <utils/Looper.h> namespace android { -using FrameRateOverride = DisplayEventReceiver::Event::FrameRateOverride; - -struct VsyncEventData { - // The Vsync Id corresponsing to this vsync event. This will be used to - // populate ISurfaceComposer::setFrameTimelineVsync and - // SurfaceComposerClient::setFrameTimelineVsync - int64_t id = FrameTimelineInfo::INVALID_VSYNC_ID; - - // The deadline in CLOCK_MONOTONIC that the app needs to complete its - // frame by (both on the CPU and the GPU) - int64_t deadlineTimestamp = std::numeric_limits<int64_t>::max(); - - // The current frame interval in ns when this frame was scheduled. - int64_t frameInterval = 0; -}; class DisplayEventDispatcher : public LooperCallback { public: explicit DisplayEventDispatcher( const sp<Looper>& looper, ISurfaceComposer::VsyncSource vsyncSource = ISurfaceComposer::eVsyncSourceApp, - ISurfaceComposer::EventRegistrationFlags eventRegistration = {}); + ISurfaceComposer::ConfigChanged configChanged = + ISurfaceComposer::eConfigChangedSuppress); status_t initialize(); void dispose(); status_t scheduleVsync(); - void injectEvent(const DisplayEventReceiver::Event& event); + void requestLatestConfig(); int getFd() const; virtual int handleEvent(int receiveFd, int events, void* data); @@ -57,22 +43,13 @@ private: DisplayEventReceiver mReceiver; bool mWaitingForVsync; - std::vector<FrameRateOverride> mFrameRateOverrides; - - virtual void dispatchVsync(nsecs_t timestamp, PhysicalDisplayId displayId, uint32_t count, - VsyncEventData vsyncEventData) = 0; + virtual void dispatchVsync(nsecs_t timestamp, PhysicalDisplayId displayId, uint32_t count) = 0; virtual void dispatchHotplug(nsecs_t timestamp, PhysicalDisplayId displayId, bool connected) = 0; - virtual void dispatchModeChanged(nsecs_t timestamp, PhysicalDisplayId displayId, int32_t modeId, - nsecs_t vsyncPeriod) = 0; - // AChoreographer-specific hook for processing null-events so that looper - // can be properly poked. - virtual void dispatchNullEvent(nsecs_t timestamp, PhysicalDisplayId displayId) = 0; - - virtual void dispatchFrameRateOverrides(nsecs_t timestamp, PhysicalDisplayId displayId, - std::vector<FrameRateOverride> overrides) = 0; + virtual void dispatchConfigChanged(nsecs_t timestamp, PhysicalDisplayId displayId, + int32_t configId, nsecs_t vsyncPeriod) = 0; bool processPendingEvents(nsecs_t* outTimestamp, PhysicalDisplayId* outDisplayId, - uint32_t* outCount, VsyncEventData* outVsyncEventData); + uint32_t* outCount); }; } // namespace android |