diff options
author | Praveen Chavan <pchavan@codeaurora.org> | 2015-05-19 19:09:48 -0700 |
---|---|---|
committer | Lajos Molnar <lajos@google.com> | 2015-06-10 16:48:59 -0700 |
commit | e1e5d7a3d3d4d6d644e6c731f977422e004140d5 (patch) | |
tree | 687a0b028303a6560b09701e1a7689fd9291fa9b /media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp | |
parent | 4a4265e9fc4e72d069eb2de37c8484d67fd3a9fc (diff) | |
download | frameworks_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.cpp | 44 |
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; |