diff options
author | Ronghua Wu <ronghuawu@google.com> | 2015-05-21 10:22:53 -0700 |
---|---|---|
committer | Ronghua Wu <ronghuawu@google.com> | 2015-05-22 10:52:13 -0700 |
commit | 19352b3287480394aa9963276305d5168a7adf85 (patch) | |
tree | d3b4ee14db574676710c26bd490f2865f0ad0d4d /media/libstagefright/MediaCodecList.cpp | |
parent | 8eddd88568fe4da0ca0ceab5072bc488827f01b5 (diff) | |
download | frameworks_av-19352b3287480394aa9963276305d5168a7adf85.zip frameworks_av-19352b3287480394aa9963276305d5168a7adf85.tar.gz frameworks_av-19352b3287480394aa9963276305d5168a7adf85.tar.bz2 |
libstagefright: add version string to profile results.
Bug: 21333717
Change-Id: I79966be5ba355633f83885844165b7d9a6b2643f
Diffstat (limited to 'media/libstagefright/MediaCodecList.cpp')
-rw-r--r-- | media/libstagefright/MediaCodecList.cpp | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/media/libstagefright/MediaCodecList.cpp b/media/libstagefright/MediaCodecList.cpp index d2352bc..a153cee 100644 --- a/media/libstagefright/MediaCodecList.cpp +++ b/media/libstagefright/MediaCodecList.cpp @@ -71,10 +71,24 @@ sp<IMediaCodecList> MediaCodecList::getLocalInstance() { if (gCodecList->initCheck() == OK) { sCodecList = gCodecList; - struct stat s; - if (stat(kProfilingResults, &s) == -1) { + FILE *resultsFile = fopen(kProfilingResults, "r"); + if (resultsFile) { + AString currentVersion = getProfilingVersionString(); + size_t currentVersionSize = currentVersion.size(); + char *versionString = new char[currentVersionSize]; + fgets(versionString, currentVersionSize, resultsFile); + if (strncmp(versionString, currentVersion.c_str(), currentVersionSize) != 0) { + // profiling result out of date + profilingNeeded = true; + } + fclose(resultsFile); + delete[] versionString; + } else { // profiling results doesn't existed profilingNeeded = true; + } + + if (profilingNeeded) { for (size_t i = 0; i < gCodecList->countCodecs(); ++i) { infos.push_back(gCodecList->getCodecInfo(i)); } |