summaryrefslogtreecommitdiffstats
path: root/media
diff options
context:
space:
mode:
authorMarco Nelissen <marcone@google.com>2012-04-13 16:00:41 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2012-04-13 16:00:41 -0700
commitfbe308d428e42fe249ec317f76e3d11feb3264d5 (patch)
treeec5519aa319720a34151463529558d923a53d580 /media
parent25736fd247ba757feefe15d3071f7e747c64fea4 (diff)
parenta28976b04c70cef3c8e79137478b6a7bc05608ac (diff)
downloadframeworks_av-fbe308d428e42fe249ec317f76e3d11feb3264d5.zip
frameworks_av-fbe308d428e42fe249ec317f76e3d11feb3264d5.tar.gz
frameworks_av-fbe308d428e42fe249ec317f76e3d11feb3264d5.tar.bz2
Merge "Make mediascanner use filedescriptors instead of paths"
Diffstat (limited to 'media')
-rw-r--r--media/libstagefright/StagefrightMediaScanner.cpp15
1 files changed, 14 insertions, 1 deletions
diff --git a/media/libstagefright/StagefrightMediaScanner.cpp b/media/libstagefright/StagefrightMediaScanner.cpp
index 711a8cd..b7cf96e 100644
--- a/media/libstagefright/StagefrightMediaScanner.cpp
+++ b/media/libstagefright/StagefrightMediaScanner.cpp
@@ -18,6 +18,10 @@
#define LOG_TAG "StagefrightMediaScanner"
#include <utils/Log.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+
#include <media/stagefright/StagefrightMediaScanner.h>
#include <media/mediametadataretriever.h>
@@ -139,7 +143,16 @@ MediaScanResult StagefrightMediaScanner::processFileInternal(
sp<MediaMetadataRetriever> mRetriever(new MediaMetadataRetriever);
- status_t status = mRetriever->setDataSource(path);
+ int fd = open(path, O_RDONLY | O_LARGEFILE);
+ status_t status;
+ if (fd < 0) {
+ // couldn't open it locally, maybe the media server can?
+ status = mRetriever->setDataSource(path);
+ } else {
+ status = mRetriever->setDataSource(fd, 0, 0x7ffffffffffffffL);
+ close(fd);
+ }
+
if (status) {
return MEDIA_SCAN_RESULT_ERROR;
}