NuPlayerDriver.cpp revision d4cdba18ba7d0057ae54ec7efa5871b1a9d8beca
1f933441648ef6a71dee783d733aac17b9508b452Andreas Huber/* 2f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * Copyright (C) 2010 The Android Open Source Project 3f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * 4f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * Licensed under the Apache License, Version 2.0 (the "License"); 5f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * you may not use this file except in compliance with the License. 6f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * You may obtain a copy of the License at 7f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * 8f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * http://www.apache.org/licenses/LICENSE-2.0 9f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * 10f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * Unless required by applicable law or agreed to in writing, software 11f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * distributed under the License is distributed on an "AS IS" BASIS, 12f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * See the License for the specific language governing permissions and 14f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * limitations under the License. 15f933441648ef6a71dee783d733aac17b9508b452Andreas Huber */ 16f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 17f933441648ef6a71dee783d733aac17b9508b452Andreas Huber//#define LOG_NDEBUG 0 18f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#define LOG_TAG "NuPlayerDriver" 19377b2ec9a2885f9b6405b07ba900a9e3f4349c38Kévin PETIT#include <inttypes.h> 20f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <utils/Log.h> 21f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 22f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include "NuPlayerDriver.h" 23f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 24f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include "NuPlayer.h" 259575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber#include "NuPlayerSource.h" 26f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 271aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber#include <media/stagefright/foundation/ADebug.h> 28f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/foundation/ALooper.h> 29a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu#include <media/stagefright/foundation/AUtils.h> 309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber#include <media/stagefright/MetaData.h> 312abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung#include <media/stagefright/Utils.h> 32f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 33f933441648ef6a71dee783d733aac17b9508b452Andreas Hubernamespace android { 34f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 35f933441648ef6a71dee783d733aac17b9508b452Andreas HuberNuPlayerDriver::NuPlayerDriver() 369575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber : mState(STATE_IDLE), 37ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber mIsAsyncPrepare(false), 389575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult(UNKNOWN_ERROR), 3913d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mSetSurfaceInProgress(false), 4043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs(-1), 4143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPositionUs(-1), 42a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress(false), 431aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mLooper(new ALooper), 449575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags(0), 45a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber mAtEOS(false), 46a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping(false), 47f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAutoLoop(false), 4843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mStartupSeekTimeUs(-1) { 492abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("NuPlayerDriver(%p)", this); 50f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mLooper->setName("NuPlayerDriver Looper"); 51f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 52f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mLooper->start( 53f933441648ef6a71dee783d733aac17b9508b452Andreas Huber false, /* runOnCallingThread */ 54f933441648ef6a71dee783d733aac17b9508b452Andreas Huber true, /* canCallJava */ 55f933441648ef6a71dee783d733aac17b9508b452Andreas Huber PRIORITY_AUDIO); 56f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 57f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mPlayer = new NuPlayer; 58f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mLooper->registerHandler(mPlayer); 59f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 6043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPlayer->setDriver(this); 61f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 62f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 63f933441648ef6a71dee783d733aac17b9508b452Andreas HuberNuPlayerDriver::~NuPlayerDriver() { 642abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("~NuPlayerDriver(%p)", this); 65f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mLooper->stop(); 66f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 67f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 68f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::initCheck() { 69f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 70f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 71f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 729b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huberstatus_t NuPlayerDriver::setUID(uid_t uid) { 739b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber mPlayer->setUID(uid); 749b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber 759b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber return OK; 769b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber} 779b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber 78f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::setDataSource( 791b86fe063badb5f28c467ade39be0f4008688947Andreas Huber const sp<IMediaHTTPService> &httpService, 801b86fe063badb5f28c467ade39be0f4008688947Andreas Huber const char *url, 811b86fe063badb5f28c467ade39be0f4008688947Andreas Huber const KeyedVector<String8, String8> *headers) { 822abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("setDataSource(%p) url(%s)", this, uriDebugString(url, false).c_str()); 839575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 8443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 859575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (mState != STATE_IDLE) { 869575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 879575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 885bc087c573c70c84c6a39946457590b42d392a33Andreas Huber 899575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_SET_DATASOURCE_PENDING; 9043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 911b86fe063badb5f28c467ade39be0f4008688947Andreas Huber mPlayer->setDataSourceAsync(httpService, url, headers); 929575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 939575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_SET_DATASOURCE_PENDING) { 949575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.wait(mLock); 959575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 969575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 979575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return mAsyncResult; 98f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 99f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 100f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::setDataSource(int fd, int64_t offset, int64_t length) { 1012abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("setDataSource(%p) file(%d)", this, fd); 1029575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 103afed0e1fa37473a4cd30018577b560acc79d9a3fAndreas Huber 1049575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (mState != STATE_IDLE) { 1059575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 1069575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 107afed0e1fa37473a4cd30018577b560acc79d9a3fAndreas Huber 1089575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_SET_DATASOURCE_PENDING; 109afed0e1fa37473a4cd30018577b560acc79d9a3fAndreas Huber 1109575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayer->setDataSourceAsync(fd, offset, length); 1119575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 1129575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_SET_DATASOURCE_PENDING) { 1139575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.wait(mLock); 1149575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 1159575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 1169575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return mAsyncResult; 117f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 118f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 119f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::setDataSource(const sp<IStreamSource> &source) { 1202abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("setDataSource(%p) stream source", this); 1219575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 12243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 1239575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (mState != STATE_IDLE) { 1249575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 1259575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 126f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 1279575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_SET_DATASOURCE_PENDING; 12843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 1299575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayer->setDataSourceAsync(source); 1309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 1319575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_SET_DATASOURCE_PENDING) { 1329575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.wait(mLock); 1339575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 1349575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 1359575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return mAsyncResult; 136f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 137f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 1381173118eace0e9e347cb007f0da817cee87579edGlenn Kastenstatus_t NuPlayerDriver::setVideoSurfaceTexture( 1398ba01021b573889802e67e029225a96f0dfa471aAndy McFadden const sp<IGraphicBufferProducer> &bufferProducer) { 1402abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("setVideoSurfaceTexture(%p)", this); 14157a339cdb7524f883de3ceb364c0b5606df0c610Andreas Huber Mutex::Autolock autoLock(mLock); 14257a339cdb7524f883de3ceb364c0b5606df0c610Andreas Huber 14313d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang if (mSetSurfaceInProgress) { 14413d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang return INVALID_OPERATION; 14513d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang } 14613d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 1479575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 1489575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_SET_DATASOURCE_PENDING: 1499575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RESET_IN_PROGRESS: 1509575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 1519575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 1529575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 1539575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 1549575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 1559575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 15613d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mSetSurfaceInProgress = true; 15713d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 1588ba01021b573889802e67e029225a96f0dfa471aAndy McFadden mPlayer->setVideoSurfaceTextureAsync(bufferProducer); 15957a339cdb7524f883de3ceb364c0b5606df0c610Andreas Huber 16013d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang while (mSetSurfaceInProgress) { 16113d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mCondition.wait(mLock); 16213d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang } 16313d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 1641173118eace0e9e347cb007f0da817cee87579edGlenn Kasten return OK; 1651173118eace0e9e347cb007f0da817cee87579edGlenn Kasten} 1661173118eace0e9e347cb007f0da817cee87579edGlenn Kasten 167f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::prepare() { 1682abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("prepare(%p)", this); 1699575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 1709575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return prepare_l(); 171f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 172f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 1739575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huberstatus_t NuPlayerDriver::prepare_l() { 1749575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 1759575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_UNPREPARED: 1769575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_PREPARING; 177ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber 178ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber // Make sure we're not posting any notifications, success or 179ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber // failure information is only communicated through our result 180ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber // code. 181ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber mIsAsyncPrepare = false; 1829575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayer->prepareAsync(); 1839575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_PREPARING) { 1849575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.wait(mLock); 1859575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 1869575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return (mState == STATE_PREPARED) ? OK : UNKNOWN_ERROR; 1874b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED: 1884b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar // this is really just paused. handle as seek to start 1894b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mAtEOS = false; 1904b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mState = STATE_STOPPED_AND_PREPARING; 1914b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mIsAsyncPrepare = false; 192dab70a065a8e972d272ed948e77cf2cd0f1525e1Wei Jia mPlayer->seekToAsync(0, true /* needNotify */); 1934b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar while (mState == STATE_STOPPED_AND_PREPARING) { 1944b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mCondition.wait(mLock); 1954b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 1964b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return (mState == STATE_STOPPED_AND_PREPARED) ? OK : UNKNOWN_ERROR; 1979575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 1989575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 1999575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber }; 2009575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 201afed0e1fa37473a4cd30018577b560acc79d9a3fAndreas Huber 2029575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huberstatus_t NuPlayerDriver::prepareAsync() { 2032abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("prepareAsync(%p)", this); 2049575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 2055bc087c573c70c84c6a39946457590b42d392a33Andreas Huber 2069575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 2079575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_UNPREPARED: 2089575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_PREPARING; 209ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber mIsAsyncPrepare = true; 2109575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayer->prepareAsync(); 2119575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 2124b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED: 2134b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar // this is really just paused. handle as seek to start 2144b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mAtEOS = false; 2154b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mState = STATE_STOPPED_AND_PREPARING; 2164b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mIsAsyncPrepare = true; 217dab70a065a8e972d272ed948e77cf2cd0f1525e1Wei Jia mPlayer->seekToAsync(0, true /* needNotify */); 2184b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return OK; 2199575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 2209575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 2219575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber }; 222f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 223f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 224f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::start() { 2252abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("start(%p)", this); 2269575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 2279575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 22843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 2299575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_UNPREPARED: 2309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber { 2319575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber status_t err = prepare_l(); 2329575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2339575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (err != OK) { 2349575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return err; 2359575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 2369575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2379575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_PREPARED); 2389575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2399575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber // fall through 2409575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 2419575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2429421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_PAUSED: 2439421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_STOPPED_AND_PREPARED: 2449421174a2f002fef31b330fb04e00105a905dca4Wei Jia { 2459421174a2f002fef31b330fb04e00105a905dca4Wei Jia if (mAtEOS && mStartupSeekTimeUs < 0) { 2469421174a2f002fef31b330fb04e00105a905dca4Wei Jia mStartupSeekTimeUs = 0; 2479421174a2f002fef31b330fb04e00105a905dca4Wei Jia mPositionUs = -1; 2489421174a2f002fef31b330fb04e00105a905dca4Wei Jia } 2499421174a2f002fef31b330fb04e00105a905dca4Wei Jia 2509421174a2f002fef31b330fb04e00105a905dca4Wei Jia // fall through 2519421174a2f002fef31b330fb04e00105a905dca4Wei Jia } 2529421174a2f002fef31b330fb04e00105a905dca4Wei Jia 2539575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 25443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber { 255a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber mAtEOS = false; 25643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPlayer->start(); 25743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 25843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber if (mStartupSeekTimeUs >= 0) { 2599421174a2f002fef31b330fb04e00105a905dca4Wei Jia mPlayer->seekToAsync(mStartupSeekTimeUs); 26043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mStartupSeekTimeUs = -1; 26143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 26243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 26343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 26443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 2659575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 2660560195a71ee26e8546075e56c49ff535fcf1767Wei Jia { 2670560195a71ee26e8546075e56c49ff535fcf1767Wei Jia if (mAtEOS) { 2680560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPlayer->seekToAsync(0); 2690560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mAtEOS = false; 2700560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPositionUs = -1; 2710560195a71ee26e8546075e56c49ff535fcf1767Wei Jia } 2729575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 2730560195a71ee26e8546075e56c49ff535fcf1767Wei Jia } 2749575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2759575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 2769575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 27743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 27843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 2799575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_RUNNING; 280f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 281f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 282f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 283f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 284f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::stop() { 2852abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("stop(%p)", this); 2864b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar Mutex::Autolock autoLock(mLock); 2874b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 2884b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar switch (mState) { 2894b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_RUNNING: 2904b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mPlayer->pause(); 2914b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar // fall through 2924b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 2934b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_PAUSED: 2942a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_STOPPED; 2950560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_STOPPED); 2962a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen break; 2974b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 2984b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_PREPARED: 2994b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED: 3004b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED_AND_PREPARING: 3014b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED_AND_PREPARED: 3024b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mState = STATE_STOPPED; 3034b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar break; 3044b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3054b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar default: 3064b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return INVALID_OPERATION; 3074b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 3084b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3094b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return OK; 310f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 311f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 312f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::pause() { 313f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // The NuPlayerRenderer may get flushed if pause for long enough, e.g. the pause timeout tear 314f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // down for audio offload mode. If that happens, the NuPlayerRenderer will no longer know the 315f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // current position. So similar to seekTo, update |mPositionUs| to the pause position by calling 316f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // getCurrentPosition here. 317f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu int msec; 318f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu getCurrentPosition(&msec); 319f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu 3209575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 3219575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 32243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 3239575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PAUSED: 3249575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 32543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber return OK; 3269575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 3279575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 3282a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_PAUSED; 3290560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PAUSED); 33043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPlayer->pause(); 33143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 3329575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 33343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber default: 3349575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 33543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 33643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 337f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 338f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 339f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 340f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool NuPlayerDriver::isPlaying() { 3419575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return mState == STATE_RUNNING && !mAtEOS; 342f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 343f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 344f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::seekTo(int msec) { 3452abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("seekTo(%p) %d ms", this, msec); 3469575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 3479575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 34843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber int64_t seekTimeUs = msec * 1000ll; 34943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 35043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 3519575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 3529421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_STOPPED_AND_PREPARED: 35343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber { 35443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mStartupSeekTimeUs = seekTimeUs; 355dd114d19f65d8a5cdfddbaf6d3ef8119c6169b28Marco Nelissen // pretend that the seek completed. It will actually happen when starting playback. 356dd114d19f65d8a5cdfddbaf6d3ef8119c6169b28Marco Nelissen // TODO: actually perform the seek here, so the player is ready to go at the new 357dd114d19f65d8a5cdfddbaf6d3ef8119c6169b28Marco Nelissen // location 358eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen notifySeekComplete_l(); 35943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 36043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 3619575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 3629575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 3639575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PAUSED: 36443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber { 365a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber mAtEOS = false; 366a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress = true; 367cbaffcffee6418d678806e63097c19fe26d48fe0Lajos Molnar // seeks can take a while, so we essentially paused 3680560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PAUSED); 369e427abf1ea252ff305fc33aacdd2e83cf34891b5Wei Jia mPlayer->seekToAsync(seekTimeUs, true /* needNotify */); 37043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 37143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 37243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 37343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber default: 3749575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 37543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 37643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 3770560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPositionUs = seekTimeUs; 37843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber return OK; 379f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 380f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 381f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getCurrentPosition(int *msec) { 382a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t tempUs = 0; 383d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia { 384d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia Mutex::Autolock autoLock(mLock); 385d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia if (mSeekInProgress || mState == STATE_PAUSED) { 386d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia tempUs = (mPositionUs <= 0) ? 0 : mPositionUs; 387d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia *msec = (int)divRound(tempUs, (int64_t)(1000)); 388d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia return OK; 389d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia } 390d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia } 391d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia 392a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu status_t ret = mPlayer->getCurrentPosition(&tempUs); 39343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 394a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu Mutex::Autolock autoLock(mLock); 395a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // We need to check mSeekInProgress here because mPlayer->seekToAsync is an async call, which 396a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // means getCurrentPosition can be called before seek is completed. Iow, renderer may return a 397a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // position value that's different the seek to position. 398d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia if (ret != OK) { 399a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu tempUs = (mPositionUs <= 0) ? 0 : mPositionUs; 40043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } else { 401a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mPositionUs = tempUs; 40243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 403a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu *msec = (int)divRound(tempUs, (int64_t)(1000)); 4045bc087c573c70c84c6a39946457590b42d392a33Andreas Huber return OK; 405f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 406f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 407f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getDuration(int *msec) { 40843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber Mutex::Autolock autoLock(mLock); 40943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 41043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber if (mDurationUs < 0) { 411d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber return UNKNOWN_ERROR; 41243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 4135bc087c573c70c84c6a39946457590b42d392a33Andreas Huber 414d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber *msec = (mDurationUs + 500ll) / 1000; 415d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber 4165bc087c573c70c84c6a39946457590b42d392a33Andreas Huber return OK; 417f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 418f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 419f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::reset() { 4202abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("reset(%p)", this); 4211aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber Mutex::Autolock autoLock(mLock); 4221aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 4239575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 4249575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_IDLE: 4259575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 4269575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 4279575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_SET_DATASOURCE_PENDING: 4289575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RESET_IN_PROGRESS: 4299575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 4309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 431b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber case STATE_PREPARING: 432b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber { 433b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber CHECK(mIsAsyncPrepare); 434b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 4350560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PREPARED); 436b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber break; 437b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber } 438b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 4399575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 4409575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 4419575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 4429575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 4434b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar if (mState != STATE_STOPPED) { 4440560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_STOPPED); 4454b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 446cbaffcffee6418d678806e63097c19fe26d48fe0Lajos Molnar 4479575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_RESET_IN_PROGRESS; 4481aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mPlayer->resetAsync(); 4491aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 4509575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_RESET_IN_PROGRESS) { 4511aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mCondition.wait(mLock); 4521aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber } 4531aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 45443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs = -1; 45543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPositionUs = -1; 45643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mStartupSeekTimeUs = -1; 457a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping = false; 45843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 459f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 460f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 461f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 462a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnarstatus_t NuPlayerDriver::setLooping(int loop) { 463a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping = loop != 0; 464a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar return OK; 465f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 466f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 467f933441648ef6a71dee783d733aac17b9508b452Andreas Huberplayer_type NuPlayerDriver::playerType() { 468f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return NU_PLAYER; 469f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 470f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 471f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::invoke(const Parcel &request, Parcel *reply) { 4720d268a3cae145afb2720c88ae38fb81550be5584James Dong if (reply == NULL) { 4730d268a3cae145afb2720c88ae38fb81550be5584James Dong ALOGE("reply is a NULL pointer"); 4740d268a3cae145afb2720c88ae38fb81550be5584James Dong return BAD_VALUE; 4750d268a3cae145afb2720c88ae38fb81550be5584James Dong } 4760d268a3cae145afb2720c88ae38fb81550be5584James Dong 4770d268a3cae145afb2720c88ae38fb81550be5584James Dong int32_t methodId; 4780d268a3cae145afb2720c88ae38fb81550be5584James Dong status_t ret = request.readInt32(&methodId); 4790d268a3cae145afb2720c88ae38fb81550be5584James Dong if (ret != OK) { 4800d268a3cae145afb2720c88ae38fb81550be5584James Dong ALOGE("Failed to retrieve the requested method to invoke"); 4810d268a3cae145afb2720c88ae38fb81550be5584James Dong return ret; 4820d268a3cae145afb2720c88ae38fb81550be5584James Dong } 4830d268a3cae145afb2720c88ae38fb81550be5584James Dong 4840d268a3cae145afb2720c88ae38fb81550be5584James Dong switch (methodId) { 4850d268a3cae145afb2720c88ae38fb81550be5584James Dong case INVOKE_ID_SET_VIDEO_SCALING_MODE: 4860d268a3cae145afb2720c88ae38fb81550be5584James Dong { 4870d268a3cae145afb2720c88ae38fb81550be5584James Dong int mode = request.readInt32(); 4880d268a3cae145afb2720c88ae38fb81550be5584James Dong return mPlayer->setVideoScalingMode(mode); 4890d268a3cae145afb2720c88ae38fb81550be5584James Dong } 490d5e56231a598b180a1d898bb7dc61b75580e59a4Andreas Huber 491dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_GET_TRACK_INFO: 492dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 493dcb89b3b505522efde173c105a851c412f947178Chong Zhang return mPlayer->getTrackInfo(reply); 494dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 495dcb89b3b505522efde173c105a851c412f947178Chong Zhang 496dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_SELECT_TRACK: 497dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 498dcb89b3b505522efde173c105a851c412f947178Chong Zhang int trackIndex = request.readInt32(); 4996ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih int msec = 0; 5006ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih // getCurrentPosition should always return OK 5016ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih getCurrentPosition(&msec); 5026ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih return mPlayer->selectTrack(trackIndex, true /* select */, msec * 1000ll); 503dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 504dcb89b3b505522efde173c105a851c412f947178Chong Zhang 505dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_UNSELECT_TRACK: 506dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 507dcb89b3b505522efde173c105a851c412f947178Chong Zhang int trackIndex = request.readInt32(); 5086ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih return mPlayer->selectTrack(trackIndex, false /* select */, 0xdeadbeef /* not used */); 509dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 510dcb89b3b505522efde173c105a851c412f947178Chong Zhang 5117c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih case INVOKE_ID_GET_SELECTED_TRACK: 5127c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih { 5137c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih int32_t type = request.readInt32(); 5147c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih return mPlayer->getSelectedTrack(type, reply); 5157c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih } 5167c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih 5170d268a3cae145afb2720c88ae38fb81550be5584James Dong default: 5180d268a3cae145afb2720c88ae38fb81550be5584James Dong { 5190d268a3cae145afb2720c88ae38fb81550be5584James Dong return INVALID_OPERATION; 5200d268a3cae145afb2720c88ae38fb81550be5584James Dong } 5210d268a3cae145afb2720c88ae38fb81550be5584James Dong } 522f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 523f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 524f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid NuPlayerDriver::setAudioSink(const sp<AudioSink> &audioSink) { 525f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mPlayer->setAudioSink(audioSink); 526f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAudioSink = audioSink; 527f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 528f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 52984333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::setParameter( 53084333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber int /* key */, const Parcel & /* request */) { 5314f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang return INVALID_OPERATION; 5324f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang} 5334f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang 53484333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::getParameter(int /* key */, Parcel * /* reply */) { 5354f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang return INVALID_OPERATION; 5364f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang} 5374f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang 538f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getMetadata( 53984333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber const media::Metadata::Filter& /* ids */, Parcel *records) { 5409575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 5419575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5429575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber using media::Metadata; 5439575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5449575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata meta(records); 5459575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5469575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5479575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kPauseAvailable, 5489575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_PAUSE); 5499575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5509575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5519575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekBackwardAvailable, 5529575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK_BACKWARD); 5539575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5549575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5559575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekForwardAvailable, 5569575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK_FORWARD); 5579575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5589575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5599575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekAvailable, 5609575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK); 5619575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5629575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 563f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 564f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 56543c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyResetComplete() { 5668d121d41f5355b78b687f44e8d4aae4de2aa0359Andy Hung ALOGD("notifyResetComplete(%p)", this); 5671aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber Mutex::Autolock autoLock(mLock); 5689575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5699575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_RESET_IN_PROGRESS); 5709575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_IDLE; 5711aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mCondition.broadcast(); 5721aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber} 5731aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 57413d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhangvoid NuPlayerDriver::notifySetSurfaceComplete() { 5752abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("notifySetSurfaceComplete(%p)", this); 57613d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang Mutex::Autolock autoLock(mLock); 57713d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 57813d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang CHECK(mSetSurfaceInProgress); 57913d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mSetSurfaceInProgress = false; 58013d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 58113d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mCondition.broadcast(); 58213d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang} 58313d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 58443c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyDuration(int64_t durationUs) { 58543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber Mutex::Autolock autoLock(mLock); 58643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs = durationUs; 58743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber} 58843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 58943c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifySeekComplete() { 5902abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("notifySeekComplete(%p)", this); 591eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen Mutex::Autolock autoLock(mLock); 592a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress = false; 593eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen notifySeekComplete_l(); 594eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen} 595eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen 596eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissenvoid NuPlayerDriver::notifySeekComplete_l() { 5974b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar bool wasSeeking = true; 598eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen if (mState == STATE_STOPPED_AND_PREPARING) { 599eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen wasSeeking = false; 600eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen mState = STATE_STOPPED_AND_PREPARED; 601eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen mCondition.broadcast(); 602eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen if (!mIsAsyncPrepare) { 603eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen // if we are preparing synchronously, no need to notify listener 6044b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return; 6054b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 606eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen } else if (mState == STATE_STOPPED) { 607eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen // no need to notify listener 608eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen return; 6094b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 6100560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(wasSeeking ? MEDIA_SEEK_COMPLETE : MEDIA_PREPARED); 61143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber} 61243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 61384333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::dump( 61484333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber int fd, const Vector<String16> & /* args */) const { 615a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t numFramesTotal; 616a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t numFramesDropped; 617a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mPlayer->getStats(&numFramesTotal, &numFramesDropped); 6183fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6193fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber FILE *out = fdopen(dup(fd), "w"); 6203fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6213fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber fprintf(out, " NuPlayer\n"); 622377b2ec9a2885f9b6405b07ba900a9e3f4349c38Kévin PETIT fprintf(out, " numFramesTotal(%" PRId64 "), numFramesDropped(%" PRId64 "), " 6233fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber "percentageDropped(%.2f)\n", 624a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesTotal, 625a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesDropped, 626a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesTotal == 0 627a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu ? 0.0 : (double)numFramesDropped / numFramesTotal); 6283fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6293fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber fclose(out); 6303fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber out = NULL; 6313fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6323fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber return OK; 6333fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber} 6343fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 635dcb89b3b505522efde173c105a851c412f947178Chong Zhangvoid NuPlayerDriver::notifyListener( 636dcb89b3b505522efde173c105a851c412f947178Chong Zhang int msg, int ext1, int ext2, const Parcel *in) { 6370560195a71ee26e8546075e56c49ff535fcf1767Wei Jia Mutex::Autolock autoLock(mLock); 6380560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(msg, ext1, ext2, in); 6390560195a71ee26e8546075e56c49ff535fcf1767Wei Jia} 6400560195a71ee26e8546075e56c49ff535fcf1767Wei Jia 6410560195a71ee26e8546075e56c49ff535fcf1767Wei Jiavoid NuPlayerDriver::notifyListener_l( 6420560195a71ee26e8546075e56c49ff535fcf1767Wei Jia int msg, int ext1, int ext2, const Parcel *in) { 643a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar switch (msg) { 644a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar case MEDIA_PLAYBACK_COMPLETE: 645a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar { 64671079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia if (mState != STATE_RESET_IN_PROGRESS) { 647707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (mAutoLoop) { 648707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen audio_stream_type_t streamType = AUDIO_STREAM_MUSIC; 649707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (mAudioSink != NULL) { 650707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen streamType = mAudioSink->getAudioStreamType(); 651707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 652707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (streamType == AUDIO_STREAM_NOTIFICATION) { 653707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen ALOGW("disabling auto-loop for notification"); 654707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen mAutoLoop = false; 655707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 656707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 657f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen if (mLooping || (mAutoLoop 658f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen && (mAudioSink == NULL || mAudioSink->realtime()))) { 65971079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mPlayer->seekToAsync(0); 660368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen if (mAudioSink != NULL) { 661368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen // The renderer has stopped the sink at the end in order to play out 662368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen // the last little bit of audio. If we're looping, we need to restart it. 663368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen mAudioSink->start(); 664368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen } 66571079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia break; 66671079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia } 66771079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia 66871079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mPlayer->pause(); 66971079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mState = STATE_PAUSED; 670a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 671a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar // fall through 672a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 673a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar 674a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar case MEDIA_ERROR: 675a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar { 676a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mAtEOS = true; 677a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar break; 678a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 679a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar 680a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar default: 681a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar break; 682a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber } 683a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber 6840560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mLock.unlock(); 685dcb89b3b505522efde173c105a851c412f947178Chong Zhang sendEvent(msg, ext1, ext2, in); 6860560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mLock.lock(); 687a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber} 688a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber 6899575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifySetDataSourceCompleted(status_t err) { 6909575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 6919575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6929575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_SET_DATASOURCE_PENDING); 6939575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6949575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult = err; 6959575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = (err == OK) ? STATE_UNPREPARED : STATE_IDLE; 6969575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.broadcast(); 6979575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 6989575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6999575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifyPrepareCompleted(status_t err) { 7009575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 7019575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 702b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber if (mState != STATE_PREPARING) { 703b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // We were preparing asynchronously when the client called 704b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // reset(), we sent a premature "prepared" notification and 705b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // then initiated the reset. This notification is stale. 706b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber CHECK(mState == STATE_RESET_IN_PROGRESS || mState == STATE_IDLE); 707b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber return; 708b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber } 709b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 7109575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_PREPARING); 7119575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7129575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult = err; 7139575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7149575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (err == OK) { 7152a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen // update state before notifying client, so that if client calls back into NuPlayerDriver 7162a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen // in response, NuPlayerDriver has the right state 7172a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_PREPARED; 718ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber if (mIsAsyncPrepare) { 7190560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PREPARED); 720ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber } 7219575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } else { 7222a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_UNPREPARED; 723ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber if (mIsAsyncPrepare) { 7240560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_ERROR, MEDIA_ERROR_UNKNOWN, err); 725ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber } 7269575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 7279575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 728f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen sp<MetaData> meta = mPlayer->getFileMeta(); 729f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen int32_t loop; 730f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen if (meta != NULL 731f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen && meta->findInt32(kKeyAutoLoop, &loop) && loop != 0) { 732f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAutoLoop = true; 733f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen } 734f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen 7359575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.broadcast(); 7369575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 7379575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7389575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifyFlagsChanged(uint32_t flags) { 7399575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 7409575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7419575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags = flags; 7429575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 7439575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 744f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} // namespace android 745