mediaplayer.cpp revision b187de1ada34a9023c05d020a4592686ba761278
199e53b86eebb605b70dd7591b89bf61a9414ed0eGlenn Kasten/*
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
2134fb29696b0f3abf61b10f8d053b1f33d501de0aMark Salyzyn#include <fcntl.h>
2234fb29696b0f3abf61b10f8d053b1f33d501de0aMark Salyzyn#include <inttypes.h>
2389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <sys/stat.h>
2434fb29696b0f3abf61b10f8d053b1f33d501de0aMark Salyzyn#include <sys/types.h>
2589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <unistd.h>
2634fb29696b0f3abf61b10f8d053b1f33d501de0aMark Salyzyn
2734fb29696b0f3abf61b10f8d053b1f33d501de0aMark Salyzyn#include <utils/Log.h>
2889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
297562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/IServiceManager.h>
307562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/IPCThreadState.h>
3189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
32b1e7cd156ca3e1747374e0d20cdd1ce467210453Mathias Agopian#include <gui/Surface.h>
3361c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennis
3489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <media/mediaplayer.h>
35a3f1fa308728976fc9ca1b4f37d26e633b32b9acGlenn Kasten#include <media/AudioSystem.h>
3689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
377562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/MemoryBase.h>
3889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
392db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber#include <utils/KeyedVector.h>
402db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber#include <utils/String8.h>
412db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber
4264760240f931714858a59c1579f07264d7182ba2Dima Zavin#include <system/audio.h>
4361c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennis#include <system/window.h>
44fce7a473248381cc83a01855f92581077d3c9ee2Dima Zavin
4589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectnamespace android {
4689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
4789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectMediaPlayer::MediaPlayer()
4889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
493856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("constructor");
5089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mListener = NULL;
5189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mCookie = NULL;
52fce7a473248381cc83a01855f92581077d3c9ee2Dima Zavin    mStreamType = AUDIO_STREAM_MUSIC;
53640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi    mAudioAttributesParcel = NULL;
5489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mCurrentPosition = -1;
5589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mSeekPosition = -1;
5689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mCurrentState = MEDIA_PLAYER_IDLE;
5789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mPrepareSync = false;
5889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mPrepareStatus = NO_ERROR;
5989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mLoop = false;
6089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mLeftVolume = mRightVolume = 1.0;
6189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mVideoWidth = mVideoHeight = 0;
621af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    mLockThreadId = 0;
63de3f8392fbf380ba6f09d009b00d7172477389a2Eric Laurent    mAudioSessionId = AudioSystem::newAudioUniqueId();
64d457c970c8d08519cd77280a90b61ae1e342cfe3Marco Nelissen    AudioSystem::acquireAudioSessionId(mAudioSessionId, -1);
658c563ed9ca8a863a66965330b5d14bb4b4ab59d4Eric Laurent    mSendLevel = 0;
66c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    mRetransmitEndpointValid = false;
6789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
6889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
6989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectMediaPlayer::~MediaPlayer()
7089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
713856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("destructor");
72640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi    if (mAudioAttributesParcel != NULL) {
73640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        delete mAudioAttributesParcel;
74640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        mAudioAttributesParcel = NULL;
75640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi    }
76d457c970c8d08519cd77280a90b61ae1e342cfe3Marco Nelissen    AudioSystem::releaseAudioSessionId(mAudioSessionId, -1);
7789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    disconnect();
7889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    IPCThreadState::self()->flushCommands();
7989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
8089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
8189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::disconnect()
8289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
833856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("disconnect");
8489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    sp<IMediaPlayer> p;
8589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    {
8689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        Mutex::Autolock _l(mLock);
8789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        p = mPlayer;
8889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mPlayer.clear();
8989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
9089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
9189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (p != 0) {
9289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        p->disconnect();
9389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
9489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
9589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
9689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// always call with lock held
9789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::clear_l()
9889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
9989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mCurrentPosition = -1;
10089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mSeekPosition = -1;
10189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mVideoWidth = mVideoHeight = 0;
102c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    mRetransmitEndpointValid = false;
10389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
10489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
10589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setListener(const sp<MediaPlayerListener>& listener)
10689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
1073856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("setListener");
10889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
10989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mListener = listener;
11089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return NO_ERROR;
11189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
11289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
11389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
114d681bbb1767bed09415e050ba78975df214bcd68Dave Burkestatus_t MediaPlayer::attachNewPlayer(const sp<IMediaPlayer>& player)
11589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
11689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    status_t err = UNKNOWN_ERROR;
11789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    sp<IMediaPlayer> p;
11889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    { // scope for the lock
11989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        Mutex::Autolock _l(mLock);
12089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
12183ff1438d2d1d5dbf39ca5e6f2e4fa1799e7ba80Marco Nelissen        if ( !( (mCurrentState & MEDIA_PLAYER_IDLE) ||
12283ff1438d2d1d5dbf39ca5e6f2e4fa1799e7ba80Marco Nelissen                (mCurrentState == MEDIA_PLAYER_STATE_ERROR ) ) ) {
12329357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block            ALOGE("attachNewPlayer called in state %d", mCurrentState);
12489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            return INVALID_OPERATION;
12589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
12689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
12789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        clear_l();
12889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        p = mPlayer;
12989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mPlayer = player;
13089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (player != 0) {
13189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_INITIALIZED;
13289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            err = NO_ERROR;
13389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        } else {
134f65fa170b28f97503df3c309ecdaab377a042ba6Masaki Muranaka            ALOGE("Unable to create media player");
13589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
13689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
13789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
13889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (p != 0) {
13989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        p->disconnect();
14089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
14189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
14289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return err;
14389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
14489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
1452db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huberstatus_t MediaPlayer::setDataSource(
1461b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        const sp<IMediaHTTPService> &httpService,
1472db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber        const char *url, const KeyedVector<String8, String8> *headers)
14889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
1493856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("setDataSource(%s)", url);
15089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    status_t err = BAD_VALUE;
15189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (url != NULL) {
15289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        const sp<IMediaPlayerService>& service(getMediaPlayerService());
15389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (service != 0) {
154f37971f624164c3ed185d3f976404a6f60f49b9aGlenn Kasten            sp<IMediaPlayer> player(service->create(this, mAudioSessionId));
155c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman            if ((NO_ERROR != doSetRetransmitEndpoint(player)) ||
1561b86fe063badb5f28c467ade39be0f4008688947Andreas Huber                (NO_ERROR != player->setDataSource(httpService, url, headers))) {
1570662067b06658a4a56a8416c676f6cce8ccddb53Dave Burke                player.clear();
158d681bbb1767bed09415e050ba78975df214bcd68Dave Burke            }
1590662067b06658a4a56a8416c676f6cce8ccddb53Dave Burke            err = attachNewPlayer(player);
16089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
16189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
16289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return err;
16389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
16489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
16589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setDataSource(int fd, int64_t offset, int64_t length)
16689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
16734fb29696b0f3abf61b10f8d053b1f33d501de0aMark Salyzyn    ALOGV("setDataSource(%d, %" PRId64 ", %" PRId64 ")", fd, offset, length);
16889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    status_t err = UNKNOWN_ERROR;
16989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    const sp<IMediaPlayerService>& service(getMediaPlayerService());
17089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (service != 0) {
171f37971f624164c3ed185d3f976404a6f60f49b9aGlenn Kasten        sp<IMediaPlayer> player(service->create(this, mAudioSessionId));
172c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman        if ((NO_ERROR != doSetRetransmitEndpoint(player)) ||
173c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman            (NO_ERROR != player->setDataSource(fd, offset, length))) {
1740662067b06658a4a56a8416c676f6cce8ccddb53Dave Burke            player.clear();
175d681bbb1767bed09415e050ba78975df214bcd68Dave Burke        }
1760662067b06658a4a56a8416c676f6cce8ccddb53Dave Burke        err = attachNewPlayer(player);
177d681bbb1767bed09415e050ba78975df214bcd68Dave Burke    }
178d681bbb1767bed09415e050ba78975df214bcd68Dave Burke    return err;
179d681bbb1767bed09415e050ba78975df214bcd68Dave Burke}
180d681bbb1767bed09415e050ba78975df214bcd68Dave Burke
181d681bbb1767bed09415e050ba78975df214bcd68Dave Burkestatus_t MediaPlayer::setDataSource(const sp<IStreamSource> &source)
182d681bbb1767bed09415e050ba78975df214bcd68Dave Burke{
1833856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("setDataSource");
184d681bbb1767bed09415e050ba78975df214bcd68Dave Burke    status_t err = UNKNOWN_ERROR;
185d681bbb1767bed09415e050ba78975df214bcd68Dave Burke    const sp<IMediaPlayerService>& service(getMediaPlayerService());
186d681bbb1767bed09415e050ba78975df214bcd68Dave Burke    if (service != 0) {
187f37971f624164c3ed185d3f976404a6f60f49b9aGlenn Kasten        sp<IMediaPlayer> player(service->create(this, mAudioSessionId));
188c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman        if ((NO_ERROR != doSetRetransmitEndpoint(player)) ||
189c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman            (NO_ERROR != player->setDataSource(source))) {
1900662067b06658a4a56a8416c676f6cce8ccddb53Dave Burke            player.clear();
191d681bbb1767bed09415e050ba78975df214bcd68Dave Burke        }
1920662067b06658a4a56a8416c676f6cce8ccddb53Dave Burke        err = attachNewPlayer(player);
19389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
19489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return err;
19589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
19689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
1971d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Cataniastatus_t MediaPlayer::invoke(const Parcel& request, Parcel *reply)
1981d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania{
1991d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    Mutex::Autolock _l(mLock);
2004023493a827bc9751d8e40795516d0d536a53348Nicolas Catania    const bool hasBeenInitialized =
2014023493a827bc9751d8e40795516d0d536a53348Nicolas Catania            (mCurrentState != MEDIA_PLAYER_STATE_ERROR) &&
2024023493a827bc9751d8e40795516d0d536a53348Nicolas Catania            ((mCurrentState & MEDIA_PLAYER_IDLE) != MEDIA_PLAYER_IDLE);
2034023493a827bc9751d8e40795516d0d536a53348Nicolas Catania    if ((mPlayer != NULL) && hasBeenInitialized) {
20434fb29696b0f3abf61b10f8d053b1f33d501de0aMark Salyzyn        ALOGV("invoke %zu", request.dataSize());
205e53b9ead781c36e96d6b6f012ddffc93a3d80f0dGlenn Kasten        return  mPlayer->invoke(request, reply);
2061d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    }
20729357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block    ALOGE("invoke failed: wrong state %X", mCurrentState);
2081d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    return INVALID_OPERATION;
2091d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania}
2101d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania
211a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Cataniastatus_t MediaPlayer::setMetadataFilter(const Parcel& filter)
212a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania{
213b8a805261bf0282e992d3608035e47d05a898710Steve Block    ALOGD("setMetadataFilter");
2148e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania    Mutex::Autolock lock(mLock);
2158e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania    if (mPlayer == NULL) {
216a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania        return NO_INIT;
217a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania    }
218a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania    return mPlayer->setMetadataFilter(filter);
219a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania}
2201d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania
2218e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Cataniastatus_t MediaPlayer::getMetadata(bool update_only, bool apply_filter, Parcel *metadata)
2228e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania{
223b8a805261bf0282e992d3608035e47d05a898710Steve Block    ALOGD("getMetadata");
2248e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania    Mutex::Autolock lock(mLock);
2258e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania    if (mPlayer == NULL) {
2268e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania        return NO_INIT;
2278e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania    }
2288e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania    return mPlayer->getMetadata(update_only, apply_filter, metadata);
2298e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania}
2308e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania
2311173118eace0e9e347cb007f0da817cee87579edGlenn Kastenstatus_t MediaPlayer::setVideoSurfaceTexture(
232484566c410afdfbc4b6bc5aa1732aef37428a5b8Andy McFadden        const sp<IGraphicBufferProducer>& bufferProducer)
2331173118eace0e9e347cb007f0da817cee87579edGlenn Kasten{
2343856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("setVideoSurfaceTexture");
2351173118eace0e9e347cb007f0da817cee87579edGlenn Kasten    Mutex::Autolock _l(mLock);
2361173118eace0e9e347cb007f0da817cee87579edGlenn Kasten    if (mPlayer == 0) return NO_INIT;
237484566c410afdfbc4b6bc5aa1732aef37428a5b8Andy McFadden    return mPlayer->setVideoSurfaceTexture(bufferProducer);
2381173118eace0e9e347cb007f0da817cee87579edGlenn Kasten}
2391173118eace0e9e347cb007f0da817cee87579edGlenn Kasten
24089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// must call with lock held
24189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepareAsync_l()
24289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
243b187de1ada34a9023c05d020a4592686ba761278Glenn Kasten    if ( (mPlayer != 0) && ( mCurrentState & (MEDIA_PLAYER_INITIALIZED | MEDIA_PLAYER_STOPPED) ) ) {
24489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mPlayer->setAudioStreamType(mStreamType);
245640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        if (mAudioAttributesParcel != NULL) {
246640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi            mPlayer->setParameter(KEY_PARAMETER_AUDIO_ATTRIBUTES, *mAudioAttributesParcel);
247640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        }
24889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mCurrentState = MEDIA_PLAYER_PREPARING;
24989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return mPlayer->prepareAsync();
25089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
25129357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block    ALOGE("prepareAsync called in state %d", mCurrentState);
25289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return INVALID_OPERATION;
25389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
25489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
25565e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// TODO: In case of error, prepareAsync provides the caller with 2 error codes,
25665e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// one defined in the Android framework and one provided by the implementation
25765e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// that generated the error. The sync version of prepare returns only 1 error
25865e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// code.
25989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepare()
26089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
2613856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("prepare");
26289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
2631af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    mLockThreadId = getThreadId();
2641af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    if (mPrepareSync) {
2651af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams        mLockThreadId = 0;
2661af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams        return -EALREADY;
2671af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    }
26889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mPrepareSync = true;
26989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    status_t ret = prepareAsync_l();
2701af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    if (ret != NO_ERROR) {
2711af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams        mLockThreadId = 0;
2721af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams        return ret;
2731af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    }
27489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
27589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPrepareSync) {
27689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mSignal.wait(mLock);  // wait for prepare done
27789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mPrepareSync = false;
27889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
2793856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("prepare complete - status=%d", mPrepareStatus);
2801af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    mLockThreadId = 0;
28189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return mPrepareStatus;
28289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
28389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
28489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepareAsync()
28589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
2863856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("prepareAsync");
28789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
28889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return prepareAsync_l();
28989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
29089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
29189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::start()
29289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
2933856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("start");
294d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang
295d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    status_t ret = NO_ERROR;
29689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
297d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang
298d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    mLockThreadId = getThreadId();
299d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang
300d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    if (mCurrentState & MEDIA_PLAYER_STARTED) {
301d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang        ret = NO_ERROR;
302d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    } else if ( (mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_PREPARED |
30389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                    MEDIA_PLAYER_PLAYBACK_COMPLETE | MEDIA_PLAYER_PAUSED ) ) ) {
30489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mPlayer->setLooping(mLoop);
30589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mPlayer->setVolume(mLeftVolume, mRightVolume);
3062beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent        mPlayer->setAuxEffectSendLevel(mSendLevel);
30789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mCurrentState = MEDIA_PLAYER_STARTED;
308d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang        ret = mPlayer->start();
30989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (ret != NO_ERROR) {
31089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_STATE_ERROR;
31189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        } else {
31289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            if (mCurrentState == MEDIA_PLAYER_PLAYBACK_COMPLETE) {
3133856b090cd04ba5dd4a59a12430ed724d5995909Steve Block                ALOGV("playback completed immediately following start()");
31489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            }
31589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
316d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    } else {
317d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang        ALOGE("start called in state %d", mCurrentState);
318d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang        ret = INVALID_OPERATION;
31989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
320d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang
321d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    mLockThreadId = 0;
322d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang
323d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    return ret;
32489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
32589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
32689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::stop()
32789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
3283856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("stop");
32989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
33089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mCurrentState & MEDIA_PLAYER_STOPPED) return NO_ERROR;
33189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if ( (mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_STARTED | MEDIA_PLAYER_PREPARED |
33289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                    MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE ) ) ) {
33389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        status_t ret = mPlayer->stop();
33489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (ret != NO_ERROR) {
33589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_STATE_ERROR;
33689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        } else {
33789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_STOPPED;
33889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
33989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return ret;
34089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
34129357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block    ALOGE("stop called in state %d", mCurrentState);
34289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return INVALID_OPERATION;
34389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
34489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
34589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::pause()
34689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
3473856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("pause");
34889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
349698f476590bc9e38d4d1d4155da9efdbedd357c4Marco Nelissen    if (mCurrentState & (MEDIA_PLAYER_PAUSED|MEDIA_PLAYER_PLAYBACK_COMPLETE))
35089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return NO_ERROR;
35189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if ((mPlayer != 0) && (mCurrentState & MEDIA_PLAYER_STARTED)) {
35289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        status_t ret = mPlayer->pause();
35389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (ret != NO_ERROR) {
35489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_STATE_ERROR;
35589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        } else {
35689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_PAUSED;
35789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
35889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return ret;
35989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
36029357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block    ALOGE("pause called in state %d", mCurrentState);
36189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return INVALID_OPERATION;
36289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
36389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
36489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectbool MediaPlayer::isPlaying()
36589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
36689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
36789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer != 0) {
36889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        bool temp = false;
36989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mPlayer->isPlaying(&temp);
3703856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("isPlaying: %d", temp);
37189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if ((mCurrentState & MEDIA_PLAYER_STARTED) && ! temp) {
37229357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block            ALOGE("internal/external state mismatch corrected");
37389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_PAUSED;
37489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
37589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return temp;
37689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
3773856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("isPlaying: no active player");
37889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return false;
37989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
38089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
38189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getVideoWidth(int *w)
38289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
3833856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("getVideoWidth");
38489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
38589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer == 0) return INVALID_OPERATION;
38689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    *w = mVideoWidth;
38789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return NO_ERROR;
38889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
38989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
39089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getVideoHeight(int *h)
39189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
3923856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("getVideoHeight");
39389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
39489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer == 0) return INVALID_OPERATION;
39589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    *h = mVideoHeight;
39689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return NO_ERROR;
39789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
39889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
39989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getCurrentPosition(int *msec)
40089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
4013856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("getCurrentPosition");
40289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
40389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer != 0) {
40489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (mCurrentPosition >= 0) {
4053856b090cd04ba5dd4a59a12430ed724d5995909Steve Block            ALOGV("Using cached seek position: %d", mCurrentPosition);
40689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            *msec = mCurrentPosition;
40789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            return NO_ERROR;
40889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
40989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return mPlayer->getCurrentPosition(msec);
41089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
41189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return INVALID_OPERATION;
41289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
41389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
41489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getDuration_l(int *msec)
41589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
416a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber    ALOGV("getDuration_l");
417b187de1ada34a9023c05d020a4592686ba761278Glenn Kasten    bool isValidState = (mCurrentState & (MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_STARTED |
418b187de1ada34a9023c05d020a4592686ba761278Glenn Kasten            MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_STOPPED | MEDIA_PLAYER_PLAYBACK_COMPLETE));
41989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer != 0 && isValidState) {
420a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        int durationMs;
421a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        status_t ret = mPlayer->getDuration(&durationMs);
4222070254f241f52cadb69bc2323f56df72704f1caAndreas Huber
4232070254f241f52cadb69bc2323f56df72704f1caAndreas Huber        if (ret != OK) {
4242070254f241f52cadb69bc2323f56df72704f1caAndreas Huber            // Do not enter error state just because no duration was available.
4252070254f241f52cadb69bc2323f56df72704f1caAndreas Huber            durationMs = -1;
4262070254f241f52cadb69bc2323f56df72704f1caAndreas Huber            ret = OK;
4272070254f241f52cadb69bc2323f56df72704f1caAndreas Huber        }
4282070254f241f52cadb69bc2323f56df72704f1caAndreas Huber
429a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        if (msec) {
430a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber            *msec = durationMs;
431a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        }
43289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return ret;
43389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
43429357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block    ALOGE("Attempt to call getDuration without a valid mediaplayer");
43589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return INVALID_OPERATION;
43689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
43789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
43889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getDuration(int *msec)
43989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
44089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
44189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return getDuration_l(msec);
44289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
44389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
44489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::seekTo_l(int msec)
44589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
4463856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("seekTo %d", msec);
447b187de1ada34a9023c05d020a4592686ba761278Glenn Kasten    if ((mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_STARTED | MEDIA_PLAYER_PREPARED |
448b187de1ada34a9023c05d020a4592686ba761278Glenn Kasten            MEDIA_PLAYER_PAUSED |  MEDIA_PLAYER_PLAYBACK_COMPLETE) ) ) {
44989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if ( msec < 0 ) {
4505ff1dd576bb93c45b44088a51544a18fc43ebf58Steve Block            ALOGW("Attempt to seek to invalid position: %d", msec);
45189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            msec = 0;
45289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
453a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber
454a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        int durationMs;
455a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        status_t err = mPlayer->getDuration(&durationMs);
456a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber
457a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        if (err != OK) {
458a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber            ALOGW("Stream has no duration and is therefore not seekable.");
459a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber            return err;
460a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        }
461a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber
462a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        if (msec > durationMs) {
463a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber            ALOGW("Attempt to seek to past end of file: request = %d, "
464a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber                  "durationMs = %d",
465a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber                  msec,
466a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber                  durationMs);
467a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber
468a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber            msec = durationMs;
469a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber        }
470a4c5bc0f18fe272146426ab2eccad6215279c9f3Andreas Huber
47189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        // cache duration
47289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mCurrentPosition = msec;
47389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (mSeekPosition < 0) {
47489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mSeekPosition = msec;
47589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            return mPlayer->seekTo(msec);
47689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
47789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        else {
4783856b090cd04ba5dd4a59a12430ed724d5995909Steve Block            ALOGV("Seek in progress - queue up seekTo[%d]", msec);
47989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            return NO_ERROR;
48089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
48189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
482b187de1ada34a9023c05d020a4592686ba761278Glenn Kasten    ALOGE("Attempt to perform seekTo in wrong state: mPlayer=%p, mCurrentState=%u", mPlayer.get(),
483b187de1ada34a9023c05d020a4592686ba761278Glenn Kasten            mCurrentState);
48489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return INVALID_OPERATION;
48589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
48689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
48789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::seekTo(int msec)
48889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
4895cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber    mLockThreadId = getThreadId();
49089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
4915cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber    status_t result = seekTo_l(msec);
4925cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber    mLockThreadId = 0;
4935cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber
4945cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber    return result;
49589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
49689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
49761c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennisstatus_t MediaPlayer::reset_l()
49889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
49989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mLoop = false;
50089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mCurrentState == MEDIA_PLAYER_IDLE) return NO_ERROR;
50189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mPrepareSync = false;
50289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer != 0) {
50389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        status_t ret = mPlayer->reset();
50489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (ret != NO_ERROR) {
50529357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block            ALOGE("reset() failed with return code (%d)", ret);
50689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_STATE_ERROR;
50789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        } else {
50889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_IDLE;
50989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
510a1680bce73ea1b051cc92e0df651a53944b104eeJames Dong        // setDataSource has to be called again to create a
511a1680bce73ea1b051cc92e0df651a53944b104eeJames Dong        // new mediaplayer.
512a1680bce73ea1b051cc92e0df651a53944b104eeJames Dong        mPlayer = 0;
51389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return ret;
51489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
51589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    clear_l();
51689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return NO_ERROR;
51789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
51889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
519c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossmanstatus_t MediaPlayer::doSetRetransmitEndpoint(const sp<IMediaPlayer>& player) {
520c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    Mutex::Autolock _l(mLock);
521c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
522c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    if (player == NULL) {
523c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman        return UNKNOWN_ERROR;
524c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    }
525c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
526c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    if (mRetransmitEndpointValid) {
527c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman        return player->setRetransmitEndpoint(&mRetransmitEndpoint);
528c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    }
529c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
530c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    return OK;
531c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman}
532c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
53361c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennisstatus_t MediaPlayer::reset()
53461c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennis{
5353856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("reset");
53661c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennis    Mutex::Autolock _l(mLock);
53761c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennis    return reset_l();
53861c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennis}
53961c7ef5bde2c7ed94a078396aa65da67b47e5402Jamie Gennis
540fff6d715a8db0daf08a50634f242c40268de3d49Glenn Kastenstatus_t MediaPlayer::setAudioStreamType(audio_stream_type_t type)
54189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
5423856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("MediaPlayer::setAudioStreamType");
54389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
54489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mStreamType == type) return NO_ERROR;
54589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mCurrentState & ( MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_STARTED |
54689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE ) ) {
54789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        // Can't change the stream type after prepare
54829357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("setAudioStream called in state %d", mCurrentState);
54989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return INVALID_OPERATION;
55089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
55189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    // cache
55289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mStreamType = type;
55389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return OK;
55489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
55589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
556de9453fb5cbc9cd69fd1ea45d577851e3aa3b8c9John Spurlockstatus_t MediaPlayer::getAudioStreamType(audio_stream_type_t *type)
557de9453fb5cbc9cd69fd1ea45d577851e3aa3b8c9John Spurlock{
558de9453fb5cbc9cd69fd1ea45d577851e3aa3b8c9John Spurlock    ALOGV("getAudioStreamType");
559de9453fb5cbc9cd69fd1ea45d577851e3aa3b8c9John Spurlock    Mutex::Autolock _l(mLock);
560de9453fb5cbc9cd69fd1ea45d577851e3aa3b8c9John Spurlock    *type = mStreamType;
561de9453fb5cbc9cd69fd1ea45d577851e3aa3b8c9John Spurlock    return OK;
562de9453fb5cbc9cd69fd1ea45d577851e3aa3b8c9John Spurlock}
563de9453fb5cbc9cd69fd1ea45d577851e3aa3b8c9John Spurlock
56489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setLooping(int loop)
56589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
5663856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("MediaPlayer::setLooping");
56789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
56889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mLoop = (loop != 0);
56989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer != 0) {
57089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return mPlayer->setLooping(loop);
57189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
57289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return OK;
57389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
57489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
57589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectbool MediaPlayer::isLooping() {
5763856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("isLooping");
57789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
57889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer != 0) {
57989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return mLoop;
58089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
5813856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("isLooping: no active player");
58289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return false;
58389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
58489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
58589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setVolume(float leftVolume, float rightVolume)
58689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
5873856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("MediaPlayer::setVolume(%f, %f)", leftVolume, rightVolume);
58889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    Mutex::Autolock _l(mLock);
58989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mLeftVolume = leftVolume;
59089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    mRightVolume = rightVolume;
59189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (mPlayer != 0) {
59289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return mPlayer->setVolume(leftVolume, rightVolume);
59389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
59489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    return OK;
59589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
59689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
597a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurentstatus_t MediaPlayer::setAudioSessionId(int sessionId)
598a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent{
5993856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("MediaPlayer::setAudioSessionId(%d)", sessionId);
600a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent    Mutex::Autolock _l(mLock);
601a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent    if (!(mCurrentState & MEDIA_PLAYER_IDLE)) {
60229357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("setAudioSessionId called in state %d", mCurrentState);
603a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent        return INVALID_OPERATION;
604a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent    }
605a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent    if (sessionId < 0) {
606a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent        return BAD_VALUE;
607a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent    }
6083a34befc6fb04a4945a849e8bda8b84e4bf973feMarco Nelissen    if (sessionId != mAudioSessionId) {
609d457c970c8d08519cd77280a90b61ae1e342cfe3Marco Nelissen        AudioSystem::acquireAudioSessionId(sessionId, -1);
610d457c970c8d08519cd77280a90b61ae1e342cfe3Marco Nelissen        AudioSystem::releaseAudioSessionId(mAudioSessionId, -1);
611e53b9ead781c36e96d6b6f012ddffc93a3d80f0dGlenn Kasten        mAudioSessionId = sessionId;
6123a34befc6fb04a4945a849e8bda8b84e4bf973feMarco Nelissen    }
613a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent    return NO_ERROR;
614a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent}
615a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent
616a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurentint MediaPlayer::getAudioSessionId()
617a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent{
618a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent    Mutex::Autolock _l(mLock);
619a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent    return mAudioSessionId;
620a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent}
621a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent
6222beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurentstatus_t MediaPlayer::setAuxEffectSendLevel(float level)
6232beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent{
6243856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("MediaPlayer::setAuxEffectSendLevel(%f)", level);
6252beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    Mutex::Autolock _l(mLock);
6262beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    mSendLevel = level;
6272beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    if (mPlayer != 0) {
6282beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent        return mPlayer->setAuxEffectSendLevel(level);
6292beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    }
6302beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    return OK;
6312beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent}
6322beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent
6332beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurentstatus_t MediaPlayer::attachAuxEffect(int effectId)
6342beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent{
6353856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("MediaPlayer::attachAuxEffect(%d)", effectId);
6362beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    Mutex::Autolock _l(mLock);
6372beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    if (mPlayer == 0 ||
6382beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent        (mCurrentState & MEDIA_PLAYER_IDLE) ||
6392beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent        (mCurrentState == MEDIA_PLAYER_STATE_ERROR )) {
64029357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("attachAuxEffect called in state %d", mCurrentState);
6412beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent        return INVALID_OPERATION;
6422beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    }
6432beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent
6442beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent    return mPlayer->attachAuxEffect(effectId);
6452beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent}
6462beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent
647d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi// always call with lock held
648d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivistatus_t MediaPlayer::checkStateForKeySet_l(int key)
649d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi{
650d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi    switch(key) {
651d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi    case KEY_PARAMETER_AUDIO_ATTRIBUTES:
652d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi        if (mCurrentState & ( MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_STARTED |
653d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi                MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE) ) {
654d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi            // Can't change the audio attributes after prepare
655d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi            ALOGE("trying to set audio attributes called in state %d", mCurrentState);
656d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi            return INVALID_OPERATION;
657d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi        }
658d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi        break;
659d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi    default:
660d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi        // parameter doesn't require player state check
661d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi        break;
662d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi    }
663d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi    return OK;
664d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi}
665d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi
6664f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wangstatus_t MediaPlayer::setParameter(int key, const Parcel& request)
6674f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang{
6683856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("MediaPlayer::setParameter(%d)", key);
6694f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    Mutex::Autolock _l(mLock);
670d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi    if (checkStateForKeySet_l(key) != OK) {
671d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi        return INVALID_OPERATION;
672d9d7fa0873796ac661c44a7fcd6ad5ff697ff01fJean-Michel Trivi    }
6734f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    if (mPlayer != NULL) {
6744f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang        return  mPlayer->setParameter(key, request);
6754f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    }
676640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi    switch (key) {
677640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi    case KEY_PARAMETER_AUDIO_ATTRIBUTES:
678640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        // no player, save the marshalled audio attributes
679640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        if (mAudioAttributesParcel != NULL) { delete mAudioAttributesParcel; };
680640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        mAudioAttributesParcel = new Parcel();
681640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        mAudioAttributesParcel->appendFrom(&request, 0, request.dataSize());
682640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        return OK;
683640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi    default:
684640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        ALOGV("setParameter: no active player");
685640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi        return INVALID_OPERATION;
686640adb3cf89cc9b826372009fad8c9b3d120482eJean-Michel Trivi    }
6874f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang}
6884f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang
6894f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wangstatus_t MediaPlayer::getParameter(int key, Parcel *reply)
6904f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang{
6913856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("MediaPlayer::getParameter(%d)", key);
6924f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    Mutex::Autolock _l(mLock);
6934f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    if (mPlayer != NULL) {
694e53b9ead781c36e96d6b6f012ddffc93a3d80f0dGlenn Kasten        return  mPlayer->getParameter(key, reply);
6954f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    }
6963856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("getParameter: no active player");
6974f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    return INVALID_OPERATION;
6984f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang}
6994f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang
700c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossmanstatus_t MediaPlayer::setRetransmitEndpoint(const char* addrString,
701c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman                                            uint16_t port) {
702c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    ALOGV("MediaPlayer::setRetransmitEndpoint(%s:%hu)",
703c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman            addrString ? addrString : "(null)", port);
704c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
705c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    Mutex::Autolock _l(mLock);
706c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    if ((mPlayer != NULL) || (mCurrentState != MEDIA_PLAYER_IDLE))
707c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman        return INVALID_OPERATION;
708c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
709c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    if (NULL == addrString) {
710c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman        mRetransmitEndpointValid = false;
711c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman        return OK;
712c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    }
713c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
714c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    struct in_addr saddr;
715c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    if(!inet_aton(addrString, &saddr)) {
716c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman        return BAD_VALUE;
717c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    }
718c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
719be08f6a6688f3b1ae6914fbe800953c9bfb13c45Glenn Kasten    memset(&mRetransmitEndpoint, 0, sizeof(mRetransmitEndpoint));
720c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    mRetransmitEndpoint.sin_family = AF_INET;
721c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    mRetransmitEndpoint.sin_addr   = saddr;
722c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    mRetransmitEndpoint.sin_port   = htons(port);
723c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    mRetransmitEndpointValid       = true;
724c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
725c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman    return OK;
726c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman}
727c795b64060c3af9d7961fc1371e4ccfa8ee3e450John Grossman
728b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wangvoid MediaPlayer::notify(int msg, int ext1, int ext2, const Parcel *obj)
72989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
7303856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("message received msg=%d, ext1=%d, ext2=%d", msg, ext1, ext2);
73189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    bool send = true;
7321af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    bool locked = false;
73389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
73489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    // TODO: In the future, we might be on the same thread if the app is
73589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    // running in the same process as the media server. In that case,
73689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    // this will deadlock.
737660951867e959ebe98612742ef1f72d33ea7e9a3Nicolas Catania    //
738d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    // The threadId hack below works around this for the care of prepare,
739d88adb96ec867ed1b629c434f87514d2fabaf5e9Chong Zhang    // seekTo and start within the same process.
7405cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber    // FIXME: Remember, this is a hack, it's not even a hack that is applied
7415cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber    // consistently for all use-cases, this needs to be revisited.
742e53b9ead781c36e96d6b6f012ddffc93a3d80f0dGlenn Kasten    if (mLockThreadId != getThreadId()) {
7431af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams        mLock.lock();
7441af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams        locked = true;
745660951867e959ebe98612742ef1f72d33ea7e9a3Nicolas Catania    }
7461af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams
7473b26844e60f8487388e7e62709faf0dada86e7e1Eric Laurent    // Allows calls from JNI in idle state to notify errors
7483b26844e60f8487388e7e62709faf0dada86e7e1Eric Laurent    if (!(msg == MEDIA_ERROR && mCurrentState == MEDIA_PLAYER_IDLE) && mPlayer == 0) {
7493856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("notify(%d, %d, %d) callback on disconnected mediaplayer", msg, ext1, ext2);
7501af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams        if (locked) mLock.unlock();   // release the lock when done.
75189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        return;
75289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
75389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
75489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    switch (msg) {
75589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    case MEDIA_NOP: // interface test message
75689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        break;
75789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    case MEDIA_PREPARED:
7583856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("prepared");
75989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mCurrentState = MEDIA_PLAYER_PREPARED;
76089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (mPrepareSync) {
7613856b090cd04ba5dd4a59a12430ed724d5995909Steve Block            ALOGV("signal application thread");
76289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mPrepareSync = false;
76389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mPrepareStatus = NO_ERROR;
76489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mSignal.signal();
76589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
76689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        break;
76789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    case MEDIA_PLAYBACK_COMPLETE:
7683856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("playback complete");
7691c1503cf47c0a37a30e7acac2c5d29140fc61a5fMarco Nelissen        if (mCurrentState == MEDIA_PLAYER_IDLE) {
77029357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block            ALOGE("playback complete in idle state");
7711c1503cf47c0a37a30e7acac2c5d29140fc61a5fMarco Nelissen        }
77289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (!mLoop) {
77389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentState = MEDIA_PLAYER_PLAYBACK_COMPLETE;
77489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
77589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        break;
77689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    case MEDIA_ERROR:
77765e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project        // Always log errors.
77865e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project        // ext1: Media framework error code.
77965e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project        // ext2: Implementation dependant error code.
78029357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("error (%d, %d)", ext1, ext2);
78189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mCurrentState = MEDIA_PLAYER_STATE_ERROR;
78289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (mPrepareSync)
78389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        {
7843856b090cd04ba5dd4a59a12430ed724d5995909Steve Block            ALOGV("signal application thread");
78589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mPrepareSync = false;
78689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mPrepareStatus = ext1;
78789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mSignal.signal();
78889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            send = false;
78989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
79089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        break;
79165e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project    case MEDIA_INFO:
79265e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project        // ext1: Media framework error code.
79365e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project        // ext2: Implementation dependant error code.
794145e68fc778275963189b02a1adcbe27cce4d769Andreas Huber        if (ext1 != MEDIA_INFO_VIDEO_TRACK_LAGGING) {
7955ff1dd576bb93c45b44088a51544a18fc43ebf58Steve Block            ALOGW("info/warning (%d, %d)", ext1, ext2);
796145e68fc778275963189b02a1adcbe27cce4d769Andreas Huber        }
79765e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project        break;
79889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    case MEDIA_SEEK_COMPLETE:
7993856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("Received seek complete");
80089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        if (mSeekPosition != mCurrentPosition) {
8013856b090cd04ba5dd4a59a12430ed724d5995909Steve Block            ALOGV("Executing queued seekTo(%d)", mSeekPosition);
80289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mSeekPosition = -1;
80389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            seekTo_l(mCurrentPosition);
80489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
80589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        else {
8063856b090cd04ba5dd4a59a12430ed724d5995909Steve Block            ALOGV("All seeks complete - return to regularly scheduled program");
80789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project            mCurrentPosition = mSeekPosition = -1;
80889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        }
80989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        break;
81089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    case MEDIA_BUFFERING_UPDATE:
8113856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("buffering %d", ext1);
81289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        break;
81389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    case MEDIA_SET_VIDEO_SIZE:
8143856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("New video size %d x %d", ext1, ext2);
81589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mVideoWidth = ext1;
81689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        mVideoHeight = ext2;
81789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        break;
818b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wang    case MEDIA_TIMED_TEXT:
8193856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("Received timed text message");
820b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wang        break;
821dcb89b3b505522efde173c105a851c412f947178Chong Zhang    case MEDIA_SUBTITLE_DATA:
822dcb89b3b505522efde173c105a851c412f947178Chong Zhang        ALOGV("Received subtitle data message");
823dcb89b3b505522efde173c105a851c412f947178Chong Zhang        break;
82489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    default:
8253856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("unrecognized message: (%d, %d, %d)", msg, ext1, ext2);
82689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        break;
82789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
82889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
82989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    sp<MediaPlayerListener> listener = mListener;
8301af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams    if (locked) mLock.unlock();
83189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
83289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    // this prevents re-entrant calls into client code
83389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if ((listener != 0) && send) {
83489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        Mutex::Autolock _l(mNotifyLock);
8353856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("callback application");
836b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wang        listener->notify(msg, ext1, ext2, obj);
8373856b090cd04ba5dd4a59a12430ed724d5995909Steve Block        ALOGV("back from callback");
83889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
83989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
84089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
8411b86fe063badb5f28c467ade39be0f4008688947Andreas Huber/*static*/ status_t MediaPlayer::decode(
8421b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        const sp<IMediaHTTPService> &httpService,
8431b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        const char* url,
8441b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        uint32_t *pSampleRate,
8451b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        int* pNumChannels,
8461b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        audio_format_t* pFormat,
8471b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        const sp<IMemoryHeap>& heap,
8481b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        size_t *pSize)
84989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
8503856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("decode(%s)", url);
8513d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent    status_t status;
85289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    const sp<IMediaPlayerService>& service = getMediaPlayerService();
85389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (service != 0) {
8541b86fe063badb5f28c467ade39be0f4008688947Andreas Huber        status = service->decode(httpService, url, pSampleRate, pNumChannels, pFormat, heap, pSize);
85589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    } else {
85629357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("Unable to locate media service");
8573d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent        status = DEAD_OBJECT;
85889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
8593d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent    return status;
86089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
86189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
86289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
863dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dongvoid MediaPlayer::died()
864dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong{
8653856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("died");
866dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong    notify(MEDIA_ERROR, MEDIA_ERROR_SERVER_DIED, 0);
867dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong}
868dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong
8693d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent/*static*/ status_t MediaPlayer::decode(int fd, int64_t offset, int64_t length,
8703d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent                                        uint32_t *pSampleRate, int* pNumChannels,
8713d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent                                        audio_format_t* pFormat,
8723d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent                                        const sp<IMemoryHeap>& heap, size_t *pSize)
87389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
87434fb29696b0f3abf61b10f8d053b1f33d501de0aMark Salyzyn    ALOGV("decode(%d, %" PRId64 ", %" PRId64 ")", fd, offset, length);
8753d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent    status_t status;
87689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    const sp<IMediaPlayerService>& service = getMediaPlayerService();
87789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    if (service != 0) {
8783d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent        status = service->decode(fd, offset, length, pSampleRate,
8793d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent                                 pNumChannels, pFormat, heap, pSize);
88089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    } else {
88129357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("Unable to locate media service");
8823d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent        status = DEAD_OBJECT;
88389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    }
8843d00aa6de95fb46e36f2bab4e3facdf0b96acf06Eric Laurent    return status;
88589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
88689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}
88789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
8886b74d671a1321a6ecc4a40b6c87beedfecc1ec44Marco Nelissenstatus_t MediaPlayer::setNextMediaPlayer(const sp<MediaPlayer>& next) {
8896b74d671a1321a6ecc4a40b6c87beedfecc1ec44Marco Nelissen    if (mPlayer == NULL) {
8906b74d671a1321a6ecc4a40b6c87beedfecc1ec44Marco Nelissen        return NO_INIT;
8916b74d671a1321a6ecc4a40b6c87beedfecc1ec44Marco Nelissen    }
892b13820ffafcb6bcdd33b6272676535afb4dff479Marco Nelissen
893b13820ffafcb6bcdd33b6272676535afb4dff479Marco Nelissen    if (next != NULL && !(next->mCurrentState &
894b13820ffafcb6bcdd33b6272676535afb4dff479Marco Nelissen            (MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE))) {
895b13820ffafcb6bcdd33b6272676535afb4dff479Marco Nelissen        ALOGE("next player is not prepared");
896b13820ffafcb6bcdd33b6272676535afb4dff479Marco Nelissen        return INVALID_OPERATION;
897b13820ffafcb6bcdd33b6272676535afb4dff479Marco Nelissen    }
898b13820ffafcb6bcdd33b6272676535afb4dff479Marco Nelissen
8996b74d671a1321a6ecc4a40b6c87beedfecc1ec44Marco Nelissen    return mPlayer->setNextPlayer(next == NULL ? NULL : next->mPlayer);
9006b74d671a1321a6ecc4a40b6c87beedfecc1ec44Marco Nelissen}
9016b74d671a1321a6ecc4a40b6c87beedfecc1ec44Marco Nelissen
90289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}; // namespace android
903