summaryrefslogtreecommitdiffstats
path: root/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
diff options
context:
space:
mode:
authorWei Jia <wjia@google.com>2014-12-19 22:27:00 +0000
committerAndroid Git Automerger <android-git-automerger@android.com>2014-12-19 22:27:00 +0000
commitbae511e3b982355fbc75ae2ba13bb88feab9fe8c (patch)
tree67593d3fda0779b0850f57c44756c4e9deca5201 /media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
parent01a7aaf2cec81edbdc2bb62a5a46594312cce078 (diff)
parent4af263bd15a8177f1e28a53a2765277022d7372e (diff)
downloadframeworks_av-bae511e3b982355fbc75ae2ba13bb88feab9fe8c.zip
frameworks_av-bae511e3b982355fbc75ae2ba13bb88feab9fe8c.tar.gz
frameworks_av-bae511e3b982355fbc75ae2ba13bb88feab9fe8c.tar.bz2
am 4af263bd: am ad019236: Merge "NuPlayer: reports paused position in paused state." into lmp-mr1-dev
* commit '4af263bd15a8177f1e28a53a2765277022d7372e': NuPlayer: reports paused position in paused state.
Diffstat (limited to 'media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp')
-rw-r--r--media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp11
1 files changed, 10 insertions, 1 deletions
diff --git a/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp b/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
index d050c78..e7e1759 100644
--- a/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
+++ b/media/libmediaplayerservice/nuplayer/NuPlayerDriver.cpp
@@ -380,13 +380,22 @@ status_t NuPlayerDriver::seekTo(int msec) {
status_t NuPlayerDriver::getCurrentPosition(int *msec) {
int64_t tempUs = 0;
+ {
+ Mutex::Autolock autoLock(mLock);
+ if (mSeekInProgress || mState == STATE_PAUSED) {
+ tempUs = (mPositionUs <= 0) ? 0 : mPositionUs;
+ *msec = (int)divRound(tempUs, (int64_t)(1000));
+ return OK;
+ }
+ }
+
status_t ret = mPlayer->getCurrentPosition(&tempUs);
Mutex::Autolock autoLock(mLock);
// We need to check mSeekInProgress here because mPlayer->seekToAsync is an async call, which
// means getCurrentPosition can be called before seek is completed. Iow, renderer may return a
// position value that's different the seek to position.
- if (ret != OK || mSeekInProgress) {
+ if (ret != OK) {
tempUs = (mPositionUs <= 0) ? 0 : mPositionUs;
} else {
mPositionUs = tempUs;