surfaceflinger: add getDisplayStats() method
This is used by media service to schedule video frames at the
proper time, based on precise vsync timings.
Bug: 14659809
Change-Id: I1a90603f3dc09dca9aa4f90a3aa845fab56e0a5e
diff --git a/libs/gui/ISurfaceComposer.cpp b/libs/gui/ISurfaceComposer.cpp
index 4d65c56..81e8336 100644
--- a/libs/gui/ISurfaceComposer.cpp
+++ b/libs/gui/ISurfaceComposer.cpp
@@ -33,6 +33,7 @@
#include <private/gui/LayerState.h>
#include <ui/DisplayInfo.h>
+#include <ui/DisplayStatInfo.h>
#include <utils/Log.h>
@@ -237,6 +238,22 @@
return result;
}
+ virtual status_t getDisplayStats(const sp<IBinder>& display,
+ DisplayStatInfo* stats)
+ {
+ Parcel data, reply;
+ data.writeInterfaceToken(ISurfaceComposer::getInterfaceDescriptor());
+ data.writeStrongBinder(display);
+ remote()->transact(BnSurfaceComposer::GET_DISPLAY_STATS, data, &reply);
+ status_t result = reply.readInt32();
+ if (result == NO_ERROR) {
+ memcpy(stats,
+ reply.readInplace(sizeof(DisplayStatInfo)),
+ sizeof(DisplayStatInfo));
+ }
+ return result;
+ }
+
virtual int getActiveConfig(const sp<IBinder>& display)
{
Parcel data, reply;
@@ -390,6 +407,18 @@
}
return NO_ERROR;
}
+ case GET_DISPLAY_STATS: {
+ CHECK_INTERFACE(ISurfaceComposer, data, reply);
+ DisplayStatInfo stats;
+ sp<IBinder> display = data.readStrongBinder();
+ status_t result = getDisplayStats(display, &stats);
+ reply->writeInt32(result);
+ if (result == NO_ERROR) {
+ memcpy(reply->writeInplace(sizeof(DisplayStatInfo)),
+ &stats, sizeof(DisplayStatInfo));
+ }
+ return NO_ERROR;
+ }
case GET_ACTIVE_CONFIG: {
CHECK_INTERFACE(ISurfaceComposer, data, reply);
sp<IBinder> display = data.readStrongBinder();