NuPlayerDriver.cpp revision f83408b41bbd796b7923d719e7e3799ddc7acaff
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; 383a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu status_t ret = mPlayer->getCurrentPosition(&tempUs); 38443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 385a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu Mutex::Autolock autoLock(mLock); 386a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // We need to check mSeekInProgress here because mPlayer->seekToAsync is an async call, which 387a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // means getCurrentPosition can be called before seek is completed. Iow, renderer may return a 388a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // position value that's different the seek to position. 389a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu if (ret != OK || mSeekInProgress) { 390a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu tempUs = (mPositionUs <= 0) ? 0 : mPositionUs; 39143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } else { 392a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mPositionUs = tempUs; 39343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 394a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu *msec = (int)divRound(tempUs, (int64_t)(1000)); 3955bc087c573c70c84c6a39946457590b42d392a33Andreas Huber return OK; 396f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 397f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 398f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getDuration(int *msec) { 39943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber Mutex::Autolock autoLock(mLock); 40043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 40143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber if (mDurationUs < 0) { 402d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber return UNKNOWN_ERROR; 40343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 4045bc087c573c70c84c6a39946457590b42d392a33Andreas Huber 405d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber *msec = (mDurationUs + 500ll) / 1000; 406d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber 4075bc087c573c70c84c6a39946457590b42d392a33Andreas Huber return OK; 408f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 409f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 410f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::reset() { 4112abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("reset(%p)", this); 4121aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber Mutex::Autolock autoLock(mLock); 4131aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 4149575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 4159575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_IDLE: 4169575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 4179575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 4189575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_SET_DATASOURCE_PENDING: 4199575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RESET_IN_PROGRESS: 4209575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 4219575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 422b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber case STATE_PREPARING: 423b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber { 424b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber CHECK(mIsAsyncPrepare); 425b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 4260560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PREPARED); 427b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber break; 428b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber } 429b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 4309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 4319575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 4329575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 4339575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 4344b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar if (mState != STATE_STOPPED) { 4350560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_STOPPED); 4364b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 437cbaffcffee6418d678806e63097c19fe26d48fe0Lajos Molnar 4389575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_RESET_IN_PROGRESS; 4391aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mPlayer->resetAsync(); 4401aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 4419575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_RESET_IN_PROGRESS) { 4421aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mCondition.wait(mLock); 4431aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber } 4441aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 44543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs = -1; 44643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPositionUs = -1; 44743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mStartupSeekTimeUs = -1; 448a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping = false; 44943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 450f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 451f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 452f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 453a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnarstatus_t NuPlayerDriver::setLooping(int loop) { 454a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping = loop != 0; 455a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar return OK; 456f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 457f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 458f933441648ef6a71dee783d733aac17b9508b452Andreas Huberplayer_type NuPlayerDriver::playerType() { 459f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return NU_PLAYER; 460f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 461f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 462f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::invoke(const Parcel &request, Parcel *reply) { 4630d268a3cae145afb2720c88ae38fb81550be5584James Dong if (reply == NULL) { 4640d268a3cae145afb2720c88ae38fb81550be5584James Dong ALOGE("reply is a NULL pointer"); 4650d268a3cae145afb2720c88ae38fb81550be5584James Dong return BAD_VALUE; 4660d268a3cae145afb2720c88ae38fb81550be5584James Dong } 4670d268a3cae145afb2720c88ae38fb81550be5584James Dong 4680d268a3cae145afb2720c88ae38fb81550be5584James Dong int32_t methodId; 4690d268a3cae145afb2720c88ae38fb81550be5584James Dong status_t ret = request.readInt32(&methodId); 4700d268a3cae145afb2720c88ae38fb81550be5584James Dong if (ret != OK) { 4710d268a3cae145afb2720c88ae38fb81550be5584James Dong ALOGE("Failed to retrieve the requested method to invoke"); 4720d268a3cae145afb2720c88ae38fb81550be5584James Dong return ret; 4730d268a3cae145afb2720c88ae38fb81550be5584James Dong } 4740d268a3cae145afb2720c88ae38fb81550be5584James Dong 4750d268a3cae145afb2720c88ae38fb81550be5584James Dong switch (methodId) { 4760d268a3cae145afb2720c88ae38fb81550be5584James Dong case INVOKE_ID_SET_VIDEO_SCALING_MODE: 4770d268a3cae145afb2720c88ae38fb81550be5584James Dong { 4780d268a3cae145afb2720c88ae38fb81550be5584James Dong int mode = request.readInt32(); 4790d268a3cae145afb2720c88ae38fb81550be5584James Dong return mPlayer->setVideoScalingMode(mode); 4800d268a3cae145afb2720c88ae38fb81550be5584James Dong } 481d5e56231a598b180a1d898bb7dc61b75580e59a4Andreas Huber 482dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_GET_TRACK_INFO: 483dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 484dcb89b3b505522efde173c105a851c412f947178Chong Zhang return mPlayer->getTrackInfo(reply); 485dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 486dcb89b3b505522efde173c105a851c412f947178Chong Zhang 487dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_SELECT_TRACK: 488dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 489dcb89b3b505522efde173c105a851c412f947178Chong Zhang int trackIndex = request.readInt32(); 490dcb89b3b505522efde173c105a851c412f947178Chong Zhang return mPlayer->selectTrack(trackIndex, true /* select */); 491dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 492dcb89b3b505522efde173c105a851c412f947178Chong Zhang 493dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_UNSELECT_TRACK: 494dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 495dcb89b3b505522efde173c105a851c412f947178Chong Zhang int trackIndex = request.readInt32(); 496dcb89b3b505522efde173c105a851c412f947178Chong Zhang return mPlayer->selectTrack(trackIndex, false /* select */); 497dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 498dcb89b3b505522efde173c105a851c412f947178Chong Zhang 4997c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih case INVOKE_ID_GET_SELECTED_TRACK: 5007c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih { 5017c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih int32_t type = request.readInt32(); 5027c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih return mPlayer->getSelectedTrack(type, reply); 5037c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih } 5047c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih 5050d268a3cae145afb2720c88ae38fb81550be5584James Dong default: 5060d268a3cae145afb2720c88ae38fb81550be5584James Dong { 5070d268a3cae145afb2720c88ae38fb81550be5584James Dong return INVALID_OPERATION; 5080d268a3cae145afb2720c88ae38fb81550be5584James Dong } 5090d268a3cae145afb2720c88ae38fb81550be5584James Dong } 510f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 511f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 512f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid NuPlayerDriver::setAudioSink(const sp<AudioSink> &audioSink) { 513f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mPlayer->setAudioSink(audioSink); 514f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAudioSink = audioSink; 515f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 516f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 51784333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::setParameter( 51884333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber int /* key */, const Parcel & /* request */) { 5194f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang return INVALID_OPERATION; 5204f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang} 5214f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang 52284333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::getParameter(int /* key */, Parcel * /* reply */) { 5234f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang return INVALID_OPERATION; 5244f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang} 5254f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang 526f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getMetadata( 52784333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber const media::Metadata::Filter& /* ids */, Parcel *records) { 5289575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 5299575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber using media::Metadata; 5319575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5329575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata meta(records); 5339575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5349575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5359575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kPauseAvailable, 5369575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_PAUSE); 5379575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5389575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5399575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekBackwardAvailable, 5409575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK_BACKWARD); 5419575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5429575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5439575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekForwardAvailable, 5449575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK_FORWARD); 5459575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5469575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5479575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekAvailable, 5489575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK); 5499575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5509575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 551f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 552f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 55343c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyResetComplete() { 5548d121d41f5355b78b687f44e8d4aae4de2aa0359Andy Hung ALOGD("notifyResetComplete(%p)", this); 5551aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber Mutex::Autolock autoLock(mLock); 5569575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5579575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_RESET_IN_PROGRESS); 5589575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_IDLE; 5591aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mCondition.broadcast(); 5601aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber} 5611aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 56213d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhangvoid NuPlayerDriver::notifySetSurfaceComplete() { 5632abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("notifySetSurfaceComplete(%p)", this); 56413d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang Mutex::Autolock autoLock(mLock); 56513d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 56613d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang CHECK(mSetSurfaceInProgress); 56713d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mSetSurfaceInProgress = false; 56813d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 56913d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mCondition.broadcast(); 57013d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang} 57113d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 57243c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyDuration(int64_t durationUs) { 57343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber Mutex::Autolock autoLock(mLock); 57443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs = durationUs; 57543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber} 57643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 57743c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifySeekComplete() { 5782abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("notifySeekComplete(%p)", this); 579eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen Mutex::Autolock autoLock(mLock); 580a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress = false; 581eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen notifySeekComplete_l(); 582eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen} 583eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen 584eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissenvoid NuPlayerDriver::notifySeekComplete_l() { 5854b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar bool wasSeeking = true; 586eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen if (mState == STATE_STOPPED_AND_PREPARING) { 587eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen wasSeeking = false; 588eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen mState = STATE_STOPPED_AND_PREPARED; 589eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen mCondition.broadcast(); 590eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen if (!mIsAsyncPrepare) { 591eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen // if we are preparing synchronously, no need to notify listener 5924b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return; 5934b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 594eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen } else if (mState == STATE_STOPPED) { 595eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen // no need to notify listener 596eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen return; 5974b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 5980560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(wasSeeking ? MEDIA_SEEK_COMPLETE : MEDIA_PREPARED); 59943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber} 60043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 60184333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::dump( 60284333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber int fd, const Vector<String16> & /* args */) const { 603a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t numFramesTotal; 604a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t numFramesDropped; 605a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mPlayer->getStats(&numFramesTotal, &numFramesDropped); 6063fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6073fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber FILE *out = fdopen(dup(fd), "w"); 6083fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6093fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber fprintf(out, " NuPlayer\n"); 610377b2ec9a2885f9b6405b07ba900a9e3f4349c38Kévin PETIT fprintf(out, " numFramesTotal(%" PRId64 "), numFramesDropped(%" PRId64 "), " 6113fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber "percentageDropped(%.2f)\n", 612a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesTotal, 613a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesDropped, 614a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesTotal == 0 615a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu ? 0.0 : (double)numFramesDropped / numFramesTotal); 6163fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6173fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber fclose(out); 6183fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber out = NULL; 6193fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6203fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber return OK; 6213fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber} 6223fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 623dcb89b3b505522efde173c105a851c412f947178Chong Zhangvoid NuPlayerDriver::notifyListener( 624dcb89b3b505522efde173c105a851c412f947178Chong Zhang int msg, int ext1, int ext2, const Parcel *in) { 6250560195a71ee26e8546075e56c49ff535fcf1767Wei Jia Mutex::Autolock autoLock(mLock); 6260560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(msg, ext1, ext2, in); 6270560195a71ee26e8546075e56c49ff535fcf1767Wei Jia} 6280560195a71ee26e8546075e56c49ff535fcf1767Wei Jia 6290560195a71ee26e8546075e56c49ff535fcf1767Wei Jiavoid NuPlayerDriver::notifyListener_l( 6300560195a71ee26e8546075e56c49ff535fcf1767Wei Jia int msg, int ext1, int ext2, const Parcel *in) { 631a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar switch (msg) { 632a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar case MEDIA_PLAYBACK_COMPLETE: 633a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar { 63471079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia if (mState != STATE_RESET_IN_PROGRESS) { 635f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen if (mLooping || (mAutoLoop 636f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen && (mAudioSink == NULL || mAudioSink->realtime()))) { 63771079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mPlayer->seekToAsync(0); 638368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen if (mAudioSink != NULL) { 639368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen // The renderer has stopped the sink at the end in order to play out 640368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen // the last little bit of audio. If we're looping, we need to restart it. 641368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen mAudioSink->start(); 642368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen } 64371079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia break; 64471079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia } 64571079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia 64671079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mPlayer->pause(); 64771079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mState = STATE_PAUSED; 648a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 649a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar // fall through 650a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 651a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar 652a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar case MEDIA_ERROR: 653a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar { 654a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mAtEOS = true; 655a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar break; 656a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 657a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar 658a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar default: 659a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar break; 660a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber } 661a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber 6620560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mLock.unlock(); 663dcb89b3b505522efde173c105a851c412f947178Chong Zhang sendEvent(msg, ext1, ext2, in); 6640560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mLock.lock(); 665a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber} 666a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber 6679575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifySetDataSourceCompleted(status_t err) { 6689575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 6699575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6709575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_SET_DATASOURCE_PENDING); 6719575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6729575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult = err; 6739575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = (err == OK) ? STATE_UNPREPARED : STATE_IDLE; 6749575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.broadcast(); 6759575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 6769575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6779575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifyPrepareCompleted(status_t err) { 6789575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 6799575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 680b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber if (mState != STATE_PREPARING) { 681b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // We were preparing asynchronously when the client called 682b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // reset(), we sent a premature "prepared" notification and 683b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // then initiated the reset. This notification is stale. 684b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber CHECK(mState == STATE_RESET_IN_PROGRESS || mState == STATE_IDLE); 685b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber return; 686b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber } 687b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 6889575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_PREPARING); 6899575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6909575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult = err; 6919575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6929575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (err == OK) { 6932a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen // update state before notifying client, so that if client calls back into NuPlayerDriver 6942a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen // in response, NuPlayerDriver has the right state 6952a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_PREPARED; 696ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber if (mIsAsyncPrepare) { 6970560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PREPARED); 698ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber } 6999575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } else { 7002a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_UNPREPARED; 701ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber if (mIsAsyncPrepare) { 7020560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_ERROR, MEDIA_ERROR_UNKNOWN, err); 703ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber } 7049575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 7059575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 706f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen sp<MetaData> meta = mPlayer->getFileMeta(); 707f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen int32_t loop; 708f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen if (meta != NULL 709f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen && meta->findInt32(kKeyAutoLoop, &loop) && loop != 0) { 710f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAutoLoop = true; 711f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen } 712f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen 7139575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.broadcast(); 7149575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 7159575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7169575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifyFlagsChanged(uint32_t flags) { 7179575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 7189575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7199575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags = flags; 7209575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 7219575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 722f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} // namespace android 723