diff options
| author | 2009-11-10 12:27:53 -0800 | |
|---|---|---|
| committer | 2009-11-10 12:27:53 -0800 | |
| commit | cfe45c775ddb5e48bf556aee7422298260eb4fd8 (patch) | |
| tree | 55082097f253a772712770955f0aad7f07e6c179 | |
| parent | cc9a63dbc2b5569ef65ec3a04d86dbdfdee3f134 (diff) | |
| parent | da440f137fbae90d4c1709e499198d6cd4effdf6 (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.cpp | 4 |
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) { |