summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Android (Google) Code Review <android-gerrit@google.com> 2009-11-10 12:27:53 -0800
committer Android (Google) Code Review <android-gerrit@google.com> 2009-11-10 12:27:53 -0800
commitcfe45c775ddb5e48bf556aee7422298260eb4fd8 (patch)
tree55082097f253a772712770955f0aad7f07e6c179
parentcc9a63dbc2b5569ef65ec3a04d86dbdfdee3f134 (diff)
parentda440f137fbae90d4c1709e499198d6cd4effdf6 (diff)
Merge change I96c4d4b3 into eclair
* changes: Fix for random audio output failures, properly dup() the file descriptor in IMediaPlayer::setDataSource to assume ownership as the caller will otherwise close it.
-rw-r--r--media/libmediaplayerservice/StagefrightPlayer.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/media/libmediaplayerservice/StagefrightPlayer.cpp b/media/libmediaplayerservice/StagefrightPlayer.cpp
index 9a06d13be747..dbee451b01e1 100644
--- a/media/libmediaplayerservice/StagefrightPlayer.cpp
+++ b/media/libmediaplayerservice/StagefrightPlayer.cpp
@@ -40,11 +40,13 @@ status_t StagefrightPlayer::setDataSource(const char *url) {
return err;
}
+// Warning: The filedescriptor passed into this method will only be valid until
+// the method returns, if you want to keep it, dup it!
status_t StagefrightPlayer::setDataSource(int fd, int64_t offset, int64_t length) {
LOGV("setDataSource(%d, %lld, %lld)", fd, offset, length);
reset();
- mPlayer = new MediaPlayerImpl(fd, offset, length);
+ mPlayer = new MediaPlayerImpl(dup(fd), offset, length);
status_t err = mPlayer->initCheck();
if (err != OK) {