diff options
author | Andreas Huber <andih@google.com> | 2010-07-20 16:30:35 -0700 |
---|---|---|
committer | Andreas Huber <andih@google.com> | 2010-07-21 10:40:07 -0700 |
commit | 66d6f1fcd9cb80a603b833e93779eb0dfb5e67ee (patch) | |
tree | c1a08d86ce22e55b33a88b7fbab8c28b2bb9ffa1 /cmds | |
parent | ef3f986ebeee48af0e8cbfa651260974bbd1ed4d (diff) | |
download | frameworks_av-66d6f1fcd9cb80a603b833e93779eb0dfb5e67ee.zip frameworks_av-66d6f1fcd9cb80a603b833e93779eb0dfb5e67ee.tar.gz frameworks_av-66d6f1fcd9cb80a603b833e93779eb0dfb5e67ee.tar.bz2 |
Add a seek test to the stagefright commandline tool.
Change-Id: Ibf3517afa288fc4c7e2184c11bc7a63594f321df
Diffstat (limited to 'cmds')
-rw-r--r-- | cmds/stagefright/stagefright.cpp | 68 |
1 files changed, 67 insertions, 1 deletions
diff --git a/cmds/stagefright/stagefright.cpp b/cmds/stagefright/stagefright.cpp index b7a3f99..f74240f 100644 --- a/cmds/stagefright/stagefright.cpp +++ b/cmds/stagefright/stagefright.cpp @@ -278,6 +278,62 @@ static void writeSourceToMP4(const sp<MediaSource> &source) { writer->stop(); } +static void performSeekTest(const sp<MediaSource> &source) { + CHECK_EQ(OK, source->start()); + + int64_t durationUs; + CHECK(source->getFormat()->findInt64(kKeyDuration, &durationUs)); + + for (int64_t seekTimeUs = 0; seekTimeUs <= durationUs; + seekTimeUs += 60000ll) { + MediaSource::ReadOptions options; + options.setSeekTo( + seekTimeUs, MediaSource::ReadOptions::SEEK_PREVIOUS_SYNC); + + MediaBuffer *buffer; + status_t err; + for (;;) { + err = source->read(&buffer, &options); + + options.clearSeekTo(); + + if (err == INFO_FORMAT_CHANGED) { + CHECK(buffer == NULL); + continue; + } + + if (err != OK) { + CHECK(buffer == NULL); + break; + } + + if (buffer->range_length() > 0) { + break; + } + + CHECK(buffer != NULL); + + buffer->release(); + buffer = NULL; + } + + if (err == OK) { + int64_t timeUs; + CHECK(buffer->meta_data()->findInt64(kKeyTime, &timeUs)); + + printf("%lld\t%lld\t%lld\n", seekTimeUs, timeUs, seekTimeUs - timeUs); + + buffer->release(); + buffer = NULL; + } else { + printf("ERROR\n"); + break; + } + } + + CHECK_EQ(OK, source->stop()); +} + static void usage(const char *me) { fprintf(stderr, "usage: %s\n", me); fprintf(stderr, " -h(elp)\n"); @@ -291,6 +347,7 @@ static void usage(const char *me) { fprintf(stderr, " -s(oftware) prefer software codec\n"); fprintf(stderr, " -o playback audio\n"); fprintf(stderr, " -w(rite) filename (write to .mp4 file)\n"); + fprintf(stderr, " -k seek test\n"); } int main(int argc, char **argv) { @@ -300,6 +357,7 @@ int main(int argc, char **argv) { bool listComponents = false; bool dumpProfiles = false; bool extractThumbnail = false; + bool seekTest = false; gNumRepetitions = 1; gMaxNumFrames = 0; gReproduceBug = -1; @@ -308,7 +366,7 @@ int main(int argc, char **argv) { gWriteMP4 = false; int res; - while ((res = getopt(argc, argv, "han:lm:b:ptsow:")) >= 0) { + while ((res = getopt(argc, argv, "han:lm:b:ptsow:k")) >= 0) { switch (res) { case 'a': { @@ -375,6 +433,12 @@ int main(int argc, char **argv) { break; } + case 'k': + { + seekTest = true; + break; + } + case '?': case 'h': default: @@ -585,6 +649,8 @@ int main(int argc, char **argv) { if (gWriteMP4) { writeSourceToMP4(mediaSource); + } else if (seekTest) { + performSeekTest(mediaSource); } else { playSource(&client, mediaSource); } |