AwesomePlayer.cpp revision 69f5f4c021ee55055df39718244c036faf2d3382
1bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber/* 2bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * Copyright (C) 2009 The Android Open Source Project 3bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * 4bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * Licensed under the Apache License, Version 2.0 (the "License"); 5bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * you may not use this file except in compliance with the License. 6bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * You may obtain a copy of the License at 7bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * 8bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * http://www.apache.org/licenses/LICENSE-2.0 9bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * 10bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * Unless required by applicable law or agreed to in writing, software 11bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * distributed under the License is distributed on an "AS IS" BASIS, 12bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * See the License for the specific language governing permissions and 14bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * limitations under the License. 15bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber */ 16bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 17bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber//#define LOG_NDEBUG 0 18bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#define LOG_TAG "AwesomePlayer" 19bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <utils/Log.h> 20bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 21bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include "include/AwesomePlayer.h" 2266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber#include "include/Prefetcher.h" 23733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber#include "include/SoftwareRenderer.h" 24bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 254844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber#include <binder/IPCThreadState.h> 26bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/AudioPlayer.h> 27bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/DataSource.h> 28bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/FileSource.h> 29bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MediaBuffer.h> 30717826ececd8d39596f62418677721d70776add1Andreas Huber#include <media/stagefright/MediaDefs.h> 31bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MediaExtractor.h> 32bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MediaDebug.h> 33bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MediaSource.h> 34bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MetaData.h> 35bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/OMXCodec.h> 36717826ececd8d39596f62418677721d70776add1Andreas Huber 37bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubernamespace android { 38bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 39bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstruct AwesomeEvent : public TimedEventQueue::Event { 40bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomeEvent(AwesomePlayer *player, int32_t code) 41bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber : mPlayer(player), 42bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mCode(code) { 43bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 44bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 45bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberprotected: 46bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber virtual ~AwesomeEvent() {} 47bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 48bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber virtual void fire(TimedEventQueue *queue, int64_t /* now_us */) { 49bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mPlayer->onEvent(mCode); 50bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 51bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 52bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberprivate: 53bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomePlayer *mPlayer; 54bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t mCode; 55bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 56bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomeEvent(const AwesomeEvent &); 57bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomeEvent &operator=(const AwesomeEvent &); 58bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber}; 59bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 60733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberstruct AwesomeRemoteRenderer : public AwesomeRenderer { 61733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeRemoteRenderer(const sp<IOMXRenderer> &target) 62733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber : mTarget(target) { 63733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 64733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 65733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber virtual void render(MediaBuffer *buffer) { 66733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber void *id; 67733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber if (buffer->meta_data()->findPointer(kKeyBufferID, &id)) { 68733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mTarget->render((IOMX::buffer_id)id); 69733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 70733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 71733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 72733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberprivate: 73733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber sp<IOMXRenderer> mTarget; 74733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 75733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeRemoteRenderer(const AwesomeRemoteRenderer &); 76733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeRemoteRenderer &operator=(const AwesomeRemoteRenderer &); 77733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber}; 78733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 79733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberstruct AwesomeLocalRenderer : public AwesomeRenderer { 80733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeLocalRenderer( 81733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber OMX_COLOR_FORMATTYPE colorFormat, 82733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber const sp<ISurface> &surface, 83733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber size_t displayWidth, size_t displayHeight, 84733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber size_t decodedWidth, size_t decodedHeight) 85733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber : mTarget(new SoftwareRenderer( 86733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber colorFormat, surface, displayWidth, displayHeight, 87733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber decodedWidth, decodedHeight)) { 88733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 89733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 90733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber virtual void render(MediaBuffer *buffer) { 91733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mTarget->render( 92733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber (const uint8_t *)buffer->data() + buffer->range_offset(), 93733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber buffer->range_length(), NULL); 94733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 95733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 96733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberprotected: 97733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber virtual ~AwesomeLocalRenderer() { 98733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber delete mTarget; 99733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mTarget = NULL; 100733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 101733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 102733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberprivate: 103733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber SoftwareRenderer *mTarget; 104733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 105733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeLocalRenderer(const AwesomeLocalRenderer &); 106733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeLocalRenderer &operator=(const AwesomeLocalRenderer &);; 107733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber}; 108733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 109bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas HuberAwesomePlayer::AwesomePlayer() 110bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber : mTimeSource(NULL), 111bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer(NULL), 112bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer(NULL), 113bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer(NULL) { 114bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK_EQ(mClient.connect(), OK); 115bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 116bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber DataSource::RegisterDefaultSniffers(); 117bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 118bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEvent = new AwesomeEvent(this, 0); 119bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 120bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEvent = new AwesomeEvent(this, 1); 121bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 12266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEvent = new AwesomeEvent(this, 2); 12366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEventPending = false; 124bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 125bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.start(); 126bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 127bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset(); 128bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 129bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 130bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas HuberAwesomePlayer::~AwesomePlayer() { 131bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.stop(); 132bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 133bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset(); 134bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 135bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mClient.disconnect(); 136bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 137bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 13866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Hubervoid AwesomePlayer::cancelPlayerEvents(bool keepBufferingGoing) { 139bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.cancelEvent(mVideoEvent->eventID()); 140bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 141bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.cancelEvent(mStreamDoneEvent->eventID()); 142bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 14366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 14466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (!keepBufferingGoing) { 14566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mQueue.cancelEvent(mBufferingEvent->eventID()); 14666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEventPending = false; 14766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 148bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 149bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 1500726045216f576e97672ebeefc265d39c4ebaaa5Andreas Hubervoid AwesomePlayer::setListener(const wp<MediaPlayerBase> &listener) { 151bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 152bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mListener = listener; 153bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 154bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 1555561ccf4a8db88a2e44eac1b3ed13b4ff53a7f20Andreas Huberstatus_t AwesomePlayer::setDataSource( 1565561ccf4a8db88a2e44eac1b3ed13b4ff53a7f20Andreas Huber const char *uri, const KeyedVector<String8, String8> *headers) { 157bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 158bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 159bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 160bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 1615561ccf4a8db88a2e44eac1b3ed13b4ff53a7f20Andreas Huber sp<DataSource> dataSource = DataSource::CreateFromURI(uri, headers); 16266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 16366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (dataSource == NULL) { 16466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber return UNKNOWN_ERROR; 16566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 16666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 16766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber sp<MediaExtractor> extractor = MediaExtractor::Create(dataSource); 168bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 169bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (extractor == NULL) { 170bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 171bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 172bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 17366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (dataSource->flags() & DataSource::kWantsPrefetching) { 17466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mPrefetcher = new Prefetcher; 17566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 17666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 177bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return setDataSource_l(extractor); 178bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 179bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 180bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setDataSource( 181bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int fd, int64_t offset, int64_t length) { 182bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 183bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 184bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 185bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 186bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<DataSource> source = new FileSource(fd, offset, length); 187bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 188bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber status_t err = source->initCheck(); 189bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 190bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err != OK) { 191bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return err; 192bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 193bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 194bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MediaExtractor> extractor = MediaExtractor::Create(source); 195bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 196bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (extractor == NULL) { 197bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 198bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 199bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 200bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return setDataSource_l(extractor); 201bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 202bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 203bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setDataSource_l(const sp<MediaExtractor> &extractor) { 204bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber bool haveAudio = false; 205bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber bool haveVideo = false; 206bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber for (size_t i = 0; i < extractor->countTracks(); ++i) { 207bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MetaData> meta = extractor->getTrackMetaData(i); 208bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 209bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const char *mime; 210bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findCString(kKeyMIMEType, &mime)); 211bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 212bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!haveVideo && !strncasecmp(mime, "video/", 6)) { 213bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (setVideoSource(extractor->getTrack(i)) == OK) { 214bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber haveVideo = true; 215bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 216bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else if (!haveAudio && !strncasecmp(mime, "audio/", 6)) { 217bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (setAudioSource(extractor->getTrack(i)) == OK) { 218bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber haveAudio = true; 219bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 220bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 221bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 222bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (haveAudio && haveVideo) { 223bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 224bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 225bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 226bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 227bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return !haveAudio && !haveVideo ? UNKNOWN_ERROR : OK; 228bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 229bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 230bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::reset() { 231bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 232bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 233bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 234bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 235bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::reset_l() { 236bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber cancelPlayerEvents(); 237bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 238b9280d5c2313c41eb490f58198c4e59118e0e3e6Andreas Huber mVideoRenderer.clear(); 239b9280d5c2313c41eb490f58198c4e59118e0e3e6Andreas Huber 240bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 241bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 242bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 243bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 244bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 245bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoBuffer) { 246bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 247bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 248bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 249bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 250bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 251bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource->stop(); 25269f5f4c021ee55055df39718244c036faf2d3382Andreas Huber 25369f5f4c021ee55055df39718244c036faf2d3382Andreas Huber // The following hack is necessary to ensure that the OMX 25469f5f4c021ee55055df39718244c036faf2d3382Andreas Huber // component is completely released by the time we may try 25569f5f4c021ee55055df39718244c036faf2d3382Andreas Huber // to instantiate it again. 25669f5f4c021ee55055df39718244c036faf2d3382Andreas Huber wp<MediaSource> tmp = mVideoSource; 257bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource.clear(); 25869f5f4c021ee55055df39718244c036faf2d3382Andreas Huber while (tmp.promote() != NULL) { 25969f5f4c021ee55055df39718244c036faf2d3382Andreas Huber usleep(1000); 26069f5f4c021ee55055df39718244c036faf2d3382Andreas Huber } 26169f5f4c021ee55055df39718244c036faf2d3382Andreas Huber IPCThreadState::self()->flushCommands(); 262bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 263bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 264bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioSource.clear(); 265bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 266bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mTimeSource != mAudioPlayer) { 267bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mTimeSource; 268bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 269bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = NULL; 270bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 271bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mAudioPlayer; 272bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer = NULL; 273bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 274bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = -1; 275bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags = 0; 276bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoWidth = mVideoHeight = -1; 277bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = 0; 278bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoTimeUs = 0; 279bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 280bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 281bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeekTimeUs = 0; 28266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 28366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mPrefetcher.clear(); 284bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 285bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 286bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber// static 287bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::AudioNotify(void *_me, int what) { 288bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomePlayer *me = (AwesomePlayer *)_me; 289bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 290bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(me->mLock); 291bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 292bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber switch (what) { 293bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber case AudioPlayer::REACHED_EOS: 294bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber me->postStreamDoneEvent_l(); 295bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 296bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 297bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber case AudioPlayer::SEEK_COMPLETE: 298bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber { 2990726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber me->notifyListener_l(MEDIA_SEEK_COMPLETE); 300bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 301bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 302bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 303bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber default: 304bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(!"should not be here."); 305bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 306bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 307bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 308bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 30966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Hubervoid AwesomePlayer::notifyListener_l(int msg, int ext1) { 3100726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber if (mListener != NULL) { 3110726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber sp<MediaPlayerBase> listener = mListener.promote(); 3120726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber 3130726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber if (listener != NULL) { 31466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber listener->sendEvent(msg, ext1); 31566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 31666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 31766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber} 31866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 31966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Hubervoid AwesomePlayer::onBufferingUpdate() { 32066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber Mutex::Autolock autoLock(mLock); 32166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEventPending = false; 32266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 32366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mDurationUs >= 0) { 32466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber int64_t cachedDurationUs = mPrefetcher->getCachedDurationUs(); 32566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber int64_t positionUs = 0; 32666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mVideoRenderer != NULL) { 32766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber positionUs = mVideoTimeUs; 32866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } else if (mAudioPlayer != NULL) { 32966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber positionUs = mAudioPlayer->getMediaTimeUs(); 3300726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber } 33166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 33266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber cachedDurationUs += positionUs; 33366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 33466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber double percentage = (double)cachedDurationUs / mDurationUs; 33566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber notifyListener_l(MEDIA_BUFFERING_UPDATE, percentage * 100.0); 33666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 33766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber postBufferingEvent_l(); 3380726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber } 3390726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber} 3400726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber 341bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::onStreamDone() { 342bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // Posted whenever any stream finishes playing. 343bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 344bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 345bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 346bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 347bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & LOOPING) { 348bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber seekTo_l(0); 349bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 350bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoRenderer != NULL) { 351bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 352bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 353bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 3540726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber notifyListener_l(MEDIA_PLAYBACK_COMPLETE); 355bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 356bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber pause_l(); 357bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 358bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 359bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 360bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::play() { 361bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 362bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 363bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & PLAYING) { 364bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 365bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 366bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 367bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= PLAYING; 368bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= FIRST_FRAME; 369bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 370fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber bool deferredAudioSeek = false; 371fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber 372bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSource != NULL) { 373bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer == NULL) { 374bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSink != NULL) { 375bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer = new AudioPlayer(mAudioSink); 376bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 377bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->setListenerCallback( 378bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber &AwesomePlayer::AudioNotify, this); 379bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 380bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->setSource(mAudioSource); 381bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->start(); 382bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 383bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mTimeSource; 384bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = mAudioPlayer; 385bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 386fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber deferredAudioSeek = true; 387bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 388bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 389bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->resume(); 390bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 391bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 392bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 393bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mTimeSource == NULL && mAudioPlayer == NULL) { 394bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = new SystemTimeSource; 395bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 396bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 397bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 398bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoRenderer == NULL) { 399bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber initRenderer_l(); 400bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 401bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 402bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoRenderer != NULL) { 403bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // Kick off video playback 404bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 405bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 406bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 407bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 408fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber if (deferredAudioSeek) { 409fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber // If there was a seek request while we were paused 410fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber // and we're just starting up again, honor the request now. 411fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber seekAudioIfNecessary_l(); 412fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber } 413fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber 41466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber postBufferingEvent_l(); 41566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 416bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 417bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 418bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 419bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::initRenderer_l() { 420bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mISurface != NULL) { 421bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MetaData> meta = mVideoSource->getFormat(); 422bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 423bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t format; 424bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const char *component; 425bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t decodedWidth, decodedHeight; 426bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyColorFormat, &format)); 427bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findCString(kKeyDecoderComponent, &component)); 428bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyWidth, &decodedWidth)); 429bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyHeight, &decodedHeight)); 430bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 4314844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoRenderer.clear(); 4324844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 4334844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber // Must ensure that mVideoRenderer's destructor is actually executed 4344844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber // before creating a new one. 4354844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber IPCThreadState::self()->flushCommands(); 4364844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 437733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber if (!strncmp("OMX.", component, 4)) { 438733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // Our OMX codecs allocate buffers on the media_server side 439733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // therefore they require a remote IOMXRenderer that knows how 440733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // to display them. 441733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoRenderer = new AwesomeRemoteRenderer( 442733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mClient.interface()->createRenderer( 443733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mISurface, component, 444733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber (OMX_COLOR_FORMATTYPE)format, 445733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber decodedWidth, decodedHeight, 446733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoWidth, mVideoHeight)); 447733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } else { 448733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // Other decoders are instantiated locally and as a consequence 449733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // allocate their buffers in local address space. 450733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoRenderer = new AwesomeLocalRenderer( 451733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber (OMX_COLOR_FORMATTYPE)format, 452733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mISurface, 453733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoWidth, mVideoHeight, 454733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber decodedWidth, decodedHeight); 455733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 456bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 457bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 458bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 459bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::pause() { 460bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 461bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return pause_l(); 462bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 463bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 464bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::pause_l() { 465bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!(mFlags & PLAYING)) { 466bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 467bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 468bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 46966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber cancelPlayerEvents(true /* keepBufferingGoing */); 470bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 471bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL) { 472bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->pause(); 473bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 474bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 475bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags &= ~PLAYING; 476bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 477bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 478bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 479bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 480bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberbool AwesomePlayer::isPlaying() const { 481bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 482bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 483bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mFlags & PLAYING; 484bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 485bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 486bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::setISurface(const sp<ISurface> &isurface) { 487bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 488bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 489bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mISurface = isurface; 490bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 491bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 492bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::setAudioSink( 493bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const sp<MediaPlayerBase::AudioSink> &audioSink) { 494bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 495bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 496bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioSink = audioSink; 497bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 498bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 499bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setLooping(bool shouldLoop) { 500bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 501bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 502bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags = mFlags & ~LOOPING; 503bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 504bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (shouldLoop) { 505bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= LOOPING; 506bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 507bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 508bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 509bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 510bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 511bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getDuration(int64_t *durationUs) { 512bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 513bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 514bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0) { 515bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 516bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 517bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 518bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *durationUs = mDurationUs; 519bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 520bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 521bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 522bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 523bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getPosition(int64_t *positionUs) { 524bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 525bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 526bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoRenderer != NULL) { 527bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = mVideoTimeUs; 528bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else if (mAudioPlayer != NULL) { 529bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = mAudioPlayer->getMediaTimeUs(); 530bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 531bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = 0; 532bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 533bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 534bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 535bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 536bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 537bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::seekTo(int64_t timeUs) { 538bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 539bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return seekTo_l(timeUs); 540bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 541bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 542bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::seekTo_l(int64_t timeUs) { 543bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = true; 544bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeekTimeUs = timeUs; 545bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 546bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber seekAudioIfNecessary_l(); 547bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 548bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 549bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 550bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 551bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::seekAudioIfNecessary_l() { 552bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking && mVideoRenderer == NULL && mAudioPlayer != NULL) { 553bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->seekTo(mSeekTimeUs); 554bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 555bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 556bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 557bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 558bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 559bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getVideoDimensions( 560bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t *width, int32_t *height) const { 561bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 562bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 563bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoWidth < 0 || mVideoHeight < 0) { 564bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 565bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 566bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 567bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *width = mVideoWidth; 568bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *height = mVideoHeight; 569bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 570bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 571bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 572bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 57366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huberstatus_t AwesomePlayer::setAudioSource(sp<MediaSource> source) { 574bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source == NULL) { 575bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 576bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 577bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 57866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mPrefetcher != NULL) { 57966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber source = mPrefetcher->addSource(source); 58066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 58166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 582717826ececd8d39596f62418677721d70776add1Andreas Huber sp<MetaData> meta = source->getFormat(); 583717826ececd8d39596f62418677721d70776add1Andreas Huber 584717826ececd8d39596f62418677721d70776add1Andreas Huber const char *mime; 585717826ececd8d39596f62418677721d70776add1Andreas Huber CHECK(meta->findCString(kKeyMIMEType, &mime)); 586717826ececd8d39596f62418677721d70776add1Andreas Huber 587717826ececd8d39596f62418677721d70776add1Andreas Huber if (!strcasecmp(mime, MEDIA_MIMETYPE_AUDIO_RAW)) { 588717826ececd8d39596f62418677721d70776add1Andreas Huber mAudioSource = source; 589717826ececd8d39596f62418677721d70776add1Andreas Huber } else { 590717826ececd8d39596f62418677721d70776add1Andreas Huber mAudioSource = OMXCodec::Create( 591717826ececd8d39596f62418677721d70776add1Andreas Huber mClient.interface(), source->getFormat(), 592717826ececd8d39596f62418677721d70776add1Andreas Huber false, // createEncoder 593717826ececd8d39596f62418677721d70776add1Andreas Huber source); 594717826ececd8d39596f62418677721d70776add1Andreas Huber } 595bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 596bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSource != NULL) { 597bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t durationUs; 598bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source->getFormat()->findInt64(kKeyDuration, &durationUs)) { 599bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0 || durationUs > mDurationUs) { 600bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = durationUs; 601bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 602bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 603bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 604bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 605bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mAudioSource != NULL ? OK : UNKNOWN_ERROR; 606bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 607bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 60866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huberstatus_t AwesomePlayer::setVideoSource(sp<MediaSource> source) { 609bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source == NULL) { 610bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 611bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 612bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 61366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mPrefetcher != NULL) { 61466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber source = mPrefetcher->addSource(source); 61566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 61666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 617bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource = OMXCodec::Create( 618bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mClient.interface(), source->getFormat(), 619bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber false, // createEncoder 620bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber source); 621bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 622bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 623bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t durationUs; 624bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source->getFormat()->findInt64(kKeyDuration, &durationUs)) { 625bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0 || durationUs > mDurationUs) { 626bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = durationUs; 627bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 628bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 629bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 630bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(source->getFormat()->findInt32(kKeyWidth, &mVideoWidth)); 631bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(source->getFormat()->findInt32(kKeyHeight, &mVideoHeight)); 632bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 633bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource->start(); 634bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 635bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 636bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mVideoSource != NULL ? OK : UNKNOWN_ERROR; 637bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 638bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 639bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::onEvent(int32_t code) { 640bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (code == 1) { 641bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber onStreamDone(); 642bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 64366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } else if (code == 2) { 64466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber onBufferingUpdate(); 64566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber return; 646bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 647bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 648bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 64966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 650bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 651bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 652bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 653bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 654bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 655bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 656bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 657bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 658bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoBuffer) { 659bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 660bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 661bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 662bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 663bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 664bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!mVideoBuffer) { 665bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber MediaSource::ReadOptions options; 666bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 667bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("seeking to %lld us (%.2f secs)", mSeekTimeUs, mSeekTimeUs / 1E6); 668bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 669bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber options.setSeekTo(mSeekTimeUs); 670bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 671bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber for (;;) { 672bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber status_t err = mVideoSource->read(&mVideoBuffer, &options); 673c1689e49ac867de33f2e81289449878ac2e536a0Andreas Huber options.clearSeekTo(); 674bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 675bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err != OK) { 676bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK_EQ(mVideoBuffer, NULL); 677bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 678bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err == INFO_FORMAT_CHANGED) { 679bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("VideoSource signalled format change."); 680bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 681bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber initRenderer_l(); 682bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber continue; 683bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 684bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 685bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postStreamDoneEvent_l(); 686bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 687bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 688bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 6894844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber if (mVideoBuffer->range_length() == 0) { 69008411b75d4c30ce26180639f158e2f33d190eee8Andreas Huber // Some decoders, notably the PV AVC software decoder 69108411b75d4c30ce26180639f158e2f33d190eee8Andreas Huber // return spurious empty buffers that we just want to ignore. 69208411b75d4c30ce26180639f158e2f33d190eee8Andreas Huber 6934844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoBuffer->release(); 6944844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoBuffer = NULL; 6954844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber continue; 6964844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber } 6974844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 698bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 699bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 700bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 701bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 702bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t timeUs; 703bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(mVideoBuffer->meta_data()->findInt64(kKeyTime, &timeUs)); 704bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 705bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoTimeUs = timeUs; 706bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 707bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 708bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL) { 709bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("seeking audio to %lld us (%.2f secs).", timeUs, timeUs / 1E6); 710bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 711bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->seekTo(timeUs); 712bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 713bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // If we're playing video only, report seek complete now, 714bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // otherwise audio player will notify us later. 7150726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber notifyListener_l(MEDIA_SEEK_COMPLETE); 716bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 717bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 718bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= FIRST_FRAME; 719bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 720bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 721bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 722bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & FIRST_FRAME) { 723bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags &= ~FIRST_FRAME; 724bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 725bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = mTimeSource->getRealTimeUs() - timeUs; 726bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 727bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 728bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t realTimeUs, mediaTimeUs; 729bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL 730bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber && mAudioPlayer->getMediaTimeMapping(&realTimeUs, &mediaTimeUs)) { 731bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = realTimeUs - mediaTimeUs; 732bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 733bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 734bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t nowUs = mTimeSource->getRealTimeUs() - mTimeSourceDeltaUs; 735bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 736bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t latenessUs = nowUs - timeUs; 737bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 738650773d00356129ffd661cdaef3fb3095c343707Andreas Huber if (latenessUs > 40000) { 739650773d00356129ffd661cdaef3fb3095c343707Andreas Huber // We're more than 40ms late. 740650773d00356129ffd661cdaef3fb3095c343707Andreas Huber LOGI("we're late by %lld us (%.2f secs)", latenessUs, latenessUs / 1E6); 741bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 742bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 743bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 744bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 745bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 746bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 747bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 748bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 749bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (latenessUs < -10000) { 750bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // We're more than 10ms early. 751bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 752bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(10000); 753bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 754bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 755bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 756733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoRenderer->render(mVideoBuffer); 757bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 758bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 759bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 760bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 761bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 762bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = mVideoBuffer; 763bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 764bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 765bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 766bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 767bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 768bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::postVideoEvent_l(int64_t delayUs) { 769bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoEventPending) { 770bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 771bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 772bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 773bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = true; 774bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.postEventWithDelay(mVideoEvent, delayUs < 0 ? 10000 : delayUs); 775bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 776bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 777bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::postStreamDoneEvent_l() { 778bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mStreamDoneEventPending) { 779bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 780bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 781bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = true; 782bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.postEvent(mStreamDoneEvent); 783bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 784bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 78566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Hubervoid AwesomePlayer::postBufferingEvent_l() { 78666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mPrefetcher == NULL) { 78766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber return; 78866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 78966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 79066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mBufferingEventPending) { 79166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber return; 79266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 79366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEventPending = true; 79466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mQueue.postEventWithDelay(mBufferingEvent, 1000000ll); 79566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber} 79666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 797bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} // namespace android 798bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 799