summaryrefslogtreecommitdiffstats
path: root/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
diff options
context:
space:
mode:
authorPraveen Chavan <pchavan@codeaurora.org>2015-05-19 19:09:48 -0700
committerLajos Molnar <lajos@google.com>2015-06-10 16:48:59 -0700
commite1e5d7a3d3d4d6d644e6c731f977422e004140d5 (patch)
tree687a0b028303a6560b09701e1a7689fd9291fa9b /media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
parent4a4265e9fc4e72d069eb2de37c8484d67fd3a9fc (diff)
downloadframeworks_av-e1e5d7a3d3d4d6d644e6c731f977422e004140d5.zip
frameworks_av-e1e5d7a3d3d4d6d644e6c731f977422e004140d5.tar.gz
frameworks_av-e1e5d7a3d3d4d6d644e6c731f977422e004140d5.tar.bz2
NuPlayer: Enhance dumpsys statistics
Account for dropped output-frames (rather than input-frames) in percentage dropped frames. Print mime and component name for each active track Change-Id: I3491d336c696d8ed0fd1503b80afe1df47c787c8
Diffstat (limited to 'media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp')
-rw-r--r--media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp44
1 files changed, 35 insertions, 9 deletions
diff --git a/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp b/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
index 84ae25e..6a38e68 100644
--- a/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
+++ b/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
@@ -652,20 +652,46 @@ void NuPlayerDriver::notifySeekComplete_l() {
status_t NuPlayerDriver::dump(
int fd, const Vector<String16> & /* args */) const {
- int64_t numFramesTotal;
- int64_t numFramesDropped;
- mPlayer->getStats(&numFramesTotal, &numFramesDropped);
+
+ Vector<sp<AMessage> > trackStats;
+ mPlayer->getStats(&trackStats);
FILE *out = fdopen(dup(fd), "w");
fprintf(out, " NuPlayer\n");
- fprintf(out, " numFramesTotal(%" PRId64 "), numFramesDropped(%" PRId64 "), "
- "percentageDropped(%.2f)\n",
- numFramesTotal,
- numFramesDropped,
- numFramesTotal == 0
- ? 0.0 : (double)numFramesDropped / numFramesTotal);
+ for (size_t i = 0; i < trackStats.size(); ++i) {
+ const sp<AMessage> &stats = trackStats.itemAt(i);
+
+ AString mime;
+ if (stats->findString("mime", &mime)) {
+ fprintf(out, " mime(%s)\n", mime.c_str());
+ }
+
+ AString name;
+ if (stats->findString("component-name", &name)) {
+ fprintf(out, " decoder(%s)\n", name.c_str());
+ }
+ if (mime.startsWith("video/")) {
+ int32_t width, height;
+ if (stats->findInt32("width", &width)
+ && stats->findInt32("height", &height)) {
+ fprintf(out, " resolution(%d x %d)\n", width, height);
+ }
+
+ int64_t numFramesTotal = 0;
+ int64_t numFramesDropped = 0;
+
+ stats->findInt64("frames-total", &numFramesTotal);
+ stats->findInt64("frames-dropped-output", &numFramesDropped);
+ fprintf(out, " numFramesTotal(%lld), numFramesDropped(%lld), "
+ "percentageDropped(%.2f%%)\n",
+ (long long)numFramesTotal,
+ (long long)numFramesDropped,
+ numFramesTotal == 0
+ ? 0.0 : (double)(numFramesDropped * 100) / numFramesTotal);
+ }
+ }
fclose(out);
out = NULL;