From c434ac82b57108bd08f58612f6ac8cbc92dbd975 Mon Sep 17 00:00:00 2001 From: Marco Nelissen Date: Wed, 25 Apr 2012 14:14:55 -0700 Subject: Add option to stagefright for writing decoded PCM b/774846 Change-Id: I8edce3e7d60b3f56b4eb1ed75ca80285c5ae3972 --- cmds/stagefright/stagefright.cpp | 26 +++++++++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) (limited to 'cmds') diff --git a/cmds/stagefright/stagefright.cpp b/cmds/stagefright/stagefright.cpp index 3656fe3..7087a81 100644 --- a/cmds/stagefright/stagefright.cpp +++ b/cmds/stagefright/stagefright.cpp @@ -608,6 +608,7 @@ static void usage(const char *me) { fprintf(stderr, " -S allocate buffers from a surface\n"); fprintf(stderr, " -T allocate buffers from a surface texture\n"); fprintf(stderr, " -d(ump) filename (raw stream data to a file)\n"); + fprintf(stderr, " -D(ump) filename (decoded PCM data to a file)\n"); } static void dumpCodecProfiles(const sp& omx, bool queryDecoders) { @@ -668,6 +669,7 @@ int main(int argc, char **argv) { bool useSurfaceAlloc = false; bool useSurfaceTexAlloc = false; bool dumpStream = false; + bool dumpPCMStream = false; String8 dumpStreamFilename; gNumRepetitions = 1; gMaxNumFrames = 0; @@ -682,7 +684,7 @@ int main(int argc, char **argv) { sp liveSession; int res; - while ((res = getopt(argc, argv, "han:lm:b:ptsrow:kxSTd:")) >= 0) { + while ((res = getopt(argc, argv, "han:lm:b:ptsrow:kxSTd:D:")) >= 0) { switch (res) { case 'a': { @@ -697,6 +699,14 @@ int main(int argc, char **argv) { break; } + case 'D': + { + dumpPCMStream = true; + audioOnly = true; + dumpStreamFilename.setTo(optarg); + break; + } + case 'l': { listComponents = true; @@ -1103,6 +1113,20 @@ int main(int argc, char **argv) { writeSourcesToMP4(mediaSources, syncInfoPresent); } else if (dumpStream) { dumpSource(mediaSource, dumpStreamFilename); + } else if (dumpPCMStream) { + OMXClient client; + CHECK_EQ(client.connect(), (status_t)OK); + + sp decSource = + OMXCodec::Create( + client.interface(), + mediaSource->getFormat(), + false, + mediaSource, + 0, + 0); + + dumpSource(decSource, dumpStreamFilename); } else if (seekTest) { performSeekTest(mediaSource); } else { -- cgit v1.1