NuPlayerDriver.cpp revision 3fe62150fa3dd6d25cb84aad80bc9e27ddd16c45
1f933441648ef6a71dee783d733aac17b9508b452Andreas Huber/*
2f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * Copyright (C) 2010 The Android Open Source Project
3f933441648ef6a71dee783d733aac17b9508b452Andreas Huber *
4f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * Licensed under the Apache License, Version 2.0 (the "License");
5f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * you may not use this file except in compliance with the License.
6f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * You may obtain a copy of the License at
7f933441648ef6a71dee783d733aac17b9508b452Andreas Huber *
8f933441648ef6a71dee783d733aac17b9508b452Andreas Huber *      http://www.apache.org/licenses/LICENSE-2.0
9f933441648ef6a71dee783d733aac17b9508b452Andreas Huber *
10f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * Unless required by applicable law or agreed to in writing, software
11f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * distributed under the License is distributed on an "AS IS" BASIS,
12f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * See the License for the specific language governing permissions and
14f933441648ef6a71dee783d733aac17b9508b452Andreas Huber * limitations under the License.
15f933441648ef6a71dee783d733aac17b9508b452Andreas Huber */
16f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
17f933441648ef6a71dee783d733aac17b9508b452Andreas Huber//#define LOG_NDEBUG 0
18f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#define LOG_TAG "NuPlayerDriver"
19f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <utils/Log.h>
20f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
21f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include "NuPlayerDriver.h"
22f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
23f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include "NuPlayer.h"
24f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
251aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber#include <media/stagefright/foundation/ADebug.h>
26f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/foundation/ALooper.h>
27f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
28f933441648ef6a71dee783d733aac17b9508b452Andreas Hubernamespace android {
29f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
30f933441648ef6a71dee783d733aac17b9508b452Andreas HuberNuPlayerDriver::NuPlayerDriver()
311aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    : mResetInProgress(false),
3243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber      mDurationUs(-1),
3343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber      mPositionUs(-1),
343fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber      mNumFramesTotal(0),
353fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber      mNumFramesDropped(0),
361aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber      mLooper(new ALooper),
3743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber      mState(UNINITIALIZED),
3843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber      mStartupSeekTimeUs(-1) {
39f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mLooper->setName("NuPlayerDriver Looper");
40f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
41f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mLooper->start(
42f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            false, /* runOnCallingThread */
43f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            true,  /* canCallJava */
44f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            PRIORITY_AUDIO);
45f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
46f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mPlayer = new NuPlayer;
47f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mLooper->registerHandler(mPlayer);
48f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
4943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mPlayer->setDriver(this);
50f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
51f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
52f933441648ef6a71dee783d733aac17b9508b452Andreas HuberNuPlayerDriver::~NuPlayerDriver() {
53f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mLooper->stop();
54f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
55f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
56f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::initCheck() {
57f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
58f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
59f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
609b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huberstatus_t NuPlayerDriver::setUID(uid_t uid) {
619b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber    mPlayer->setUID(uid);
629b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber
639b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber    return OK;
649b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber}
659b80c2bdb205bc143104f54d0743b6eedd67b14eAndreas Huber
66f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::setDataSource(
67f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const char *url, const KeyedVector<String8, String8> *headers) {
6843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    CHECK_EQ((int)mState, (int)UNINITIALIZED);
6943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
705bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    mPlayer->setDataSource(url, headers);
715bc087c573c70c84c6a39946457590b42d392a33Andreas Huber
7243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mState = STOPPED;
7343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
745bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    return OK;
75f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
76f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
77f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::setDataSource(int fd, int64_t offset, int64_t length) {
78f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return INVALID_OPERATION;
79f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
80f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
81f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::setDataSource(const sp<IStreamSource> &source) {
8243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    CHECK_EQ((int)mState, (int)UNINITIALIZED);
8343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
84f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mPlayer->setDataSource(source);
85f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
8643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mState = STOPPED;
8743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
88f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
89f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
90f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
91f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::setVideoSurface(const sp<Surface> &surface) {
92f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mPlayer->setVideoSurface(surface);
93f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
94f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
95f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
96f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
971173118eace0e9e347cb007f0da817cee87579edGlenn Kastenstatus_t NuPlayerDriver::setVideoSurfaceTexture(
981173118eace0e9e347cb007f0da817cee87579edGlenn Kasten        const sp<ISurfaceTexture> &surfaceTexture) {
991173118eace0e9e347cb007f0da817cee87579edGlenn Kasten    mPlayer->setVideoSurfaceTexture(surfaceTexture);
1001173118eace0e9e347cb007f0da817cee87579edGlenn Kasten
1011173118eace0e9e347cb007f0da817cee87579edGlenn Kasten    return OK;
1021173118eace0e9e347cb007f0da817cee87579edGlenn Kasten}
1031173118eace0e9e347cb007f0da817cee87579edGlenn Kasten
104f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::prepare() {
105f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
106f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
107f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
108f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::prepareAsync() {
1095bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    sendEvent(MEDIA_PREPARED);
1105bc087c573c70c84c6a39946457590b42d392a33Andreas Huber
111f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
112f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
113f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
114f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::start() {
11543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    switch (mState) {
11643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case UNINITIALIZED:
11743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            return INVALID_OPERATION;
11843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case STOPPED:
11943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        {
12043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            mPlayer->start();
12143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
12243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            if (mStartupSeekTimeUs >= 0) {
1232048d0cfccce48be26816dec8711a6691ebff71cAndreas Huber                if (mStartupSeekTimeUs == 0) {
1242048d0cfccce48be26816dec8711a6691ebff71cAndreas Huber                    notifySeekComplete();
1252048d0cfccce48be26816dec8711a6691ebff71cAndreas Huber                } else {
1262048d0cfccce48be26816dec8711a6691ebff71cAndreas Huber                    mPlayer->seekToAsync(mStartupSeekTimeUs);
1272048d0cfccce48be26816dec8711a6691ebff71cAndreas Huber                }
1282048d0cfccce48be26816dec8711a6691ebff71cAndreas Huber
12943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber                mStartupSeekTimeUs = -1;
13043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            }
1312048d0cfccce48be26816dec8711a6691ebff71cAndreas Huber
13243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            break;
13343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        }
13443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case PLAYING:
13543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            return OK;
13643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        default:
13743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        {
13843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            CHECK_EQ((int)mState, (int)PAUSED);
13943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
14043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            mPlayer->resume();
14143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            break;
14243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        }
14343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    }
14443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
14543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mState = PLAYING;
146f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
147f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
148f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
149f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
150f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::stop() {
15143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    return pause();
152f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
153f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
154f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::pause() {
15543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    switch (mState) {
15643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case UNINITIALIZED:
15743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            return INVALID_OPERATION;
15843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case STOPPED:
15943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            return OK;
16043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case PLAYING:
16143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            mPlayer->pause();
16243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            break;
16343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        default:
16443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        {
16543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            CHECK_EQ((int)mState, (int)PAUSED);
16643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            return OK;
16743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        }
16843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    }
16943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
17043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mState = PAUSED;
17143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
172f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
173f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
174f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
175f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool NuPlayerDriver::isPlaying() {
17643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    return mState == PLAYING;
177f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
178f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
179f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::seekTo(int msec) {
18043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    int64_t seekTimeUs = msec * 1000ll;
18143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
18243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    switch (mState) {
18343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case UNINITIALIZED:
18443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            return INVALID_OPERATION;
18543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case STOPPED:
18643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        {
18743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            mStartupSeekTimeUs = seekTimeUs;
18843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            break;
18943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        }
19043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case PLAYING:
19143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        case PAUSED:
19243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        {
19343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            mPlayer->seekToAsync(seekTimeUs);
19443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            break;
19543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        }
19643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
19743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        default:
19843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            TRESPASS();
19943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber            break;
20043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    }
20143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
20243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    return OK;
203f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
204f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
205f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getCurrentPosition(int *msec) {
20643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    Mutex::Autolock autoLock(mLock);
20743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
20843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    if (mPositionUs < 0) {
20943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        *msec = 0;
21043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    } else {
21143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        *msec = (mPositionUs + 500ll) / 1000;
21243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    }
2135bc087c573c70c84c6a39946457590b42d392a33Andreas Huber
2145bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    return OK;
215f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
216f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
217f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getDuration(int *msec) {
21843c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    Mutex::Autolock autoLock(mLock);
21943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
22043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    if (mDurationUs < 0) {
22143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        *msec = 0;
22243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    } else {
22343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber        *msec = (mDurationUs + 500ll) / 1000;
22443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    }
2255bc087c573c70c84c6a39946457590b42d392a33Andreas Huber
2265bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    return OK;
227f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
228f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
229f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::reset() {
2301aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    Mutex::Autolock autoLock(mLock);
2311aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    mResetInProgress = true;
2321aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber
2331aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    mPlayer->resetAsync();
2341aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber
2351aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    while (mResetInProgress) {
2361aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber        mCondition.wait(mLock);
2371aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    }
2381aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber
23943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mDurationUs = -1;
24043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mPositionUs = -1;
24143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mState = UNINITIALIZED;
24243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mStartupSeekTimeUs = -1;
24343c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
244f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
245f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
246f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
247f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::setLooping(int loop) {
248f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return INVALID_OPERATION;
249f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
250f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
251f933441648ef6a71dee783d733aac17b9508b452Andreas Huberplayer_type NuPlayerDriver::playerType() {
252f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return NU_PLAYER;
253f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
254f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
255f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::invoke(const Parcel &request, Parcel *reply) {
256f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return INVALID_OPERATION;
257f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
258f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
259f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid NuPlayerDriver::setAudioSink(const sp<AudioSink> &audioSink) {
260f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mPlayer->setAudioSink(audioSink);
261f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
262f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2634f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wangstatus_t NuPlayerDriver::setParameter(int key, const Parcel &request) {
2644f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    return INVALID_OPERATION;
2654f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang}
2664f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang
2674f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wangstatus_t NuPlayerDriver::getParameter(int key, Parcel *reply) {
2684f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang    return INVALID_OPERATION;
2694f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang}
2704f9e47f2c03ce36261c4717cd7e131d7940bb068Gloria Wang
271f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t NuPlayerDriver::getMetadata(
272f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const media::Metadata::Filter& ids, Parcel *records) {
273f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return INVALID_OPERATION;
274f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
275f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
27643c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyResetComplete() {
2771aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    Mutex::Autolock autoLock(mLock);
2781aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    CHECK(mResetInProgress);
2791aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    mResetInProgress = false;
2801aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber    mCondition.broadcast();
2811aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber}
2821aef211b4e5dc952081727bfd2318b2cb5ca4506Andreas Huber
28343c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyDuration(int64_t durationUs) {
28443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    Mutex::Autolock autoLock(mLock);
28543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mDurationUs = durationUs;
28643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber}
28743c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
28843c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifyPosition(int64_t positionUs) {
28943c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    Mutex::Autolock autoLock(mLock);
29043c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    mPositionUs = positionUs;
29143c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber}
29243c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
29343c3e6ce02215ca99d506458f596cb1211639f29Andreas Hubervoid NuPlayerDriver::notifySeekComplete() {
29443c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber    sendEvent(MEDIA_SEEK_COMPLETE);
29543c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber}
29643c3e6ce02215ca99d506458f596cb1211639f29Andreas Huber
2973fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Hubervoid NuPlayerDriver::notifyFrameStats(
2983fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber        int64_t numFramesTotal, int64_t numFramesDropped) {
2993fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    Mutex::Autolock autoLock(mLock);
3003fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    mNumFramesTotal = numFramesTotal;
3013fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    mNumFramesDropped = numFramesDropped;
3023fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber}
3033fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber
3043fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huberstatus_t NuPlayerDriver::dump(int fd, const Vector<String16> &args) const {
3053fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    Mutex::Autolock autoLock(mLock);
3063fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber
3073fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    FILE *out = fdopen(dup(fd), "w");
3083fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber
3093fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    fprintf(out, " NuPlayer\n");
3103fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    fprintf(out, "  numFramesTotal(%lld), numFramesDropped(%lld), "
3113fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber                 "percentageDropped(%.2f)\n",
3123fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber                 mNumFramesTotal,
3133fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber                 mNumFramesDropped,
3143fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber                 mNumFramesTotal == 0
3153fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber                    ? 0.0 : (double)mNumFramesDropped / mNumFramesTotal);
3163fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber
3173fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    fclose(out);
3183fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    out = NULL;
3193fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber
3203fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber    return OK;
3213fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber}
3223fe62150fa3dd6d25cb84aad80bc9e27ddd16c45Andreas Huber
323f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}  // namespace android
324