AwesomePlayer.cpp revision c23f12af0394aa2f6651968a3c8840f1af317aa1
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 { 40c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber AwesomeEvent( 41c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber AwesomePlayer *player, 42c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber void (AwesomePlayer::*method)()) 43bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber : mPlayer(player), 44c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mMethod(method) { 45bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 46bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 47bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberprotected: 48bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber virtual ~AwesomeEvent() {} 49bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 50bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber virtual void fire(TimedEventQueue *queue, int64_t /* now_us */) { 51c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber (mPlayer->*mMethod)(); 52bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 53bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 54bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberprivate: 55bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomePlayer *mPlayer; 56c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber void (AwesomePlayer::*mMethod)(); 57bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 58bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomeEvent(const AwesomeEvent &); 59bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomeEvent &operator=(const AwesomeEvent &); 60bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber}; 61bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 62733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberstruct AwesomeRemoteRenderer : public AwesomeRenderer { 63733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeRemoteRenderer(const sp<IOMXRenderer> &target) 64733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber : mTarget(target) { 65733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 66733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 67733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber virtual void render(MediaBuffer *buffer) { 68733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber void *id; 69733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber if (buffer->meta_data()->findPointer(kKeyBufferID, &id)) { 70733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mTarget->render((IOMX::buffer_id)id); 71733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 72733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 73733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 74733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberprivate: 75733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber sp<IOMXRenderer> mTarget; 76733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 77733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeRemoteRenderer(const AwesomeRemoteRenderer &); 78733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeRemoteRenderer &operator=(const AwesomeRemoteRenderer &); 79733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber}; 80733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 81733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberstruct AwesomeLocalRenderer : public AwesomeRenderer { 82733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeLocalRenderer( 83733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber OMX_COLOR_FORMATTYPE colorFormat, 84733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber const sp<ISurface> &surface, 85733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber size_t displayWidth, size_t displayHeight, 86733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber size_t decodedWidth, size_t decodedHeight) 87733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber : mTarget(new SoftwareRenderer( 88733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber colorFormat, surface, displayWidth, displayHeight, 89733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber decodedWidth, decodedHeight)) { 90733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 91733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 92733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber virtual void render(MediaBuffer *buffer) { 93733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mTarget->render( 94733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber (const uint8_t *)buffer->data() + buffer->range_offset(), 95733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber buffer->range_length(), NULL); 96733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 97733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 98733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberprotected: 99733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber virtual ~AwesomeLocalRenderer() { 100733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber delete mTarget; 101733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mTarget = NULL; 102733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 103733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 104733b7729ea462fae9c6899456444e28fef1c757cAndreas Huberprivate: 105733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber SoftwareRenderer *mTarget; 106733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 107733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeLocalRenderer(const AwesomeLocalRenderer &); 108733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber AwesomeLocalRenderer &operator=(const AwesomeLocalRenderer &);; 109733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber}; 110733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber 111bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas HuberAwesomePlayer::AwesomePlayer() 112bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber : mTimeSource(NULL), 113bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer(NULL), 114bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer(NULL), 115bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer(NULL) { 116bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK_EQ(mClient.connect(), OK); 117bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 118bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber DataSource::RegisterDefaultSniffers(); 119bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 120c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mVideoEvent = new AwesomeEvent(this, &AwesomePlayer::onVideoEvent); 121bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 122c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mStreamDoneEvent = new AwesomeEvent(this, &AwesomePlayer::onStreamDone); 123bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 124c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mBufferingEvent = new AwesomeEvent(this, &AwesomePlayer::onBufferingUpdate); 12566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEventPending = false; 126c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 127c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mCheckAudioStatusEvent = new AwesomeEvent( 128c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber this, &AwesomePlayer::onCheckAudioStatus); 129c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 1301862a33b246249630b654182afb5914da3480d4cAndreas Huber mAudioStatusEventPending = false; 131bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 132bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.start(); 133bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 134bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset(); 135bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 136bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 137bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas HuberAwesomePlayer::~AwesomePlayer() { 138bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.stop(); 139bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 140bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset(); 141bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 142bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mClient.disconnect(); 143bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 144bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 14566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Hubervoid AwesomePlayer::cancelPlayerEvents(bool keepBufferingGoing) { 146bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.cancelEvent(mVideoEvent->eventID()); 147bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 148bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.cancelEvent(mStreamDoneEvent->eventID()); 149bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 1501862a33b246249630b654182afb5914da3480d4cAndreas Huber mQueue.cancelEvent(mCheckAudioStatusEvent->eventID()); 1511862a33b246249630b654182afb5914da3480d4cAndreas Huber mAudioStatusEventPending = false; 15266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 15366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (!keepBufferingGoing) { 15466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mQueue.cancelEvent(mBufferingEvent->eventID()); 15566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEventPending = false; 15666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 157bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 158bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 1590726045216f576e97672ebeefc265d39c4ebaaa5Andreas Hubervoid AwesomePlayer::setListener(const wp<MediaPlayerBase> &listener) { 160bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 161bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mListener = listener; 162bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 163bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 1645561ccf4a8db88a2e44eac1b3ed13b4ff53a7f20Andreas Huberstatus_t AwesomePlayer::setDataSource( 1655561ccf4a8db88a2e44eac1b3ed13b4ff53a7f20Andreas Huber const char *uri, const KeyedVector<String8, String8> *headers) { 166bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 167bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 168bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 169bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 1705561ccf4a8db88a2e44eac1b3ed13b4ff53a7f20Andreas Huber sp<DataSource> dataSource = DataSource::CreateFromURI(uri, headers); 17166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 17266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (dataSource == NULL) { 17366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber return UNKNOWN_ERROR; 17466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 17566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 17666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber sp<MediaExtractor> extractor = MediaExtractor::Create(dataSource); 177bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 178bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (extractor == NULL) { 179bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 180bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 181bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 18266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (dataSource->flags() & DataSource::kWantsPrefetching) { 18366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mPrefetcher = new Prefetcher; 18466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 18566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 186bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return setDataSource_l(extractor); 187bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 188bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 189bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setDataSource( 190bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int fd, int64_t offset, int64_t length) { 191bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 192bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 193bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 194bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 195bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<DataSource> source = new FileSource(fd, offset, length); 196bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 197bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber status_t err = source->initCheck(); 198bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 199bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err != OK) { 200bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return err; 201bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 202bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 203bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MediaExtractor> extractor = MediaExtractor::Create(source); 204bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 205bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (extractor == NULL) { 206bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 207bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 208bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 209bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return setDataSource_l(extractor); 210bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 211bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 212bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setDataSource_l(const sp<MediaExtractor> &extractor) { 213bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber bool haveAudio = false; 214bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber bool haveVideo = false; 215bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber for (size_t i = 0; i < extractor->countTracks(); ++i) { 216bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MetaData> meta = extractor->getTrackMetaData(i); 217bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 218bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const char *mime; 219bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findCString(kKeyMIMEType, &mime)); 220bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 221bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!haveVideo && !strncasecmp(mime, "video/", 6)) { 222bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (setVideoSource(extractor->getTrack(i)) == OK) { 223bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber haveVideo = true; 224bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 225bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else if (!haveAudio && !strncasecmp(mime, "audio/", 6)) { 226bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (setAudioSource(extractor->getTrack(i)) == OK) { 227bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber haveAudio = true; 228bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 229bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 230bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 231bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (haveAudio && haveVideo) { 232bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 233bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 234bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 235bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 236bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return !haveAudio && !haveVideo ? UNKNOWN_ERROR : OK; 237bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 238bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 239bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::reset() { 240bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 241bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 242bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 243bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 244bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::reset_l() { 245bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber cancelPlayerEvents(); 246bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 247b9280d5c2313c41eb490f58198c4e59118e0e3e6Andreas Huber mVideoRenderer.clear(); 248b9280d5c2313c41eb490f58198c4e59118e0e3e6Andreas Huber 249bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 250bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 251bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 252bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 253bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 254bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoBuffer) { 255bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 256bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 257bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 258bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 259bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 260bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource->stop(); 26169f5f4c021ee55055df39718244c036faf2d3382Andreas Huber 26269f5f4c021ee55055df39718244c036faf2d3382Andreas Huber // The following hack is necessary to ensure that the OMX 26369f5f4c021ee55055df39718244c036faf2d3382Andreas Huber // component is completely released by the time we may try 26469f5f4c021ee55055df39718244c036faf2d3382Andreas Huber // to instantiate it again. 26569f5f4c021ee55055df39718244c036faf2d3382Andreas Huber wp<MediaSource> tmp = mVideoSource; 266bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource.clear(); 26769f5f4c021ee55055df39718244c036faf2d3382Andreas Huber while (tmp.promote() != NULL) { 26869f5f4c021ee55055df39718244c036faf2d3382Andreas Huber usleep(1000); 26969f5f4c021ee55055df39718244c036faf2d3382Andreas Huber } 27069f5f4c021ee55055df39718244c036faf2d3382Andreas Huber IPCThreadState::self()->flushCommands(); 271bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 272bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 273bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioSource.clear(); 274bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 275bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mTimeSource != mAudioPlayer) { 276bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mTimeSource; 277bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 278bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = NULL; 279bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 280bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mAudioPlayer; 281bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer = NULL; 282bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 283bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = -1; 284bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags = 0; 285bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoWidth = mVideoHeight = -1; 286bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = 0; 287bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoTimeUs = 0; 288bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 289bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 290bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeekTimeUs = 0; 29166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 29266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mPrefetcher.clear(); 293bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 294bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 295c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Hubervoid AwesomePlayer::notifyListener_l(int msg, int ext1, int ext2) { 2960726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber if (mListener != NULL) { 2970726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber sp<MediaPlayerBase> listener = mListener.promote(); 2980726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber 2990726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber if (listener != NULL) { 300c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber listener->sendEvent(msg, ext1, ext2); 30166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 30266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 30366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber} 30466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 30566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Hubervoid AwesomePlayer::onBufferingUpdate() { 30666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber Mutex::Autolock autoLock(mLock); 30766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEventPending = false; 30866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 30966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mDurationUs >= 0) { 31066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber int64_t cachedDurationUs = mPrefetcher->getCachedDurationUs(); 31166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber int64_t positionUs = 0; 312a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber if (mVideoSource != NULL) { 31366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber positionUs = mVideoTimeUs; 31466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } else if (mAudioPlayer != NULL) { 31566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber positionUs = mAudioPlayer->getMediaTimeUs(); 3160726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber } 31766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 31866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber cachedDurationUs += positionUs; 31966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 32066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber double percentage = (double)cachedDurationUs / mDurationUs; 32166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber notifyListener_l(MEDIA_BUFFERING_UPDATE, percentage * 100.0); 32266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 32366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber postBufferingEvent_l(); 3240726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber } 3250726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber} 3260726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber 327bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::onStreamDone() { 328bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // Posted whenever any stream finishes playing. 329bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 330bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 331bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 332bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 333bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & LOOPING) { 334bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber seekTo_l(0); 335bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 336a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber if (mVideoSource != NULL) { 337bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 338bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 339bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 3400726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber notifyListener_l(MEDIA_PLAYBACK_COMPLETE); 341bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 342bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber pause_l(); 343bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 344bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 345bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 346bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::play() { 347bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 348bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 349bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & PLAYING) { 350bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 351bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 352bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 353bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= PLAYING; 354bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= FIRST_FRAME; 355bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 356fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber bool deferredAudioSeek = false; 357fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber 358bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSource != NULL) { 359bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer == NULL) { 360bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSink != NULL) { 361bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer = new AudioPlayer(mAudioSink); 362bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->setSource(mAudioSource); 36388c030e0e0152791ff74f90249f55fce01371198Andreas Huber status_t err = mAudioPlayer->start(); 36488c030e0e0152791ff74f90249f55fce01371198Andreas Huber 36588c030e0e0152791ff74f90249f55fce01371198Andreas Huber if (err != OK) { 36688c030e0e0152791ff74f90249f55fce01371198Andreas Huber delete mAudioPlayer; 36788c030e0e0152791ff74f90249f55fce01371198Andreas Huber mAudioPlayer = NULL; 36888c030e0e0152791ff74f90249f55fce01371198Andreas Huber 36988c030e0e0152791ff74f90249f55fce01371198Andreas Huber mFlags &= ~(PLAYING | FIRST_FRAME); 37088c030e0e0152791ff74f90249f55fce01371198Andreas Huber 37188c030e0e0152791ff74f90249f55fce01371198Andreas Huber return err; 37288c030e0e0152791ff74f90249f55fce01371198Andreas Huber } 373bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 374bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mTimeSource; 375bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = mAudioPlayer; 376bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 377fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber deferredAudioSeek = true; 3781862a33b246249630b654182afb5914da3480d4cAndreas Huber 3791862a33b246249630b654182afb5914da3480d4cAndreas Huber mWatchForAudioSeekComplete = false; 3801862a33b246249630b654182afb5914da3480d4cAndreas Huber mWatchForAudioEOS = true; 381bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 382bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 383bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->resume(); 384bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 3851862a33b246249630b654182afb5914da3480d4cAndreas Huber 3861862a33b246249630b654182afb5914da3480d4cAndreas Huber postCheckAudioStatusEvent_l(); 387bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 388bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 389bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mTimeSource == NULL && mAudioPlayer == NULL) { 390bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = new SystemTimeSource; 391bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 392bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 393bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 394a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber // Kick off video playback 395a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber postVideoEvent_l(); 396bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 397bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 398fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber if (deferredAudioSeek) { 399fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber // If there was a seek request while we were paused 400fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber // and we're just starting up again, honor the request now. 401fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber seekAudioIfNecessary_l(); 402fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber } 403fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber 40466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber postBufferingEvent_l(); 40566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 406bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 407bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 408bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 409bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::initRenderer_l() { 410bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mISurface != NULL) { 411bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MetaData> meta = mVideoSource->getFormat(); 412bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 413bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t format; 414bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const char *component; 415bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t decodedWidth, decodedHeight; 416bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyColorFormat, &format)); 417bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findCString(kKeyDecoderComponent, &component)); 418bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyWidth, &decodedWidth)); 419bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyHeight, &decodedHeight)); 420bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 4214844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoRenderer.clear(); 4224844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 4234844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber // Must ensure that mVideoRenderer's destructor is actually executed 4244844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber // before creating a new one. 4254844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber IPCThreadState::self()->flushCommands(); 4264844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 427733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber if (!strncmp("OMX.", component, 4)) { 428733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // Our OMX codecs allocate buffers on the media_server side 429733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // therefore they require a remote IOMXRenderer that knows how 430733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // to display them. 431733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoRenderer = new AwesomeRemoteRenderer( 432733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mClient.interface()->createRenderer( 433733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mISurface, component, 434733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber (OMX_COLOR_FORMATTYPE)format, 435733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber decodedWidth, decodedHeight, 436733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoWidth, mVideoHeight)); 437733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } else { 438733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // Other decoders are instantiated locally and as a consequence 439733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber // allocate their buffers in local address space. 440733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoRenderer = new AwesomeLocalRenderer( 441733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber (OMX_COLOR_FORMATTYPE)format, 442733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mISurface, 443733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber mVideoWidth, mVideoHeight, 444733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber decodedWidth, decodedHeight); 445733b7729ea462fae9c6899456444e28fef1c757cAndreas Huber } 446bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 447bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 448bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 449bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::pause() { 450bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 451bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return pause_l(); 452bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 453bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 454bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::pause_l() { 455bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!(mFlags & PLAYING)) { 456bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 457bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 458bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 45966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber cancelPlayerEvents(true /* keepBufferingGoing */); 460bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 461bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL) { 462bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->pause(); 463bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 464bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 465bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags &= ~PLAYING; 466bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 467bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 468bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 469bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 470bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberbool AwesomePlayer::isPlaying() const { 471bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 472bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 473bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mFlags & PLAYING; 474bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 475bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 476bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::setISurface(const sp<ISurface> &isurface) { 477bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 478bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 479bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mISurface = isurface; 480bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 481bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 482bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::setAudioSink( 483bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const sp<MediaPlayerBase::AudioSink> &audioSink) { 484bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 485bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 486bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioSink = audioSink; 487bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 488bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 489bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setLooping(bool shouldLoop) { 490bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 491bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 492bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags = mFlags & ~LOOPING; 493bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 494bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (shouldLoop) { 495bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= LOOPING; 496bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 497bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 498bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 499bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 500bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 501bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getDuration(int64_t *durationUs) { 502bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 503bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 504bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0) { 505bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 506bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 507bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 508bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *durationUs = mDurationUs; 509bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 510bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 511bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 512bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 513bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getPosition(int64_t *positionUs) { 514bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 515bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 516a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber if (mVideoSource != NULL) { 517bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = mVideoTimeUs; 518bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else if (mAudioPlayer != NULL) { 519bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = mAudioPlayer->getMediaTimeUs(); 520bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 521bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = 0; 522bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 523bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 524bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 525bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 526bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 527bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::seekTo(int64_t timeUs) { 528bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 529bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return seekTo_l(timeUs); 530bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 531bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 532bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::seekTo_l(int64_t timeUs) { 533bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = true; 534bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeekTimeUs = timeUs; 535bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 536bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber seekAudioIfNecessary_l(); 537bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 538bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 539bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 540bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 541bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::seekAudioIfNecessary_l() { 542a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber if (mSeeking && mVideoSource == NULL && mAudioPlayer != NULL) { 543bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->seekTo(mSeekTimeUs); 544bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 5451862a33b246249630b654182afb5914da3480d4cAndreas Huber mWatchForAudioSeekComplete = true; 5461862a33b246249630b654182afb5914da3480d4cAndreas Huber mWatchForAudioEOS = true; 547bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 548bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 549bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 550bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 551bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getVideoDimensions( 552bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t *width, int32_t *height) const { 553bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 554bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 555bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoWidth < 0 || mVideoHeight < 0) { 556bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 557bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 558bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 559bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *width = mVideoWidth; 560bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *height = mVideoHeight; 561bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 562bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 563bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 564bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 56566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huberstatus_t AwesomePlayer::setAudioSource(sp<MediaSource> source) { 566bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source == NULL) { 567bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 568bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 569bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 57066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mPrefetcher != NULL) { 57166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber source = mPrefetcher->addSource(source); 57266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 57366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 574717826ececd8d39596f62418677721d70776add1Andreas Huber sp<MetaData> meta = source->getFormat(); 575717826ececd8d39596f62418677721d70776add1Andreas Huber 576717826ececd8d39596f62418677721d70776add1Andreas Huber const char *mime; 577717826ececd8d39596f62418677721d70776add1Andreas Huber CHECK(meta->findCString(kKeyMIMEType, &mime)); 578717826ececd8d39596f62418677721d70776add1Andreas Huber 579717826ececd8d39596f62418677721d70776add1Andreas Huber if (!strcasecmp(mime, MEDIA_MIMETYPE_AUDIO_RAW)) { 580717826ececd8d39596f62418677721d70776add1Andreas Huber mAudioSource = source; 581717826ececd8d39596f62418677721d70776add1Andreas Huber } else { 582717826ececd8d39596f62418677721d70776add1Andreas Huber mAudioSource = OMXCodec::Create( 583717826ececd8d39596f62418677721d70776add1Andreas Huber mClient.interface(), source->getFormat(), 584717826ececd8d39596f62418677721d70776add1Andreas Huber false, // createEncoder 585717826ececd8d39596f62418677721d70776add1Andreas Huber source); 586717826ececd8d39596f62418677721d70776add1Andreas Huber } 587bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 588bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSource != NULL) { 589bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t durationUs; 590bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source->getFormat()->findInt64(kKeyDuration, &durationUs)) { 591bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0 || durationUs > mDurationUs) { 592bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = durationUs; 593bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 594bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 595bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 596bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 597bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mAudioSource != NULL ? OK : UNKNOWN_ERROR; 598bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 599bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 60066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huberstatus_t AwesomePlayer::setVideoSource(sp<MediaSource> source) { 601bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source == NULL) { 602bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 603bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 604bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 60566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mPrefetcher != NULL) { 60666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber source = mPrefetcher->addSource(source); 60766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 60866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 609bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource = OMXCodec::Create( 610bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mClient.interface(), source->getFormat(), 611bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber false, // createEncoder 612bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber source); 613bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 614bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 615bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t durationUs; 616bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source->getFormat()->findInt64(kKeyDuration, &durationUs)) { 617bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0 || durationUs > mDurationUs) { 618bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = durationUs; 619bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 620bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 621bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 622bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(source->getFormat()->findInt32(kKeyWidth, &mVideoWidth)); 623bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(source->getFormat()->findInt32(kKeyHeight, &mVideoHeight)); 624bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 625bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource->start(); 626bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 627bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 628bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mVideoSource != NULL ? OK : UNKNOWN_ERROR; 629bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 630bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 631c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Hubervoid AwesomePlayer::onVideoEvent() { 632bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 63366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 634bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 635bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 636bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 637bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 638bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 639bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 640bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 641bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 642bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoBuffer) { 643bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 644bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 645bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 646bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 647bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 648bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!mVideoBuffer) { 649bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber MediaSource::ReadOptions options; 650bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 651bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("seeking to %lld us (%.2f secs)", mSeekTimeUs, mSeekTimeUs / 1E6); 652bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 653bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber options.setSeekTo(mSeekTimeUs); 654bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 655bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber for (;;) { 656bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber status_t err = mVideoSource->read(&mVideoBuffer, &options); 657c1689e49ac867de33f2e81289449878ac2e536a0Andreas Huber options.clearSeekTo(); 658bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 659bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err != OK) { 660bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK_EQ(mVideoBuffer, NULL); 661bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 662bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err == INFO_FORMAT_CHANGED) { 663bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("VideoSource signalled format change."); 664bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 665a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber if (mVideoRenderer != NULL) { 666a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber initRenderer_l(); 667a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber } 668bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber continue; 669bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 670bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 671bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postStreamDoneEvent_l(); 672bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 673bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 674bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 6754844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber if (mVideoBuffer->range_length() == 0) { 67608411b75d4c30ce26180639f158e2f33d190eee8Andreas Huber // Some decoders, notably the PV AVC software decoder 67708411b75d4c30ce26180639f158e2f33d190eee8Andreas Huber // return spurious empty buffers that we just want to ignore. 67808411b75d4c30ce26180639f158e2f33d190eee8Andreas Huber 6794844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoBuffer->release(); 6804844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoBuffer = NULL; 6814844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber continue; 6824844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber } 6834844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 684bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 685bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 686bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 687bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 688bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t timeUs; 689bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(mVideoBuffer->meta_data()->findInt64(kKeyTime, &timeUs)); 690bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 691bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoTimeUs = timeUs; 692bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 693bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 694bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL) { 695bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("seeking audio to %lld us (%.2f secs).", timeUs, timeUs / 1E6); 696bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 697bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->seekTo(timeUs); 6981862a33b246249630b654182afb5914da3480d4cAndreas Huber mWatchForAudioSeekComplete = true; 6991862a33b246249630b654182afb5914da3480d4cAndreas Huber mWatchForAudioEOS = true; 700bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 701bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // If we're playing video only, report seek complete now, 702bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // otherwise audio player will notify us later. 7030726045216f576e97672ebeefc265d39c4ebaaa5Andreas Huber notifyListener_l(MEDIA_SEEK_COMPLETE); 704bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 705bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 706bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= FIRST_FRAME; 707bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 708bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 709bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 710bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & FIRST_FRAME) { 711bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags &= ~FIRST_FRAME; 712bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 713bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = mTimeSource->getRealTimeUs() - timeUs; 714bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 715bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 716bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t realTimeUs, mediaTimeUs; 717bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL 718bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber && mAudioPlayer->getMediaTimeMapping(&realTimeUs, &mediaTimeUs)) { 719bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = realTimeUs - mediaTimeUs; 720bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 721bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 722bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t nowUs = mTimeSource->getRealTimeUs() - mTimeSourceDeltaUs; 723bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 724bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t latenessUs = nowUs - timeUs; 725bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 726650773d00356129ffd661cdaef3fb3095c343707Andreas Huber if (latenessUs > 40000) { 727650773d00356129ffd661cdaef3fb3095c343707Andreas Huber // We're more than 40ms late. 728650773d00356129ffd661cdaef3fb3095c343707Andreas Huber LOGI("we're late by %lld us (%.2f secs)", latenessUs, latenessUs / 1E6); 729bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 730bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 731bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 732bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 733bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 734bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 735bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 736bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 737bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (latenessUs < -10000) { 738bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // We're more than 10ms early. 739bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 740bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(10000); 741bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 742bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 743bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 744a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber if (mVideoRenderer == NULL) { 745a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber initRenderer_l(); 746a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber } 747a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber 748a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber if (mVideoRenderer != NULL) { 749a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber mVideoRenderer->render(mVideoBuffer); 750a657f8deaf21acbe5faba7be1df9c6681d44d471Andreas Huber } 751bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 752bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 753bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 754bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 755bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 756bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = mVideoBuffer; 757bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 758bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 759bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 760bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 761bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 762bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::postVideoEvent_l(int64_t delayUs) { 763bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoEventPending) { 764bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 765bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 766bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 767bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = true; 768bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.postEventWithDelay(mVideoEvent, delayUs < 0 ? 10000 : delayUs); 769bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 770bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 771bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::postStreamDoneEvent_l() { 772bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mStreamDoneEventPending) { 773bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 774bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 775bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = true; 776bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.postEvent(mStreamDoneEvent); 777bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 778bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 77966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Hubervoid AwesomePlayer::postBufferingEvent_l() { 78066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mPrefetcher == NULL) { 78166b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber return; 78266b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 78366b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 78466b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber if (mBufferingEventPending) { 78566b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber return; 78666b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber } 78766b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mBufferingEventPending = true; 78866b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber mQueue.postEventWithDelay(mBufferingEvent, 1000000ll); 78966b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber} 79066b0a35c9a4136a84c3f73b1b25fcb5220138b95Andreas Huber 7911862a33b246249630b654182afb5914da3480d4cAndreas Hubervoid AwesomePlayer::postCheckAudioStatusEvent_l() { 7921862a33b246249630b654182afb5914da3480d4cAndreas Huber if (mAudioStatusEventPending) { 7931862a33b246249630b654182afb5914da3480d4cAndreas Huber return; 7941862a33b246249630b654182afb5914da3480d4cAndreas Huber } 7951862a33b246249630b654182afb5914da3480d4cAndreas Huber mAudioStatusEventPending = true; 7961862a33b246249630b654182afb5914da3480d4cAndreas Huber mQueue.postEventWithDelay(mCheckAudioStatusEvent, 100000ll); 7971862a33b246249630b654182afb5914da3480d4cAndreas Huber} 7981862a33b246249630b654182afb5914da3480d4cAndreas Huber 7991862a33b246249630b654182afb5914da3480d4cAndreas Hubervoid AwesomePlayer::onCheckAudioStatus() { 8001862a33b246249630b654182afb5914da3480d4cAndreas Huber Mutex::Autolock autoLock(mLock); 8011862a33b246249630b654182afb5914da3480d4cAndreas Huber mAudioStatusEventPending = false; 8021862a33b246249630b654182afb5914da3480d4cAndreas Huber 8031862a33b246249630b654182afb5914da3480d4cAndreas Huber if (mWatchForAudioSeekComplete && !mAudioPlayer->isSeeking()) { 8041862a33b246249630b654182afb5914da3480d4cAndreas Huber mWatchForAudioSeekComplete = false; 8051862a33b246249630b654182afb5914da3480d4cAndreas Huber notifyListener_l(MEDIA_SEEK_COMPLETE); 8061862a33b246249630b654182afb5914da3480d4cAndreas Huber } 8071862a33b246249630b654182afb5914da3480d4cAndreas Huber 8081862a33b246249630b654182afb5914da3480d4cAndreas Huber if (mWatchForAudioEOS && mAudioPlayer->reachedEOS()) { 8091862a33b246249630b654182afb5914da3480d4cAndreas Huber mWatchForAudioEOS = false; 8101862a33b246249630b654182afb5914da3480d4cAndreas Huber postStreamDoneEvent_l(); 8111862a33b246249630b654182afb5914da3480d4cAndreas Huber } 8121862a33b246249630b654182afb5914da3480d4cAndreas Huber 8131862a33b246249630b654182afb5914da3480d4cAndreas Huber postCheckAudioStatusEvent_l(); 8141862a33b246249630b654182afb5914da3480d4cAndreas Huber} 8151862a33b246249630b654182afb5914da3480d4cAndreas Huber 816c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huberstatus_t AwesomePlayer::prepare() { 817c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber Mutex::Autolock autoLock(mLock); 818c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 819c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber status_t err = prepareAsync_l(); 820c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 821c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber if (err != OK) { 822c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber return err; 823c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber } 824c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 825c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber while (mAsyncPrepareEvent != NULL) { 826c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mPreparedCondition.wait(mLock); 827c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber } 828c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 829c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber return OK; 830c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber} 831c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 832c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huberstatus_t AwesomePlayer::prepareAsync() { 833c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber Mutex::Autolock autoLock(mLock); 834c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber return prepareAsync_l(); 835c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber} 836c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 837c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huberstatus_t AwesomePlayer::prepareAsync_l() { 838c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber if (mAsyncPrepareEvent != NULL) { 839c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber return UNKNOWN_ERROR; // async prepare already pending. 840c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber } 841c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 842c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mAsyncPrepareEvent = new AwesomeEvent( 843c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber this, &AwesomePlayer::onPrepareAsyncEvent); 844c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 845c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mQueue.postEvent(mAsyncPrepareEvent); 846c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 847c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber return OK; 848c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber} 849c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 850c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Hubervoid AwesomePlayer::onPrepareAsyncEvent() { 851c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber sp<Prefetcher> prefetcher; 852c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 853c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber { 854c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber Mutex::Autolock autoLock(mLock); 855c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber prefetcher = mPrefetcher; 856c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber } 857c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 858c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber if (prefetcher != NULL) { 859c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber prefetcher->prepare(); 860c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber } 861c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 862c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber Mutex::Autolock autoLock(mLock); 863c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 864c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber if (mVideoWidth < 0 || mVideoHeight < 0) { 865c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber notifyListener_l(MEDIA_SET_VIDEO_SIZE, 0, 0); 866c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber } else { 867c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber notifyListener_l(MEDIA_SET_VIDEO_SIZE, mVideoWidth, mVideoHeight); 868c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber } 869c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 870c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber notifyListener_l(MEDIA_PREPARED); 871c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 872c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mAsyncPrepareEvent = NULL; 873c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber mPreparedCondition.signal(); 874c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber} 875c23f12af0394aa2f6651968a3c8840f1af317aa1Andreas Huber 876bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} // namespace android 877bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 878