mediaplayer.cpp revision 7562408b2261d38415453378b6188f74fda99d88
189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project/* mediaplayer.cpp 289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** 389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** Copyright 2006, The Android Open Source Project 489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** 589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** Licensed under the Apache License, Version 2.0 (the "License"); 689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** you may not use this file except in compliance with the License. 789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** You may obtain a copy of the License at 889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** 989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** http://www.apache.org/licenses/LICENSE-2.0 1089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** 1189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** Unless required by applicable law or agreed to in writing, software 1289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** distributed under the License is distributed on an "AS IS" BASIS, 1389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** See the License for the specific language governing permissions and 1589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** limitations under the License. 1689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project*/ 1789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 1889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project//#define LOG_NDEBUG 0 1989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define LOG_TAG "MediaPlayer" 2089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <utils/Log.h> 2189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 2289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <sys/types.h> 2389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <sys/stat.h> 2489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <unistd.h> 2589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <fcntl.h> 2689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 277562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/IServiceManager.h> 287562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/IPCThreadState.h> 2989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 3089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <media/mediaplayer.h> 3189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <media/AudioTrack.h> 3289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 337562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/MemoryBase.h> 3489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 3589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectnamespace android { 3689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 3789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// client singleton for binder interface to service 3889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectMutex MediaPlayer::sServiceLock; 3989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectsp<IMediaPlayerService> MediaPlayer::sMediaPlayerService; 4089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectsp<MediaPlayer::DeathNotifier> MediaPlayer::sDeathNotifier; 4189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectSortedVector< wp<MediaPlayer> > MediaPlayer::sObitRecipients; 4289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 4389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// establish binder interface to service 4489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectconst sp<IMediaPlayerService>& MediaPlayer::getMediaPlayerService() 4589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 4689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(sServiceLock); 4789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (sMediaPlayerService.get() == 0) { 4889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IServiceManager> sm = defaultServiceManager(); 4989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IBinder> binder; 5089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project do { 5189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project binder = sm->getService(String16("media.player")); 5289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (binder != 0) 5389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 5489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGW("MediaPlayerService not published, waiting..."); 5589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project usleep(500000); // 0.5 s 5689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } while(true); 5789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (sDeathNotifier == NULL) { 5889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sDeathNotifier = new DeathNotifier(); 5989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 6089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project binder->linkToDeath(sDeathNotifier); 6189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sMediaPlayerService = interface_cast<IMediaPlayerService>(binder); 6289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 6389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE_IF(sMediaPlayerService==0, "no MediaPlayerService!?"); 6489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return sMediaPlayerService; 6589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 6689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 6789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::addObitRecipient(const wp<MediaPlayer>& recipient) 6889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 6989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(sServiceLock); 7089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sObitRecipients.add(recipient); 7189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 7289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 7389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::removeObitRecipient(const wp<MediaPlayer>& recipient) 7489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 7589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(sServiceLock); 7689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sObitRecipients.remove(recipient); 7789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 7889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 7989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectMediaPlayer::MediaPlayer() 8089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 8189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("constructor"); 8289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mListener = NULL; 8389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCookie = NULL; 8489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mDuration = -1; 8589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mStreamType = AudioSystem::MUSIC; 8689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentPosition = -1; 8789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSeekPosition = -1; 8889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_IDLE; 8989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 9089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareStatus = NO_ERROR; 9189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLoop = false; 9289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLeftVolume = mRightVolume = 1.0; 9389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mVideoWidth = mVideoHeight = 0; 941af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = 0; 9589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 9689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 9789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::onFirstRef() 9889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 9989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project addObitRecipient(this); 10089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 10189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 10289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectMediaPlayer::~MediaPlayer() 10389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 10489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("destructor"); 10589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project removeObitRecipient(this); 10689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project disconnect(); 10789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project IPCThreadState::self()->flushCommands(); 10889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 10989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 11089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::disconnect() 11189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 11289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("disconnect"); 11389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMediaPlayer> p; 11489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project { 11589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 11689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p = mPlayer; 11789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer.clear(); 11889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 11989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 12089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (p != 0) { 12189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p->disconnect(); 12289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 12389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 12489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 12589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// always call with lock held 12689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::clear_l() 12789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 12889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mDuration = -1; 12989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentPosition = -1; 13089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSeekPosition = -1; 13189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mVideoWidth = mVideoHeight = 0; 13289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 13389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 13489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setListener(const sp<MediaPlayerListener>& listener) 13589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 13689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("setListener"); 13789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 13889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mListener = listener; 13989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 14089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 14189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 14289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 14389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setDataSource(const sp<IMediaPlayer>& player) 14489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 14589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t err = UNKNOWN_ERROR; 14689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMediaPlayer> p; 14789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project { // scope for the lock 14889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 14989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 15089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( !( mCurrentState & ( MEDIA_PLAYER_IDLE | MEDIA_PLAYER_STATE_ERROR ) ) ) { 15189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("setDataSource called in state %d", mCurrentState); 15289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 15389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 15489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 15589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project clear_l(); 15689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p = mPlayer; 15789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer = player; 15889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (player != 0) { 15989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_INITIALIZED; 16089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project err = NO_ERROR; 16189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 16289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Unable to to create media player"); 16389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 16489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 16589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 16689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (p != 0) { 16789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p->disconnect(); 16889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 16989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 17089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return err; 17189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 17289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 17389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setDataSource(const char *url) 17489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 17589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("setDataSource(%s)", url); 17689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t err = BAD_VALUE; 17789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (url != NULL) { 17889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project const sp<IMediaPlayerService>& service(getMediaPlayerService()); 17989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (service != 0) { 18089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMediaPlayer> player(service->create(getpid(), this, url)); 18189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project err = setDataSource(player); 18289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 18389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 18489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return err; 18589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 18689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 18789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setDataSource(int fd, int64_t offset, int64_t length) 18889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 18989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("setDataSource(%d, %lld, %lld)", fd, offset, length); 19089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t err = UNKNOWN_ERROR; 19189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project const sp<IMediaPlayerService>& service(getMediaPlayerService()); 19289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (service != 0) { 19389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMediaPlayer> player(service->create(getpid(), this, fd, offset, length)); 19489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project err = setDataSource(player); 19589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 19689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return err; 19789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 19889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 19989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setVideoSurface(const sp<Surface>& surface) 20089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 20189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("setVideoSurface"); 20289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 20389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer == 0) return NO_INIT; 20489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->setVideoSurface(surface->getISurface()); 20589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 20689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 20789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// must call with lock held 20889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepareAsync_l() 20989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 21089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( (mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_INITIALIZED | MEDIA_PLAYER_STOPPED) ) ) { 21189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer->setAudioStreamType(mStreamType); 21289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PREPARING; 21389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->prepareAsync(); 21489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 21589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("prepareAsync called in state %d", mCurrentState); 21689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 21789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 21889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 21965e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// TODO: In case of error, prepareAsync provides the caller with 2 error codes, 22065e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// one defined in the Android framework and one provided by the implementation 22165e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// that generated the error. The sync version of prepare returns only 1 error 22265e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// code. 22389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepare() 22489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 22589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("prepare"); 22689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 2271af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = getThreadId(); 2281af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (mPrepareSync) { 2291af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = 0; 2301af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams return -EALREADY; 2311af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams } 23289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = true; 23389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = prepareAsync_l(); 2341af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (ret != NO_ERROR) { 2351af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = 0; 2361af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams return ret; 2371af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams } 23889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 23989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPrepareSync) { 24089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSignal.wait(mLock); // wait for prepare done 24189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 24289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 24389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("prepare complete - status=%d", mPrepareStatus); 2441af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = 0; 24589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPrepareStatus; 24689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 24789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 24889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepareAsync() 24989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 25089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("prepareAsync"); 25189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 25289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return prepareAsync_l(); 25389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 25489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 25589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::start() 25689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 25789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("start"); 25889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 25989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState & MEDIA_PLAYER_STARTED) 26089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 26189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( (mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_PREPARED | 26289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project MEDIA_PLAYER_PLAYBACK_COMPLETE | MEDIA_PLAYER_PAUSED ) ) ) { 26389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer->setLooping(mLoop); 26489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer->setVolume(mLeftVolume, mRightVolume); 26589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STARTED; 26689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = mPlayer->start(); 26789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (ret != NO_ERROR) { 26889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 26989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 27089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState == MEDIA_PLAYER_PLAYBACK_COMPLETE) { 27189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("playback completed immediately following start()"); 27289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 27389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 27489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 27589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 27689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("start called in state %d", mCurrentState); 27789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 27889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 27989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 28089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::stop() 28189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 28289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("stop"); 28389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 28489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState & MEDIA_PLAYER_STOPPED) return NO_ERROR; 28589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( (mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_STARTED | MEDIA_PLAYER_PREPARED | 28689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE ) ) ) { 28789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = mPlayer->stop(); 28889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (ret != NO_ERROR) { 28989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 29089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 29189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STOPPED; 29289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 29389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 29489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 29589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("stop called in state %d", mCurrentState); 29689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 29789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 29889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 29989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::pause() 30089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 30189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("pause"); 30289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 30389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState & MEDIA_PLAYER_PAUSED) 30489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 30589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((mPlayer != 0) && (mCurrentState & MEDIA_PLAYER_STARTED)) { 30689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = mPlayer->pause(); 30789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (ret != NO_ERROR) { 30889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 30989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 31089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PAUSED; 31189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 31289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 31389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 31489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("pause called in state %d", mCurrentState); 31589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 31689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 31789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 31889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectbool MediaPlayer::isPlaying() 31989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 32089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 32189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 32289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project bool temp = false; 32389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer->isPlaying(&temp); 32489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("isPlaying: %d", temp); 32589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((mCurrentState & MEDIA_PLAYER_STARTED) && ! temp) { 32689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("internal/external state mismatch corrected"); 32789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PAUSED; 32889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 32989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return temp; 33089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 33189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("isPlaying: no active player"); 33289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return false; 33389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 33489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 33589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getVideoWidth(int *w) 33689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 33789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("getVideoWidth"); 33889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 33989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer == 0) return INVALID_OPERATION; 34089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *w = mVideoWidth; 34189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 34289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 34389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 34489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getVideoHeight(int *h) 34589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 34689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("getVideoHeight"); 34789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 34889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer == 0) return INVALID_OPERATION; 34989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *h = mVideoHeight; 35089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 35189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 35289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 35389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getCurrentPosition(int *msec) 35489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 35589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("getCurrentPosition"); 35689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 35789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 35889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentPosition >= 0) { 35989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("Using cached seek position: %d", mCurrentPosition); 36089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *msec = mCurrentPosition; 36189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 36289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 36389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->getCurrentPosition(msec); 36489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 36589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 36689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 36789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 36889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getDuration_l(int *msec) 36989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 37089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("getDuration"); 37189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project bool isValidState = (mCurrentState & (MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_STARTED | MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_STOPPED | MEDIA_PLAYER_PLAYBACK_COMPLETE)); 37289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0 && isValidState) { 37389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = NO_ERROR; 37489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mDuration <= 0) 37589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project ret = mPlayer->getDuration(&mDuration); 37689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (msec) 37789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *msec = mDuration; 37889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 37989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 38089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Attempt to call getDuration without a valid mediaplayer"); 38189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 38289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 38389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 38489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getDuration(int *msec) 38589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 38689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 38789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return getDuration_l(msec); 38889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 38989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 39089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::seekTo_l(int msec) 39189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 39289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("seekTo %d", msec); 39389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_STARTED | MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE) ) ) { 39489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( msec < 0 ) { 39589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGW("Attempt to seek to invalid position: %d", msec); 39689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project msec = 0; 39789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else if ((mDuration > 0) && (msec > mDuration)) { 39889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGW("Attempt to seek to past end of file: request = %d, EOF = %d", msec, mDuration); 39989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project msec = mDuration; 40089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 40189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // cache duration 40289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentPosition = msec; 40389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mSeekPosition < 0) { 40489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project getDuration_l(NULL); 40589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSeekPosition = msec; 40689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->seekTo(msec); 40789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 40889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project else { 40989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("Seek in progress - queue up seekTo[%d]", msec); 41089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 41189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 41289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 41389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Attempt to perform seekTo in wrong state: mPlayer=%p, mCurrentState=%u", mPlayer.get(), mCurrentState); 41489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 41589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 41689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 41789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::seekTo(int msec) 41889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 4195cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber mLockThreadId = getThreadId(); 42089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 4215cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber status_t result = seekTo_l(msec); 4225cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber mLockThreadId = 0; 4235cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber 4245cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber return result; 42589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 42689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 42789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::reset() 42889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 42989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("reset"); 43089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 43189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLoop = false; 43289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState == MEDIA_PLAYER_IDLE) return NO_ERROR; 43389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 43489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 43589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = mPlayer->reset(); 43689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (ret != NO_ERROR) { 43789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("reset() failed with return code (%d)", ret); 43889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 43989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 44089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_IDLE; 44189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 44289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 44389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 44489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project clear_l(); 44589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 44689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 44789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 44889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setAudioStreamType(int type) 44989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 45089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("MediaPlayer::setAudioStreamType"); 45189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 45289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mStreamType == type) return NO_ERROR; 45389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState & ( MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_STARTED | 45489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE ) ) { 45589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // Can't change the stream type after prepare 45689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("setAudioStream called in state %d", mCurrentState); 45789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 45889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 45989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // cache 46089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mStreamType = type; 46189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return OK; 46289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 46389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 46489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setLooping(int loop) 46589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 46689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("MediaPlayer::setLooping"); 46789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 46889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLoop = (loop != 0); 46989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 47089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->setLooping(loop); 47189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 47289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return OK; 47389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 47489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 47589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectbool MediaPlayer::isLooping() { 47689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("isLooping"); 47789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 47889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 47989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mLoop; 48089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 48189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("isLooping: no active player"); 48289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return false; 48389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 48489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 48589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setVolume(float leftVolume, float rightVolume) 48689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 48789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("MediaPlayer::setVolume(%f, %f)", leftVolume, rightVolume); 48889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 48989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLeftVolume = leftVolume; 49089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mRightVolume = rightVolume; 49189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 49289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->setVolume(leftVolume, rightVolume); 49389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 49489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return OK; 49589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 49689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 49789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::notify(int msg, int ext1, int ext2) 49889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 49989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("message received msg=%d, ext1=%d, ext2=%d", msg, ext1, ext2); 50089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project bool send = true; 5011af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams bool locked = false; 50289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 50389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // TODO: In the future, we might be on the same thread if the app is 50489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // running in the same process as the media server. In that case, 50589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // this will deadlock. 5061af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams // 5071af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams // The threadId hack below works around this for the care of prepare 5085cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber // and seekTo within the same process. 5095cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber // FIXME: Remember, this is a hack, it's not even a hack that is applied 5105cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber // consistently for all use-cases, this needs to be revisited. 5111af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (mLockThreadId != getThreadId()) { 5121af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLock.lock(); 5131af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams locked = true; 5141af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams } 5151af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams 51689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer == 0) { 51789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("notify(%d, %d, %d) callback on disconnected mediaplayer", msg, ext1, ext2); 5181af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (locked) mLock.unlock(); // release the lock when done. 51989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return; 52089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 52189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 52289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project switch (msg) { 52389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_NOP: // interface test message 52489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 52589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_PREPARED: 52689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("prepared"); 52789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PREPARED; 52889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPrepareSync) { 52989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("signal application thread"); 53089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 53189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareStatus = NO_ERROR; 53289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSignal.signal(); 53389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 53489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 53589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_PLAYBACK_COMPLETE: 53689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("playback complete"); 53789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (!mLoop) { 53889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PLAYBACK_COMPLETE; 53989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 54089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 54189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_ERROR: 54265e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // Always log errors. 54365e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // ext1: Media framework error code. 54465e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // ext2: Implementation dependant error code. 54589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("error (%d, %d)", ext1, ext2); 54689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 54789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPrepareSync) 54889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project { 54989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("signal application thread"); 55089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 55189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareStatus = ext1; 55289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSignal.signal(); 55389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project send = false; 55489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 55589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 55665e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project case MEDIA_INFO: 55765e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // ext1: Media framework error code. 55865e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // ext2: Implementation dependant error code. 55965e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project LOGW("info/warning (%d, %d)", ext1, ext2); 56065e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project break; 56189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_SEEK_COMPLETE: 56289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("Received seek complete"); 56389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mSeekPosition != mCurrentPosition) { 56489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("Executing queued seekTo(%d)", mSeekPosition); 56589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSeekPosition = -1; 56689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project seekTo_l(mCurrentPosition); 56789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 56889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project else { 56989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("All seeks complete - return to regularly scheduled program"); 57089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentPosition = mSeekPosition = -1; 57189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 57289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 57389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_BUFFERING_UPDATE: 57489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("buffering %d", ext1); 57589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 57689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_SET_VIDEO_SIZE: 57789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("New video size %d x %d", ext1, ext2); 57889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mVideoWidth = ext1; 57989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mVideoHeight = ext2; 58089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 58189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project default: 58289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("unrecognized message: (%d, %d, %d)", msg, ext1, ext2); 58389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 58489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 58589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 58689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<MediaPlayerListener> listener = mListener; 5871af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (locked) mLock.unlock(); 58889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 58989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // this prevents re-entrant calls into client code 59089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((listener != 0) && send) { 59189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mNotifyLock); 59289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("callback application"); 59389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project listener->notify(msg, ext1, ext2); 59489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("back from callback"); 59589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 59689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 59789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 59889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::DeathNotifier::binderDied(const wp<IBinder>& who) { 59989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGW("MediaPlayer server died!"); 60089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 60189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // Need to do this with the lock held 60289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project SortedVector< wp<MediaPlayer> > list; 60389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project { 60489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(MediaPlayer::sServiceLock); 60589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project MediaPlayer::sMediaPlayerService.clear(); 60689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project list = sObitRecipients; 60789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 60889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 60989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // Notify application when media server dies. 61089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // Don't hold the static lock during callback in case app 61189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // makes a call that needs the lock. 61289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project size_t count = list.size(); 61389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project for (size_t iter = 0; iter < count; ++iter) { 61489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<MediaPlayer> player = list[iter].promote(); 61589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((player != 0) && (player->mPlayer != 0)) { 61689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project player->notify(MEDIA_ERROR, MEDIA_ERROR_SERVER_DIED, 0); 61789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 61889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 61989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 62089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 62189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectMediaPlayer::DeathNotifier::~DeathNotifier() 62289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 62389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(sServiceLock); 62489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sObitRecipients.clear(); 62589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (sMediaPlayerService != 0) { 62689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sMediaPlayerService->asBinder()->unlinkToDeath(this); 62789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 62889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 62989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 63089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project/*static*/ sp<IMemory> MediaPlayer::decode(const char* url, uint32_t *pSampleRate, int* pNumChannels, int* pFormat) 63189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 63289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("decode(%s)", url); 63389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMemory> p; 63489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project const sp<IMediaPlayerService>& service = getMediaPlayerService(); 63589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (service != 0) { 63689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p = sMediaPlayerService->decode(url, pSampleRate, pNumChannels, pFormat); 63789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 63889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Unable to locate media service"); 63989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 64089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return p; 64189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 64289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 64389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 64489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project/*static*/ sp<IMemory> MediaPlayer::decode(int fd, int64_t offset, int64_t length, uint32_t *pSampleRate, int* pNumChannels, int* pFormat) 64589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 64689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("decode(%d, %lld, %lld)", fd, offset, length); 64789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMemory> p; 64889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project const sp<IMediaPlayerService>& service = getMediaPlayerService(); 64989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (service != 0) { 65089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p = sMediaPlayerService->decode(fd, offset, length, pSampleRate, pNumChannels, pFormat); 65189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 65289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Unable to locate media service"); 65389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 65489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return p; 65589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 65689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 65789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 65889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}; // namespace android 659