NuPlayerDriver.cpp revision 1061c9c29cfdeb3b2a307a4ee4cda2cd197b48e6
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); 13099f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins 13199f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins while (mState == STATE_SET_DATASOURCE_PENDING) { 13299f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins mCondition.wait(mLock); 13399f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins } 13499f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins 13599f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins return mAsyncResult; 13699f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins} 13799f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins 13899f31604136d66ae10e20669fb6b5716f342bde0Chris Watkinsstatus_t NuPlayerDriver::setDataSource(const sp<DataSource> &source) { 13999f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins ALOGV("setDataSource(%p) callback source", this); 14099f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins Mutex::Autolock autoLock(mLock); 14199f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins 14299f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins if (mState != STATE_IDLE) { 14399f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins return INVALID_OPERATION; 14499f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins } 14599f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins 14699f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins mState = STATE_SET_DATASOURCE_PENDING; 14799f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins 14899f31604136d66ae10e20669fb6b5716f342bde0Chris Watkins mPlayer->setDataSourceAsync(source); 1499575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 1509575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_SET_DATASOURCE_PENDING) { 1519575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.wait(mLock); 1529575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 1539575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 1549575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return mAsyncResult; 155f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 156f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 1571173118eace0e9e347cb007f0da817cee87579edGlenn Kastenstatus_t NuPlayerDriver::setVideoSurfaceTexture( 1588ba01021b573889802e67e029225a96f0dfa471aAndy McFadden const sp<IGraphicBufferProducer> &bufferProducer) { 1592abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("setVideoSurfaceTexture(%p)", this); 16057a339cdb7524f883de3ceb364c0b5606df0c610Andreas Huber Mutex::Autolock autoLock(mLock); 16157a339cdb7524f883de3ceb364c0b5606df0c610Andreas Huber 16213d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang if (mSetSurfaceInProgress) { 16313d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang return INVALID_OPERATION; 16413d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang } 16513d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 1669575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 1679575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_SET_DATASOURCE_PENDING: 1689575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RESET_IN_PROGRESS: 1699575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 1709575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 1719575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 1729575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 1739575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 1749575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 17513d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mSetSurfaceInProgress = true; 17613d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 1778ba01021b573889802e67e029225a96f0dfa471aAndy McFadden mPlayer->setVideoSurfaceTextureAsync(bufferProducer); 17857a339cdb7524f883de3ceb364c0b5606df0c610Andreas Huber 17913d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang while (mSetSurfaceInProgress) { 18013d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mCondition.wait(mLock); 18113d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang } 18213d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 1831173118eace0e9e347cb007f0da817cee87579edGlenn Kasten return OK; 1841173118eace0e9e347cb007f0da817cee87579edGlenn Kasten} 1851173118eace0e9e347cb007f0da817cee87579edGlenn Kasten 186f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::prepare() { 1872abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("prepare(%p)", this); 1889575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 1899575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return prepare_l(); 190f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 191f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 1929575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huberstatus_t NuPlayerDriver::prepare_l() { 1939575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 1949575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_UNPREPARED: 1959575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_PREPARING; 196ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber 197ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber // Make sure we're not posting any notifications, success or 198ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber // failure information is only communicated through our result 199ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber // code. 200ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber mIsAsyncPrepare = false; 2019575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayer->prepareAsync(); 2029575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_PREPARING) { 2039575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.wait(mLock); 2049575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 2059575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return (mState == STATE_PREPARED) ? OK : UNKNOWN_ERROR; 2064b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED: 2074b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar // this is really just paused. handle as seek to start 2084b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mAtEOS = false; 2094b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mState = STATE_STOPPED_AND_PREPARING; 2104b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mIsAsyncPrepare = false; 211dab70a065a8e972d272ed948e77cf2cd0f1525e1Wei Jia mPlayer->seekToAsync(0, true /* needNotify */); 2124b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar while (mState == STATE_STOPPED_AND_PREPARING) { 2134b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mCondition.wait(mLock); 2144b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 2154b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return (mState == STATE_STOPPED_AND_PREPARED) ? OK : UNKNOWN_ERROR; 2169575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 2179575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 2189575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber }; 2199575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 220afed0e1fa37473a4cd30018577b560acc79d9a3fAndreas Huber 2219575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huberstatus_t NuPlayerDriver::prepareAsync() { 2222abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("prepareAsync(%p)", this); 2239575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 2245bc087c573c70c84c6a39946457590b42d392a33Andreas Huber 2259575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 2269575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_UNPREPARED: 2279575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_PREPARING; 228ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber mIsAsyncPrepare = true; 2299575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayer->prepareAsync(); 2309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 2314b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED: 2324b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar // this is really just paused. handle as seek to start 2334b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mAtEOS = false; 2344b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mState = STATE_STOPPED_AND_PREPARING; 2354b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mIsAsyncPrepare = true; 236dab70a065a8e972d272ed948e77cf2cd0f1525e1Wei Jia mPlayer->seekToAsync(0, true /* needNotify */); 2374b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return OK; 2389575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 2399575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 2409575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber }; 241f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 242f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 243f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::start() { 2442abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("start(%p)", this); 2459575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 2469575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 24743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 2489575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_UNPREPARED: 2499575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber { 2509575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber status_t err = prepare_l(); 2519575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2529575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (err != OK) { 2539575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return err; 2549575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 2559575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2569575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_PREPARED); 2579575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2589575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber // fall through 2599575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 2609575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2619421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_PAUSED: 2629421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_STOPPED_AND_PREPARED: 2639421174a2f002fef31b330fb04e00105a905dca4Wei Jia { 2649421174a2f002fef31b330fb04e00105a905dca4Wei Jia if (mAtEOS && mStartupSeekTimeUs < 0) { 2659421174a2f002fef31b330fb04e00105a905dca4Wei Jia mStartupSeekTimeUs = 0; 2669421174a2f002fef31b330fb04e00105a905dca4Wei Jia mPositionUs = -1; 2679421174a2f002fef31b330fb04e00105a905dca4Wei Jia } 2689421174a2f002fef31b330fb04e00105a905dca4Wei Jia 2699421174a2f002fef31b330fb04e00105a905dca4Wei Jia // fall through 2709421174a2f002fef31b330fb04e00105a905dca4Wei Jia } 2719421174a2f002fef31b330fb04e00105a905dca4Wei Jia 2729575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 27343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber { 274a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber mAtEOS = false; 27543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPlayer->start(); 27643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 27743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber if (mStartupSeekTimeUs >= 0) { 2789421174a2f002fef31b330fb04e00105a905dca4Wei Jia mPlayer->seekToAsync(mStartupSeekTimeUs); 27943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mStartupSeekTimeUs = -1; 28043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 28143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 28243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 28343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 2849575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 2850560195a71ee26e8546075e56c49ff535fcf1767Wei Jia { 2860560195a71ee26e8546075e56c49ff535fcf1767Wei Jia if (mAtEOS) { 2870560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPlayer->seekToAsync(0); 2880560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mAtEOS = false; 2890560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPositionUs = -1; 2900560195a71ee26e8546075e56c49ff535fcf1767Wei Jia } 2919575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 2920560195a71ee26e8546075e56c49ff535fcf1767Wei Jia } 2939575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2949575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 2959575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 29643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 29743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 2989575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_RUNNING; 299f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 300f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 301f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 302f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 303f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::stop() { 3042abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("stop(%p)", this); 3054b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar Mutex::Autolock autoLock(mLock); 3064b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3074b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar switch (mState) { 3084b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_RUNNING: 3094b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mPlayer->pause(); 3104b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar // fall through 3114b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3124b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_PAUSED: 3132a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_STOPPED; 3140560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_STOPPED); 3152a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen break; 3164b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3174b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_PREPARED: 3184b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED: 3194b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED_AND_PREPARING: 3204b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED_AND_PREPARED: 3214b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mState = STATE_STOPPED; 3224b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar break; 3234b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3244b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar default: 3254b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return INVALID_OPERATION; 3264b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 3274b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3284b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return OK; 329f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 330f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 331f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::pause() { 332f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // The NuPlayerRenderer may get flushed if pause for long enough, e.g. the pause timeout tear 333f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // down for audio offload mode. If that happens, the NuPlayerRenderer will no longer know the 334f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // current position. So similar to seekTo, update |mPositionUs| to the pause position by calling 335f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // getCurrentPosition here. 336f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu int msec; 337f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu getCurrentPosition(&msec); 338f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu 3399575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 3409575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 34143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 3429575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PAUSED: 3439575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 34443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber return OK; 3459575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 3469575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 3472a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_PAUSED; 3480560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PAUSED); 34943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPlayer->pause(); 35043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 3519575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 35243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber default: 3539575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 35443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 35543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 356f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 357f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 358f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 359f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool NuPlayerDriver::isPlaying() { 3609575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return mState == STATE_RUNNING && !mAtEOS; 361f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 362f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 3633a474aa67fc31505740526dd249d96204c08bf79Lajos Molnarstatus_t NuPlayerDriver::setPlaybackSettings(const AudioPlaybackRate &rate) { 3643a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar Mutex::Autolock autoLock(mLock); 3653a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar status_t err = mPlayer->setPlaybackSettings(rate); 3663a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar if (err == OK) { 3673a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar if (rate.mSpeed == 0.f && mState == STATE_RUNNING) { 3683a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar mState = STATE_PAUSED; 3693a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar // try to update position 3703a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar (void)mPlayer->getCurrentPosition(&mPositionUs); 3713a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar notifyListener_l(MEDIA_PAUSED); 3723a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar } else if (rate.mSpeed != 0.f && mState == STATE_PAUSED) { 3733a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar mState = STATE_RUNNING; 3743a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar } 3753a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar } 3763a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar return err; 3773a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar} 3783a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar 3793a474aa67fc31505740526dd249d96204c08bf79Lajos Molnarstatus_t NuPlayerDriver::getPlaybackSettings(AudioPlaybackRate *rate) { 3803a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar return mPlayer->getPlaybackSettings(rate); 3813a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar} 3823a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar 3833a474aa67fc31505740526dd249d96204c08bf79Lajos Molnarstatus_t NuPlayerDriver::setSyncSettings(const AVSyncSettings &sync, float videoFpsHint) { 3843a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar return mPlayer->setSyncSettings(sync, videoFpsHint); 3853a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar} 3863a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar 3873a474aa67fc31505740526dd249d96204c08bf79Lajos Molnarstatus_t NuPlayerDriver::getSyncSettings(AVSyncSettings *sync, float *videoFps) { 3883a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar return mPlayer->getSyncSettings(sync, videoFps); 3899816016afb2a13c6a866cd047d57020566a8b9a9Wei Jia} 3909816016afb2a13c6a866cd047d57020566a8b9a9Wei Jia 391f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::seekTo(int msec) { 3922abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("seekTo(%p) %d ms", this, msec); 3939575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 3949575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 39543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber int64_t seekTimeUs = msec * 1000ll; 39643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 39743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 3989575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 3999421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_STOPPED_AND_PREPARED: 4001061c9c29cfdeb3b2a307a4ee4cda2cd197b48e6Wei Jia case STATE_PAUSED: 40143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mStartupSeekTimeUs = seekTimeUs; 4021061c9c29cfdeb3b2a307a4ee4cda2cd197b48e6Wei Jia // fall through. 4039575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 40443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber { 405a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber mAtEOS = false; 406a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress = true; 407cbaffcffee6418d678806e63097c19fe26d48fe0Lajos Molnar // seeks can take a while, so we essentially paused 4080560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PAUSED); 409e427abf1ea252ff305fc33aacdd2e83cf34891b5Wei Jia mPlayer->seekToAsync(seekTimeUs, true /* needNotify */); 41043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 41143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 41243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 41343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber default: 4149575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 41543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 41643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 4170560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPositionUs = seekTimeUs; 41843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber return OK; 419f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 420f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 421f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getCurrentPosition(int *msec) { 422a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t tempUs = 0; 423d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia { 424d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia Mutex::Autolock autoLock(mLock); 425d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia if (mSeekInProgress || mState == STATE_PAUSED) { 426d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia tempUs = (mPositionUs <= 0) ? 0 : mPositionUs; 427d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia *msec = (int)divRound(tempUs, (int64_t)(1000)); 428d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia return OK; 429d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia } 430d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia } 431d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia 432a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu status_t ret = mPlayer->getCurrentPosition(&tempUs); 43343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 434a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu Mutex::Autolock autoLock(mLock); 435a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // We need to check mSeekInProgress here because mPlayer->seekToAsync is an async call, which 436a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // means getCurrentPosition can be called before seek is completed. Iow, renderer may return a 437a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // position value that's different the seek to position. 438d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia if (ret != OK) { 439a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu tempUs = (mPositionUs <= 0) ? 0 : mPositionUs; 44043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } else { 441a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mPositionUs = tempUs; 44243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 443a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu *msec = (int)divRound(tempUs, (int64_t)(1000)); 4445bc087c573c70c84c6a39946457590b42d392a33Andreas Huber return OK; 445f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 446f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 447f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getDuration(int *msec) { 44843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber Mutex::Autolock autoLock(mLock); 44943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 45043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber if (mDurationUs < 0) { 451d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber return UNKNOWN_ERROR; 45243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 4535bc087c573c70c84c6a39946457590b42d392a33Andreas Huber 454d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber *msec = (mDurationUs + 500ll) / 1000; 455d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber 4565bc087c573c70c84c6a39946457590b42d392a33Andreas Huber return OK; 457f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 458f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 459f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::reset() { 4602abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("reset(%p)", this); 4611aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber Mutex::Autolock autoLock(mLock); 4621aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 4639575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 4649575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_IDLE: 4659575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 4669575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 4679575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_SET_DATASOURCE_PENDING: 4689575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RESET_IN_PROGRESS: 4699575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 4709575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 471b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber case STATE_PREPARING: 472b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber { 473b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber CHECK(mIsAsyncPrepare); 474b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 4750560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PREPARED); 476b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber break; 477b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber } 478b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 4799575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 4809575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 4819575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 4829575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 4834b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar if (mState != STATE_STOPPED) { 4840560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_STOPPED); 4854b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 486cbaffcffee6418d678806e63097c19fe26d48fe0Lajos Molnar 4879575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_RESET_IN_PROGRESS; 4881aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mPlayer->resetAsync(); 4891aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 4909575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_RESET_IN_PROGRESS) { 4911aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mCondition.wait(mLock); 4921aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber } 4931aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 49443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs = -1; 49543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPositionUs = -1; 49643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mStartupSeekTimeUs = -1; 497a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping = false; 49843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 499f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 500f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 501f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 502a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnarstatus_t NuPlayerDriver::setLooping(int loop) { 503a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping = loop != 0; 504a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar return OK; 505f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 506f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 507f933441648ef6a71dee783d733aac17b9508b452Andreas Huberplayer_type NuPlayerDriver::playerType() { 508f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return NU_PLAYER; 509f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 510f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 511f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::invoke(const Parcel &request, Parcel *reply) { 5120d268a3cae145afb2720c88ae38fb81550be5584James Dong if (reply == NULL) { 5130d268a3cae145afb2720c88ae38fb81550be5584James Dong ALOGE("reply is a NULL pointer"); 5140d268a3cae145afb2720c88ae38fb81550be5584James Dong return BAD_VALUE; 5150d268a3cae145afb2720c88ae38fb81550be5584James Dong } 5160d268a3cae145afb2720c88ae38fb81550be5584James Dong 5170d268a3cae145afb2720c88ae38fb81550be5584James Dong int32_t methodId; 5180d268a3cae145afb2720c88ae38fb81550be5584James Dong status_t ret = request.readInt32(&methodId); 5190d268a3cae145afb2720c88ae38fb81550be5584James Dong if (ret != OK) { 5200d268a3cae145afb2720c88ae38fb81550be5584James Dong ALOGE("Failed to retrieve the requested method to invoke"); 5210d268a3cae145afb2720c88ae38fb81550be5584James Dong return ret; 5220d268a3cae145afb2720c88ae38fb81550be5584James Dong } 5230d268a3cae145afb2720c88ae38fb81550be5584James Dong 5240d268a3cae145afb2720c88ae38fb81550be5584James Dong switch (methodId) { 5250d268a3cae145afb2720c88ae38fb81550be5584James Dong case INVOKE_ID_SET_VIDEO_SCALING_MODE: 5260d268a3cae145afb2720c88ae38fb81550be5584James Dong { 5270d268a3cae145afb2720c88ae38fb81550be5584James Dong int mode = request.readInt32(); 5280d268a3cae145afb2720c88ae38fb81550be5584James Dong return mPlayer->setVideoScalingMode(mode); 5290d268a3cae145afb2720c88ae38fb81550be5584James Dong } 530d5e56231a598b180a1d898bb7dc61b75580e59a4Andreas Huber 531dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_GET_TRACK_INFO: 532dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 533dcb89b3b505522efde173c105a851c412f947178Chong Zhang return mPlayer->getTrackInfo(reply); 534dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 535dcb89b3b505522efde173c105a851c412f947178Chong Zhang 536dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_SELECT_TRACK: 537dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 538dcb89b3b505522efde173c105a851c412f947178Chong Zhang int trackIndex = request.readInt32(); 5396ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih int msec = 0; 5406ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih // getCurrentPosition should always return OK 5416ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih getCurrentPosition(&msec); 5426ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih return mPlayer->selectTrack(trackIndex, true /* select */, msec * 1000ll); 543dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 544dcb89b3b505522efde173c105a851c412f947178Chong Zhang 545dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_UNSELECT_TRACK: 546dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 547dcb89b3b505522efde173c105a851c412f947178Chong Zhang int trackIndex = request.readInt32(); 5486ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih return mPlayer->selectTrack(trackIndex, false /* select */, 0xdeadbeef /* not used */); 549dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 550dcb89b3b505522efde173c105a851c412f947178Chong Zhang 5517c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih case INVOKE_ID_GET_SELECTED_TRACK: 5527c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih { 5537c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih int32_t type = request.readInt32(); 5547c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih return mPlayer->getSelectedTrack(type, reply); 5557c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih } 5567c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih 5570d268a3cae145afb2720c88ae38fb81550be5584James Dong default: 5580d268a3cae145afb2720c88ae38fb81550be5584James Dong { 5590d268a3cae145afb2720c88ae38fb81550be5584James Dong return INVALID_OPERATION; 5600d268a3cae145afb2720c88ae38fb81550be5584James Dong } 5610d268a3cae145afb2720c88ae38fb81550be5584James Dong } 562f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 563f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 564f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid NuPlayerDriver::setAudioSink(const sp<AudioSink> &audioSink) { 565f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mPlayer->setAudioSink(audioSink); 566f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAudioSink = audioSink; 567f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 568f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 56984333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::setParameter( 57084333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber int /* key */, const Parcel & /* request */) { 5714f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang return INVALID_OPERATION; 5724f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang} 5734f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang 57484333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::getParameter(int /* key */, Parcel * /* reply */) { 5754f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang return INVALID_OPERATION; 5764f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang} 5774f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang 578f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getMetadata( 57984333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber const media::Metadata::Filter& /* ids */, Parcel *records) { 5809575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 5819575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5829575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber using media::Metadata; 5839575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5849575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata meta(records); 5859575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5869575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5879575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kPauseAvailable, 5889575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_PAUSE); 5899575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5909575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5919575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekBackwardAvailable, 5929575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK_BACKWARD); 5939575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5949575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5959575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekForwardAvailable, 5969575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK_FORWARD); 5979575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5989575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5999575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekAvailable, 6009575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK); 6019575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6029575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 603f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 604f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 60543c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyResetComplete() { 6068d121d41f5355b78b687f44e8d4aae4de2aa0359Andy Hung ALOGD("notifyResetComplete(%p)", this); 6071aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber Mutex::Autolock autoLock(mLock); 6089575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6099575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_RESET_IN_PROGRESS); 6109575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_IDLE; 6111aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mCondition.broadcast(); 6121aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber} 6131aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 61413d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhangvoid NuPlayerDriver::notifySetSurfaceComplete() { 6152abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("notifySetSurfaceComplete(%p)", this); 61613d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang Mutex::Autolock autoLock(mLock); 61713d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 61813d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang CHECK(mSetSurfaceInProgress); 61913d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mSetSurfaceInProgress = false; 62013d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 62113d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mCondition.broadcast(); 62213d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang} 62313d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 62443c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyDuration(int64_t durationUs) { 62543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber Mutex::Autolock autoLock(mLock); 62643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs = durationUs; 62743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber} 62843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 62943c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifySeekComplete() { 6302abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("notifySeekComplete(%p)", this); 631eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen Mutex::Autolock autoLock(mLock); 632a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress = false; 633eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen notifySeekComplete_l(); 634eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen} 635eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen 636eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissenvoid NuPlayerDriver::notifySeekComplete_l() { 6374b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar bool wasSeeking = true; 638eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen if (mState == STATE_STOPPED_AND_PREPARING) { 639eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen wasSeeking = false; 640eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen mState = STATE_STOPPED_AND_PREPARED; 641eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen mCondition.broadcast(); 642eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen if (!mIsAsyncPrepare) { 643eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen // if we are preparing synchronously, no need to notify listener 6444b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return; 6454b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 646eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen } else if (mState == STATE_STOPPED) { 647eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen // no need to notify listener 648eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen return; 6494b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 6500560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(wasSeeking ? MEDIA_SEEK_COMPLETE : MEDIA_PREPARED); 65143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber} 65243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 65384333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::dump( 65484333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber int fd, const Vector<String16> & /* args */) const { 655a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t numFramesTotal; 656a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t numFramesDropped; 657a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mPlayer->getStats(&numFramesTotal, &numFramesDropped); 6583fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6593fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber FILE *out = fdopen(dup(fd), "w"); 6603fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6613fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber fprintf(out, " NuPlayer\n"); 662377b2ec9a2885f9b6405b07ba900a9e3f4349c38Kévin PETIT fprintf(out, " numFramesTotal(%" PRId64 "), numFramesDropped(%" PRId64 "), " 6633fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber "percentageDropped(%.2f)\n", 664a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesTotal, 665a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesDropped, 666a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu numFramesTotal == 0 667a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu ? 0.0 : (double)numFramesDropped / numFramesTotal); 6683fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6693fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber fclose(out); 6703fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber out = NULL; 6713fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6723fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber return OK; 6733fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber} 6743fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 675dcb89b3b505522efde173c105a851c412f947178Chong Zhangvoid NuPlayerDriver::notifyListener( 676dcb89b3b505522efde173c105a851c412f947178Chong Zhang int msg, int ext1, int ext2, const Parcel *in) { 6770560195a71ee26e8546075e56c49ff535fcf1767Wei Jia Mutex::Autolock autoLock(mLock); 6780560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(msg, ext1, ext2, in); 6790560195a71ee26e8546075e56c49ff535fcf1767Wei Jia} 6800560195a71ee26e8546075e56c49ff535fcf1767Wei Jia 6810560195a71ee26e8546075e56c49ff535fcf1767Wei Jiavoid NuPlayerDriver::notifyListener_l( 6820560195a71ee26e8546075e56c49ff535fcf1767Wei Jia int msg, int ext1, int ext2, const Parcel *in) { 683a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar switch (msg) { 684a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar case MEDIA_PLAYBACK_COMPLETE: 685a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar { 68671079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia if (mState != STATE_RESET_IN_PROGRESS) { 687707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (mAutoLoop) { 688707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen audio_stream_type_t streamType = AUDIO_STREAM_MUSIC; 689707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (mAudioSink != NULL) { 690707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen streamType = mAudioSink->getAudioStreamType(); 691707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 692707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (streamType == AUDIO_STREAM_NOTIFICATION) { 693707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen ALOGW("disabling auto-loop for notification"); 694707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen mAutoLoop = false; 695707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 696707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 697b7848f1c442bc8c71020957948d1b003a62a25b7Marco Nelissen if (mLooping || mAutoLoop) { 69871079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mPlayer->seekToAsync(0); 699368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen if (mAudioSink != NULL) { 700368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen // The renderer has stopped the sink at the end in order to play out 701368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen // the last little bit of audio. If we're looping, we need to restart it. 702368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen mAudioSink->start(); 703368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen } 70471079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia break; 70571079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia } 70671079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia 70771079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mPlayer->pause(); 70818def1b8b8cdc91695ebb75bb392a84bb1b9c9beLajos Molnar mState = STATE_PAUSED; 709a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 710a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar // fall through 711c6993231c56da1924ba8d67eb150fa953ba54a1bMarco Nelissen } 712a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar 713a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar case MEDIA_ERROR: 714a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar { 715a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mAtEOS = true; 716a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar break; 717a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 718a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar 719a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar default: 720a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar break; 721a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber } 722a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber 7230560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mLock.unlock(); 724dcb89b3b505522efde173c105a851c412f947178Chong Zhang sendEvent(msg, ext1, ext2, in); 7250560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mLock.lock(); 726a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber} 727a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber 7289575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifySetDataSourceCompleted(status_t err) { 7299575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 7309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7319575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_SET_DATASOURCE_PENDING); 7329575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7339575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult = err; 7349575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = (err == OK) ? STATE_UNPREPARED : STATE_IDLE; 7359575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.broadcast(); 7369575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 7379575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7389575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifyPrepareCompleted(status_t err) { 7399575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 7409575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 741b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber if (mState != STATE_PREPARING) { 742b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // We were preparing asynchronously when the client called 743b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // reset(), we sent a premature "prepared" notification and 744b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // then initiated the reset. This notification is stale. 745b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber CHECK(mState == STATE_RESET_IN_PROGRESS || mState == STATE_IDLE); 746b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber return; 747b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber } 748b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 7499575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_PREPARING); 7509575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7519575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult = err; 7529575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7539575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (err == OK) { 7542a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen // update state before notifying client, so that if client calls back into NuPlayerDriver 7552a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen // in response, NuPlayerDriver has the right state 7562a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_PREPARED; 757ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber if (mIsAsyncPrepare) { 7580560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PREPARED); 759ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber } 7609575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } else { 7612a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_UNPREPARED; 762ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber if (mIsAsyncPrepare) { 7630560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_ERROR, MEDIA_ERROR_UNKNOWN, err); 764ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber } 7659575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 7669575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 767f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen sp<MetaData> meta = mPlayer->getFileMeta(); 768f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen int32_t loop; 769f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen if (meta != NULL 770f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen && meta->findInt32(kKeyAutoLoop, &loop) && loop != 0) { 771f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAutoLoop = true; 772f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen } 773f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen 7749575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.broadcast(); 7759575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 7769575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7779575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifyFlagsChanged(uint32_t flags) { 7789575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 7799575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7809575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags = flags; 7819575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 7829575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 783f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} // namespace android 784