summaryrefslogtreecommitdiff
path: root/libs/gui/include/gui/DisplayEventDispatcher.h
diff options
context:
space:
mode:
Diffstat (limited to 'libs/gui/include/gui/DisplayEventDispatcher.h')
-rw-r--r--libs/gui/include/gui/DisplayEventDispatcher.h37
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