NuPlayerDriver.cpp revision 8a092d306e3fb228628506ffd73d9d9f0387f271
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> 213a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan#include <cutils/properties.h> 22f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 23f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include "NuPlayerDriver.h" 24f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 25f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include "NuPlayer.h" 269575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber#include "NuPlayerSource.h" 27f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 281aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber#include <media/stagefright/foundation/ADebug.h> 29f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/foundation/ALooper.h> 30a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu#include <media/stagefright/foundation/AUtils.h> 319575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber#include <media/stagefright/MetaData.h> 322abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung#include <media/stagefright/Utils.h> 33f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 34f933441648ef6a71dee783d733aac17b9508b452Andreas Hubernamespace android { 35f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 3668845c14ebf2c7282800b1abffde38d8e9a57aabRonghua WuNuPlayerDriver::NuPlayerDriver(pid_t pid) 379575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber : mState(STATE_IDLE), 38ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber mIsAsyncPrepare(false), 399575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult(UNKNOWN_ERROR), 4013d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mSetSurfaceInProgress(false), 4143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs(-1), 4243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPositionUs(-1), 43a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress(false), 441aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mLooper(new ALooper), 459575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags(0), 46a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber mAtEOS(false), 47a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping(false), 48419187cec0ff4660a84524b1980c2a6b6f987272Wei Jia mAutoLoop(false) { 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 5768845c14ebf2c7282800b1abffde38d8e9a57aabRonghua Wu mPlayer = new NuPlayer(pid); 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() { 24467c2c94aa9d387bb7dc47514d62deeb66d486210Wei Jia ALOGD("start(%p), state is %d, eos is %d", this, mState, mAtEOS); 2459575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 2468a092d306e3fb228628506ffd73d9d9f0387f271Wei Jia return start_l(); 2478a092d306e3fb228628506ffd73d9d9f0387f271Wei Jia} 2489575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2498a092d306e3fb228628506ffd73d9d9f0387f271Wei Jiastatus_t NuPlayerDriver::start_l() { 25043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 2519575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_UNPREPARED: 2529575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber { 2539575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber status_t err = prepare_l(); 2549575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2559575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (err != OK) { 2569575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return err; 2579575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 2589575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2599575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_PREPARED); 2609575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2619575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber // fall through 2629575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 2639575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2649421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_PAUSED: 2659421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_STOPPED_AND_PREPARED: 2669575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 26743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber { 26843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPlayer->start(); 26943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 270419187cec0ff4660a84524b1980c2a6b6f987272Wei Jia // fall through 27143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 27243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 2739575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 2740560195a71ee26e8546075e56c49ff535fcf1767Wei Jia { 2750560195a71ee26e8546075e56c49ff535fcf1767Wei Jia if (mAtEOS) { 2760560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPlayer->seekToAsync(0); 2770560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mAtEOS = false; 2780560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPositionUs = -1; 2790560195a71ee26e8546075e56c49ff535fcf1767Wei Jia } 2809575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 2810560195a71ee26e8546075e56c49ff535fcf1767Wei Jia } 2829575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 2839575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 2849575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 28543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 28643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 2879575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_RUNNING; 288f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 289f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 290f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 291f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 292f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::stop() { 2932abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGD("stop(%p)", this); 2944b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar Mutex::Autolock autoLock(mLock); 2954b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 2964b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar switch (mState) { 2974b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_RUNNING: 2984b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mPlayer->pause(); 2994b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar // fall through 3004b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3014b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_PAUSED: 3022a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_STOPPED; 3030560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_STOPPED); 3042a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen break; 3054b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3064b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_PREPARED: 3074b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED: 3084b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED_AND_PREPARING: 3094b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar case STATE_STOPPED_AND_PREPARED: 3104b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar mState = STATE_STOPPED; 3114b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar break; 3124b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3134b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar default: 3144b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return INVALID_OPERATION; 3154b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 3164b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar 3174b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return OK; 318f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 319f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 320f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::pause() { 32103a5653c8f25c0e90f362e252be48f95703b18feWei Jia ALOGD("pause(%p)", this); 322f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // The NuPlayerRenderer may get flushed if pause for long enough, e.g. the pause timeout tear 323f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // down for audio offload mode. If that happens, the NuPlayerRenderer will no longer know the 324f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // current position. So similar to seekTo, update |mPositionUs| to the pause position by calling 325f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu // getCurrentPosition here. 32662cc8d0d9d8019a84e6ef63c3917d3beb99061c6Wei Jia int unused; 32762cc8d0d9d8019a84e6ef63c3917d3beb99061c6Wei Jia getCurrentPosition(&unused); 328f83408b41bbd796b7923d719e7e3799ddc7acaffRonghua Wu 3299575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 3309575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 33143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 3329575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PAUSED: 3339575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 33443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber return OK; 3359575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 3369575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 3372a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_PAUSED; 3380560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PAUSED); 33943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPlayer->pause(); 34043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 3419575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 34243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber default: 3439575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 34443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 34543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 346f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 347f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 348f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 349f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool NuPlayerDriver::isPlaying() { 3509575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return mState == STATE_RUNNING && !mAtEOS; 351f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 352f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 3533a474aa67fc31505740526dd249d96204c08bf79Lajos Molnarstatus_t NuPlayerDriver::setPlaybackSettings(const AudioPlaybackRate &rate) { 3543a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar status_t err = mPlayer->setPlaybackSettings(rate); 3553a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar if (err == OK) { 35662cc8d0d9d8019a84e6ef63c3917d3beb99061c6Wei Jia // try to update position 35762cc8d0d9d8019a84e6ef63c3917d3beb99061c6Wei Jia int unused; 35862cc8d0d9d8019a84e6ef63c3917d3beb99061c6Wei Jia getCurrentPosition(&unused); 359f3631d2921ee0738f87427848e38873370ef9ec0Wei Jia Mutex::Autolock autoLock(mLock); 3603a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar if (rate.mSpeed == 0.f && mState == STATE_RUNNING) { 3613a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar mState = STATE_PAUSED; 3623a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar notifyListener_l(MEDIA_PAUSED); 3638a092d306e3fb228628506ffd73d9d9f0387f271Wei Jia } else if (rate.mSpeed != 0.f 3648a092d306e3fb228628506ffd73d9d9f0387f271Wei Jia && (mState == STATE_PAUSED 3658a092d306e3fb228628506ffd73d9d9f0387f271Wei Jia || mState == STATE_STOPPED_AND_PREPARED 3668a092d306e3fb228628506ffd73d9d9f0387f271Wei Jia || mState == STATE_PREPARED)) { 3678a092d306e3fb228628506ffd73d9d9f0387f271Wei Jia err = start_l(); 3683a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar } 3693a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar } 3703a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar return err; 3713a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar} 3723a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar 3733a474aa67fc31505740526dd249d96204c08bf79Lajos Molnarstatus_t NuPlayerDriver::getPlaybackSettings(AudioPlaybackRate *rate) { 3743a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar return mPlayer->getPlaybackSettings(rate); 3753a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar} 3763a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar 3773a474aa67fc31505740526dd249d96204c08bf79Lajos Molnarstatus_t NuPlayerDriver::setSyncSettings(const AVSyncSettings &sync, float videoFpsHint) { 3783a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar return mPlayer->setSyncSettings(sync, videoFpsHint); 3793a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar} 3803a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar 3813a474aa67fc31505740526dd249d96204c08bf79Lajos Molnarstatus_t NuPlayerDriver::getSyncSettings(AVSyncSettings *sync, float *videoFps) { 3823a474aa67fc31505740526dd249d96204c08bf79Lajos Molnar return mPlayer->getSyncSettings(sync, videoFps); 3839816016afb2a13c6a866cd047d57020566a8b9a9Wei Jia} 3849816016afb2a13c6a866cd047d57020566a8b9a9Wei Jia 385f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::seekTo(int msec) { 386f3c2b3df8bf616ad593e2c0101b04a718f291827Wei Jia ALOGD("seekTo(%p) %d ms at state %d", this, msec, mState); 3879575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 3889575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 38943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber int64_t seekTimeUs = msec * 1000ll; 39043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 39143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber switch (mState) { 3929575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_PREPARED: 3939421174a2f002fef31b330fb04e00105a905dca4Wei Jia case STATE_STOPPED_AND_PREPARED: 3941061c9c29cfdeb3b2a307a4ee4cda2cd197b48e6Wei Jia case STATE_PAUSED: 3959575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RUNNING: 39643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber { 397a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber mAtEOS = false; 398a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress = true; 399cbaffcffee6418d678806e63097c19fe26d48fe0Lajos Molnar // seeks can take a while, so we essentially paused 4000560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PAUSED); 401e427abf1ea252ff305fc33aacdd2e83cf34891b5Wei Jia mPlayer->seekToAsync(seekTimeUs, true /* needNotify */); 40243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber break; 40343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 40443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 40543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber default: 4069575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 40743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 40843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 4090560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mPositionUs = seekTimeUs; 41043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber return OK; 411f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 412f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 413f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getCurrentPosition(int *msec) { 414a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu int64_t tempUs = 0; 415d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia { 416d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia Mutex::Autolock autoLock(mLock); 41762cc8d0d9d8019a84e6ef63c3917d3beb99061c6Wei Jia if (mSeekInProgress || (mState == STATE_PAUSED && !mAtEOS)) { 418d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia tempUs = (mPositionUs <= 0) ? 0 : mPositionUs; 419d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia *msec = (int)divRound(tempUs, (int64_t)(1000)); 420d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia return OK; 421d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia } 422d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia } 423d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia 424a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu status_t ret = mPlayer->getCurrentPosition(&tempUs); 42543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 426a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu Mutex::Autolock autoLock(mLock); 427a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // We need to check mSeekInProgress here because mPlayer->seekToAsync is an async call, which 428a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // means getCurrentPosition can be called before seek is completed. Iow, renderer may return a 429a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu // position value that's different the seek to position. 430d4cdba18ba7d0057ae54ec7efa5871b1a9d8becaWei Jia if (ret != OK) { 431a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu tempUs = (mPositionUs <= 0) ? 0 : mPositionUs; 43243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } else { 433a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mPositionUs = tempUs; 43443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 435a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu *msec = (int)divRound(tempUs, (int64_t)(1000)); 4365bc087c573c70c84c6a39946457590b42d392a33Andreas Huber return OK; 437f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 438f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 439f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getDuration(int *msec) { 44043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber Mutex::Autolock autoLock(mLock); 44143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 44243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber if (mDurationUs < 0) { 443d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber return UNKNOWN_ERROR; 44443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber } 4455bc087c573c70c84c6a39946457590b42d392a33Andreas Huber 446d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber *msec = (mDurationUs + 500ll) / 1000; 447d85929f6086e050d7cb33bfe0d29f339ad7279e5Andreas Huber 4485bc087c573c70c84c6a39946457590b42d392a33Andreas Huber return OK; 449f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 450f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 451f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::reset() { 452f3c2b3df8bf616ad593e2c0101b04a718f291827Wei Jia ALOGD("reset(%p) at state %d", this, mState); 4531aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber Mutex::Autolock autoLock(mLock); 4541aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 4559575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber switch (mState) { 4569575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_IDLE: 4579575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 4589575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 4599575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_SET_DATASOURCE_PENDING: 4609575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber case STATE_RESET_IN_PROGRESS: 4619575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return INVALID_OPERATION; 4629575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 463b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber case STATE_PREPARING: 464b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber { 465b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber CHECK(mIsAsyncPrepare); 466b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 4670560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PREPARED); 468b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber break; 469b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber } 470b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 4719575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber default: 4729575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber break; 4739575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 4749575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 4754b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar if (mState != STATE_STOPPED) { 4760560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_STOPPED); 4774b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 478cbaffcffee6418d678806e63097c19fe26d48fe0Lajos Molnar 4793a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan char value[PROPERTY_VALUE_MAX]; 4803a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan if (property_get("persist.debug.sf.stats", value, NULL) && 4813a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan (!strcmp("1", value) || !strcasecmp("true", value))) { 4823a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan Vector<String16> args; 4833a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan dump(-1, args); 4843a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan } 4853a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan 4869575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_RESET_IN_PROGRESS; 4871aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mPlayer->resetAsync(); 4881aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 4899575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber while (mState == STATE_RESET_IN_PROGRESS) { 4901aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mCondition.wait(mLock); 4911aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber } 4921aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 49343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs = -1; 49443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mPositionUs = -1; 495a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping = false; 49643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 497f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return OK; 498f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 499f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 500a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnarstatus_t NuPlayerDriver::setLooping(int loop) { 501a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mLooping = loop != 0; 502a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar return OK; 503f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 504f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 505f933441648ef6a71dee783d733aac17b9508b452Andreas Huberplayer_type NuPlayerDriver::playerType() { 506f933441648ef6a71dee783d733aac17b9508b452Andreas Huber return NU_PLAYER; 507f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 508f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 509f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::invoke(const Parcel &request, Parcel *reply) { 5100d268a3cae145afb2720c88ae38fb81550be5584James Dong if (reply == NULL) { 5110d268a3cae145afb2720c88ae38fb81550be5584James Dong ALOGE("reply is a NULL pointer"); 5120d268a3cae145afb2720c88ae38fb81550be5584James Dong return BAD_VALUE; 5130d268a3cae145afb2720c88ae38fb81550be5584James Dong } 5140d268a3cae145afb2720c88ae38fb81550be5584James Dong 5150d268a3cae145afb2720c88ae38fb81550be5584James Dong int32_t methodId; 5160d268a3cae145afb2720c88ae38fb81550be5584James Dong status_t ret = request.readInt32(&methodId); 5170d268a3cae145afb2720c88ae38fb81550be5584James Dong if (ret != OK) { 5180d268a3cae145afb2720c88ae38fb81550be5584James Dong ALOGE("Failed to retrieve the requested method to invoke"); 5190d268a3cae145afb2720c88ae38fb81550be5584James Dong return ret; 5200d268a3cae145afb2720c88ae38fb81550be5584James Dong } 5210d268a3cae145afb2720c88ae38fb81550be5584James Dong 5220d268a3cae145afb2720c88ae38fb81550be5584James Dong switch (methodId) { 5230d268a3cae145afb2720c88ae38fb81550be5584James Dong case INVOKE_ID_SET_VIDEO_SCALING_MODE: 5240d268a3cae145afb2720c88ae38fb81550be5584James Dong { 5250d268a3cae145afb2720c88ae38fb81550be5584James Dong int mode = request.readInt32(); 5260d268a3cae145afb2720c88ae38fb81550be5584James Dong return mPlayer->setVideoScalingMode(mode); 5270d268a3cae145afb2720c88ae38fb81550be5584James Dong } 528d5e56231a598b180a1d898bb7dc61b75580e59a4Andreas Huber 529dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_GET_TRACK_INFO: 530dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 531dcb89b3b505522efde173c105a851c412f947178Chong Zhang return mPlayer->getTrackInfo(reply); 532dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 533dcb89b3b505522efde173c105a851c412f947178Chong Zhang 534dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_SELECT_TRACK: 535dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 536dcb89b3b505522efde173c105a851c412f947178Chong Zhang int trackIndex = request.readInt32(); 5376ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih int msec = 0; 5386ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih // getCurrentPosition should always return OK 5396ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih getCurrentPosition(&msec); 5406ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih return mPlayer->selectTrack(trackIndex, true /* select */, msec * 1000ll); 541dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 542dcb89b3b505522efde173c105a851c412f947178Chong Zhang 543dcb89b3b505522efde173c105a851c412f947178Chong Zhang case INVOKE_ID_UNSELECT_TRACK: 544dcb89b3b505522efde173c105a851c412f947178Chong Zhang { 545dcb89b3b505522efde173c105a851c412f947178Chong Zhang int trackIndex = request.readInt32(); 5466ffb1fd67eb8f00f130a6db914ba42a8432aec70Robert Shih return mPlayer->selectTrack(trackIndex, false /* select */, 0xdeadbeef /* not used */); 547dcb89b3b505522efde173c105a851c412f947178Chong Zhang } 548dcb89b3b505522efde173c105a851c412f947178Chong Zhang 5497c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih case INVOKE_ID_GET_SELECTED_TRACK: 5507c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih { 5517c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih int32_t type = request.readInt32(); 5527c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih return mPlayer->getSelectedTrack(type, reply); 5537c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih } 5547c4f0d757bfeedaab4b7ef4ccf5b0a72ec8f4306Robert Shih 5550d268a3cae145afb2720c88ae38fb81550be5584James Dong default: 5560d268a3cae145afb2720c88ae38fb81550be5584James Dong { 5570d268a3cae145afb2720c88ae38fb81550be5584James Dong return INVALID_OPERATION; 5580d268a3cae145afb2720c88ae38fb81550be5584James Dong } 5590d268a3cae145afb2720c88ae38fb81550be5584James Dong } 560f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 561f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 562f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid NuPlayerDriver::setAudioSink(const sp<AudioSink> &audioSink) { 563f933441648ef6a71dee783d733aac17b9508b452Andreas Huber mPlayer->setAudioSink(audioSink); 564f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAudioSink = audioSink; 565f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 566f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 56784333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::setParameter( 56884333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber int /* key */, const Parcel & /* request */) { 5694f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang return INVALID_OPERATION; 5704f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang} 5714f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang 57284333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::getParameter(int /* key */, Parcel * /* reply */) { 5734f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang return INVALID_OPERATION; 5744f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang} 5754f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang 576f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getMetadata( 57784333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber const media::Metadata::Filter& /* ids */, Parcel *records) { 5789575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 5799575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5809575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber using media::Metadata; 5819575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5829575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata meta(records); 5839575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5849575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5859575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kPauseAvailable, 5869575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_PAUSE); 5879575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5889575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5899575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekBackwardAvailable, 5909575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK_BACKWARD); 5919575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5929575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5939575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekForwardAvailable, 5949575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK_FORWARD); 5959575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 5969575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber meta.appendBool( 5979575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Metadata::kSeekAvailable, 5989575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags & NuPlayer::Source::FLAG_CAN_SEEK); 5999575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6009575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber return OK; 601f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} 602f933441648ef6a71dee783d733aac17b9508b452Andreas Huber 60343c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyResetComplete() { 6048d121d41f5355b78b687f44e8d4aae4de2aa0359Andy Hung ALOGD("notifyResetComplete(%p)", this); 6051aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber Mutex::Autolock autoLock(mLock); 6069575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 6079575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_RESET_IN_PROGRESS); 6089575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = STATE_IDLE; 6091aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber mCondition.broadcast(); 6101aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber} 6111aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber 61213d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhangvoid NuPlayerDriver::notifySetSurfaceComplete() { 6132abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("notifySetSurfaceComplete(%p)", this); 61413d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang Mutex::Autolock autoLock(mLock); 61513d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 61613d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang CHECK(mSetSurfaceInProgress); 61713d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mSetSurfaceInProgress = false; 61813d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 61913d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang mCondition.broadcast(); 62013d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang} 62113d6faa02087ce3bb0d4a02b8495f1822f211433Chong Zhang 62243c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyDuration(int64_t durationUs) { 62343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber Mutex::Autolock autoLock(mLock); 62443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber mDurationUs = durationUs; 62543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber} 62643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 62743c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifySeekComplete() { 6282abde2c118a94f843a7450818c925d3f0b673cd3Andy Hung ALOGV("notifySeekComplete(%p)", this); 629eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen Mutex::Autolock autoLock(mLock); 630a73d9e0b3d171d2bfcd9eb07df9d6d36ae74df57Ronghua Wu mSeekInProgress = false; 631eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen notifySeekComplete_l(); 632eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen} 633eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen 634eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissenvoid NuPlayerDriver::notifySeekComplete_l() { 6354b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar bool wasSeeking = true; 636eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen if (mState == STATE_STOPPED_AND_PREPARING) { 637eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen wasSeeking = false; 638eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen mState = STATE_STOPPED_AND_PREPARED; 639eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen mCondition.broadcast(); 640eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen if (!mIsAsyncPrepare) { 641eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen // if we are preparing synchronously, no need to notify listener 6424b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar return; 6434b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 644eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen } else if (mState == STATE_STOPPED) { 645eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen // no need to notify listener 646eb645a0d1820b227af287a5309f017afadbab4e3Marco Nelissen return; 6474b75b86785d674b98dade17cd197b912d87cd279Lajos Molnar } 6480560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(wasSeeking ? MEDIA_SEEK_COMPLETE : MEDIA_PREPARED); 64943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber} 65043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber 65184333e0475bc911adc16417f4ca327c975cf6c36Andreas Huberstatus_t NuPlayerDriver::dump( 65284333e0475bc911adc16417f4ca327c975cf6c36Andreas Huber int fd, const Vector<String16> & /* args */) const { 653e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan 654e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan Vector<sp<AMessage> > trackStats; 655e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan mPlayer->getStats(&trackStats); 6563fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 6573a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan AString logString(" NuPlayer\n"); 6583a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan char buf[256] = {0}; 6593fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 660e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan for (size_t i = 0; i < trackStats.size(); ++i) { 661e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan const sp<AMessage> &stats = trackStats.itemAt(i); 662e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan 663e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan AString mime; 664e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan if (stats->findString("mime", &mime)) { 6653a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan snprintf(buf, sizeof(buf), " mime(%s)\n", mime.c_str()); 6663a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan logString.append(buf); 667e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan } 668e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan 669e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan AString name; 670e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan if (stats->findString("component-name", &name)) { 6713a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan snprintf(buf, sizeof(buf), " decoder(%s)\n", name.c_str()); 6723a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan logString.append(buf); 673e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan } 6743fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 675e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan if (mime.startsWith("video/")) { 676e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan int32_t width, height; 677e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan if (stats->findInt32("width", &width) 678e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan && stats->findInt32("height", &height)) { 6793a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan snprintf(buf, sizeof(buf), " resolution(%d x %d)\n", width, height); 6803a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan logString.append(buf); 681e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan } 682e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan 683e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan int64_t numFramesTotal = 0; 684e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan int64_t numFramesDropped = 0; 685e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan 686e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan stats->findInt64("frames-total", &numFramesTotal); 687e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan stats->findInt64("frames-dropped-output", &numFramesDropped); 6883a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan snprintf(buf, sizeof(buf), " numFramesTotal(%lld), numFramesDropped(%lld), " 689e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan "percentageDropped(%.2f%%)\n", 690e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan (long long)numFramesTotal, 691e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan (long long)numFramesDropped, 692e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan numFramesTotal == 0 693e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan ? 0.0 : (double)(numFramesDropped * 100) / numFramesTotal); 6943a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan logString.append(buf); 695e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan } 696e1e5d7a3d3d4d6d644e6c731f977422e004140d5Praveen Chavan } 6973a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan 6983a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan ALOGI("%s", logString.c_str()); 6993a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan 7003a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan if (fd >= 0) { 7013a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan FILE *out = fdopen(dup(fd), "w"); 7023a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan fprintf(out, "%s", logString.c_str()); 7033a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan fclose(out); 7043a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan out = NULL; 7053a20d29ff09ca2568cb904415625cc44db37edb0Praveen Chavan } 7063fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 7073fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber return OK; 7083fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber} 7093fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber 710dcb89b3b505522efde173c105a851c412f947178Chong Zhangvoid NuPlayerDriver::notifyListener( 711dcb89b3b505522efde173c105a851c412f947178Chong Zhang int msg, int ext1, int ext2, const Parcel *in) { 7120560195a71ee26e8546075e56c49ff535fcf1767Wei Jia Mutex::Autolock autoLock(mLock); 7130560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(msg, ext1, ext2, in); 7140560195a71ee26e8546075e56c49ff535fcf1767Wei Jia} 7150560195a71ee26e8546075e56c49ff535fcf1767Wei Jia 7160560195a71ee26e8546075e56c49ff535fcf1767Wei Jiavoid NuPlayerDriver::notifyListener_l( 7170560195a71ee26e8546075e56c49ff535fcf1767Wei Jia int msg, int ext1, int ext2, const Parcel *in) { 718f3c2b3df8bf616ad593e2c0101b04a718f291827Wei Jia ALOGD("notifyListener_l(%p), (%d, %d, %d), loop setting(%d, %d)", 719f3c2b3df8bf616ad593e2c0101b04a718f291827Wei Jia this, msg, ext1, ext2, mAutoLoop, mLooping); 720a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar switch (msg) { 721a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar case MEDIA_PLAYBACK_COMPLETE: 722a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar { 72371079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia if (mState != STATE_RESET_IN_PROGRESS) { 724707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (mAutoLoop) { 725707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen audio_stream_type_t streamType = AUDIO_STREAM_MUSIC; 726707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (mAudioSink != NULL) { 727707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen streamType = mAudioSink->getAudioStreamType(); 728707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 729707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen if (streamType == AUDIO_STREAM_NOTIFICATION) { 730707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen ALOGW("disabling auto-loop for notification"); 731707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen mAutoLoop = false; 732707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 733707eadef2ad1388bafdb2d003a4169208fa99811Marco Nelissen } 734b7848f1c442bc8c71020957948d1b003a62a25b7Marco Nelissen if (mLooping || mAutoLoop) { 73571079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mPlayer->seekToAsync(0); 736368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen if (mAudioSink != NULL) { 737368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen // The renderer has stopped the sink at the end in order to play out 738368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen // the last little bit of audio. If we're looping, we need to restart it. 739368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen mAudioSink->start(); 740368e33700ed16acc8e99657fb84edd5d2806b34fMarco Nelissen } 7410e4bd4db6072472de7b7fca7c91f8ac854b2d24cMarco Nelissen // don't send completion event when looping 7420e4bd4db6072472de7b7fca7c91f8ac854b2d24cMarco Nelissen return; 74371079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia } 74471079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia 74571079fc29d93fb49d6022397b6d4168b7fba6e9bWei Jia mPlayer->pause(); 74618def1b8b8cdc91695ebb75bb392a84bb1b9c9beLajos Molnar mState = STATE_PAUSED; 747a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 748a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar // fall through 749c6993231c56da1924ba8d67eb150fa953ba54a1bMarco Nelissen } 750a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar 751a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar case MEDIA_ERROR: 752a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar { 753a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar mAtEOS = true; 754a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar break; 755a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar } 756a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar 757a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar default: 758a2e14302d4b5ca5443611d0c05218b9da4cc64a6Lajos Molnar break; 759a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber } 760a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber 7610560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mLock.unlock(); 762dcb89b3b505522efde173c105a851c412f947178Chong Zhang sendEvent(msg, ext1, ext2, in); 7630560195a71ee26e8546075e56c49ff535fcf1767Wei Jia mLock.lock(); 764a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber} 765a4af2143ecbd630e946647c1b5f90fda8f61ebb3Andreas Huber 7669575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifySetDataSourceCompleted(status_t err) { 7679575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 7689575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7699575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_SET_DATASOURCE_PENDING); 7709575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7719575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult = err; 7729575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mState = (err == OK) ? STATE_UNPREPARED : STATE_IDLE; 7739575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.broadcast(); 7749575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 7759575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7769575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifyPrepareCompleted(status_t err) { 7779575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 7789575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 779b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber if (mState != STATE_PREPARING) { 780b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // We were preparing asynchronously when the client called 781b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // reset(), we sent a premature "prepared" notification and 782b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber // then initiated the reset. This notification is stale. 783b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber CHECK(mState == STATE_RESET_IN_PROGRESS || mState == STATE_IDLE); 784b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber return; 785b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber } 786b5f28d4749b898d92fe5e56236b417e37b6fe84fAndreas Huber 7879575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber CHECK_EQ(mState, STATE_PREPARING); 7889575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7899575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mAsyncResult = err; 7909575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 7919575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber if (err == OK) { 7922a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen // update state before notifying client, so that if client calls back into NuPlayerDriver 7932a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen // in response, NuPlayerDriver has the right state 7942a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_PREPARED; 795ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber if (mIsAsyncPrepare) { 7960560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_PREPARED); 797ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber } 7989575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } else { 7992a79c3274e11b91675a509e16cb3b157df141facMarco Nelissen mState = STATE_UNPREPARED; 800ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber if (mIsAsyncPrepare) { 8010560195a71ee26e8546075e56c49ff535fcf1767Wei Jia notifyListener_l(MEDIA_ERROR, MEDIA_ERROR_UNKNOWN, err); 802ec0c597cabf169ca646bcea5faac1bd81ed4484dAndreas Huber } 8039575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber } 8049575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 805f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen sp<MetaData> meta = mPlayer->getFileMeta(); 806f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen int32_t loop; 807f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen if (meta != NULL 808f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen && meta->findInt32(kKeyAutoLoop, &loop) && loop != 0) { 809f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen mAutoLoop = true; 810f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen } 811f0b72b509ab1147a2a0925aced970dd68fd7fa4fMarco Nelissen 8129575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mCondition.broadcast(); 8139575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 8149575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 8159575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Hubervoid NuPlayerDriver::notifyFlagsChanged(uint32_t flags) { 8169575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber Mutex::Autolock autoLock(mLock); 8179575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 8189575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber mPlayerFlags = flags; 8199575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber} 8209575c96b6e418914e2ffc6741ecc8d71e3968dbeAndreas Huber 821f933441648ef6a71dee783d733aac17b9508b452Andreas Huber} // namespace android 822