OMXNodeInstance.cpp revision 1b4ca5cebd7f42a8f8842e45bfabe19001e9a435
1318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber/*
2318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * Copyright (C) 2009 The Android Open Source Project
3318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber *
4318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * Licensed under the Apache License, Version 2.0 (the "License");
5318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * you may not use this file except in compliance with the License.
6318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * You may obtain a copy of the License at
7318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber *
8318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber *      http://www.apache.org/licenses/LICENSE-2.0
9318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber *
10318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * Unless required by applicable law or agreed to in writing, software
11318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * distributed under the License is distributed on an "AS IS" BASIS,
12318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * See the License for the specific language governing permissions and
14318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber * limitations under the License.
15318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber */
16318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
170c03d5c7c2fa4d17f7f5159e3fddd2adf6bfc923Andreas Huber//#define LOG_NDEBUG 0
18318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber#define LOG_TAG "OMXNodeInstance"
19318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber#include <utils/Log.h>
20318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
21318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber#include "../include/OMXNodeInstance.h"
22f0fb96c352f30b812a4903a1d783a715e1e817bdAndreas Huber#include "OMXMaster.h"
23f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden#include "GraphicBufferSource.h"
24318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
25e3ec3cec3a2e27033249ff82964d2cbd441d9873Andreas Huber#include <OMX_Component.h>
26318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
27318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber#include <binder/IMemory.h>
28f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden#include <gui/BufferQueue.h>
296c6b4d0d2b98a7ceee8b697daaf611f8df3254fbJames Dong#include <HardwareAPI.h>
30f1d5aa162c02a16b7195a43a9bcea4d592600ac4James Dong#include <media/stagefright/foundation/ADebug.h>
312a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber#include <media/stagefright/MediaErrors.h>
32318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
33f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFaddenstatic const OMX_U32 kPortIndexInput = 0;
34f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
35318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Hubernamespace android {
36318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
37318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstruct BufferMeta {
38318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta(const sp<IMemory> &mem, bool is_backup = false)
39318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        : mMem(mem),
40318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber          mIsBackup(is_backup) {
41318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
42318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
43318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta(size_t size)
44318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        : mSize(size),
45318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber          mIsBackup(false) {
46318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
47318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
4883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    BufferMeta(const sp<GraphicBuffer> &graphicBuffer)
4983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        : mGraphicBuffer(graphicBuffer),
5083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis          mIsBackup(false) {
5183750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    }
5283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
53318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    void CopyFromOMX(const OMX_BUFFERHEADERTYPE *header) {
54318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        if (!mIsBackup) {
55318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            return;
56318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        }
57318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
58318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        memcpy((OMX_U8 *)mMem->pointer() + header->nOffset,
59318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber               header->pBuffer + header->nOffset,
60318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber               header->nFilledLen);
61318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
62318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
63318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    void CopyToOMX(const OMX_BUFFERHEADERTYPE *header) {
64318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        if (!mIsBackup) {
65318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            return;
66318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        }
67318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
68318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        memcpy(header->pBuffer + header->nOffset,
69318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber               (const OMX_U8 *)mMem->pointer() + header->nOffset,
70318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber               header->nFilledLen);
71318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
72318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
73318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberprivate:
7483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    sp<GraphicBuffer> mGraphicBuffer;
75318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    sp<IMemory> mMem;
76318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    size_t mSize;
77318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    bool mIsBackup;
78318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
79318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta(const BufferMeta &);
80318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta &operator=(const BufferMeta &);
81318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber};
82318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
83318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber// static
84318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas HuberOMX_CALLBACKTYPE OMXNodeInstance::kCallbacks = {
85318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    &OnEvent, &OnEmptyBufferDone, &OnFillBufferDone
86318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber};
87318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
88318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas HuberOMXNodeInstance::OMXNodeInstance(
89318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX *owner, const sp<IOMXObserver> &observer)
90318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    : mOwner(owner),
91318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber      mNodeID(NULL),
92318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber      mHandle(NULL),
93134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber      mObserver(observer),
94134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber      mDying(false) {
95318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
96318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
97318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas HuberOMXNodeInstance::~OMXNodeInstance() {
98f1d5aa162c02a16b7195a43a9bcea4d592600ac4James Dong    CHECK(mHandle == NULL);
99318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
100318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
101318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Hubervoid OMXNodeInstance::setHandle(OMX::node_id node_id, OMX_HANDLETYPE handle) {
102f1d5aa162c02a16b7195a43a9bcea4d592600ac4James Dong    CHECK(mHandle == NULL);
103318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    mNodeID = node_id;
104318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    mHandle = handle;
105318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
106318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
107f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFaddensp<GraphicBufferSource> OMXNodeInstance::getGraphicBufferSource() {
108f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    Mutex::Autolock autoLock(mGraphicBufferSourceLock);
109f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    return mGraphicBufferSource;
110f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden}
111f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
112f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFaddenvoid OMXNodeInstance::setGraphicBufferSource(
113f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        const sp<GraphicBufferSource>& bufferSource) {
114f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    Mutex::Autolock autoLock(mGraphicBufferSourceLock);
115f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    mGraphicBufferSource = bufferSource;
116f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden}
117f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
118318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas HuberOMX *OMXNodeInstance::owner() {
119318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return mOwner;
120318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
121318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
122318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Hubersp<IOMXObserver> OMXNodeInstance::observer() {
123318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return mObserver;
124318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
125318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
126318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas HuberOMX::node_id OMXNodeInstance::nodeID() {
127318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return mNodeID;
128318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
129318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
130318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatic status_t StatusFromOMXError(OMX_ERRORTYPE err) {
1312a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber    switch (err) {
1322a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber        case OMX_ErrorNone:
1332a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber            return OK;
1342a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber        case OMX_ErrorUnsupportedSetting:
1352a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber            return ERROR_UNSUPPORTED;
1362a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber        default:
1372a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber            return UNKNOWN_ERROR;
1382a3847ee1cbdaa8a65eee397a0173bb02211c459Andreas Huber    }
139318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
140318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
141f0fb96c352f30b812a4903a1d783a715e1e817bdAndreas Huberstatus_t OMXNodeInstance::freeNode(OMXMaster *master) {
14243e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber    static int32_t kMaxNumIterations = 10;
14343e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber
144d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    // Transition the node from its current state all the way down
145d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    // to "Loaded".
146d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    // This ensures that all active buffers are properly freed even
147d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    // for components that don't do this themselves on a call to
148d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    // "FreeHandle".
149d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
150134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    // The code below may trigger some more events to be dispatched
151134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    // by the OMX component - we want to ignore them as our client
152134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    // does not expect them.
153134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    mDying = true;
154134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber
155d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    OMX_STATETYPE state;
156d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    CHECK_EQ(OMX_GetState(mHandle, &state), OMX_ErrorNone);
157d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    switch (state) {
158d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        case OMX_StateExecuting:
159d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        {
1603856b090cd04ba5dd4a59a12430ed724d5995909Steve Block            ALOGV("forcing Executing->Idle");
161d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            sendCommand(OMX_CommandStateSet, OMX_StateIdle);
162d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            OMX_ERRORTYPE err;
16343e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber            int32_t iteration = 0;
164d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            while ((err = OMX_GetState(mHandle, &state)) == OMX_ErrorNone
1650d681df3b0ded2c1e335b6b5785439da4ce2c238Andreas Huber                   && state != OMX_StateIdle
1660d681df3b0ded2c1e335b6b5785439da4ce2c238Andreas Huber                   && state != OMX_StateInvalid) {
16743e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber                if (++iteration > kMaxNumIterations) {
16829357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block                    ALOGE("component failed to enter Idle state, aborting.");
16943e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber                    state = OMX_StateInvalid;
17043e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber                    break;
17143e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber                }
17243e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber
173d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber                usleep(100000);
174d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            }
175d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            CHECK_EQ(err, OMX_ErrorNone);
176d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
1770d681df3b0ded2c1e335b6b5785439da4ce2c238Andreas Huber            if (state == OMX_StateInvalid) {
1780d681df3b0ded2c1e335b6b5785439da4ce2c238Andreas Huber                break;
1790d681df3b0ded2c1e335b6b5785439da4ce2c238Andreas Huber            }
1800d681df3b0ded2c1e335b6b5785439da4ce2c238Andreas Huber
181d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            // fall through
182d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        }
183d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
184d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        case OMX_StateIdle:
185d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        {
1863856b090cd04ba5dd4a59a12430ed724d5995909Steve Block            ALOGV("forcing Idle->Loaded");
187d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            sendCommand(OMX_CommandStateSet, OMX_StateLoaded);
188d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
189d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            freeActiveBuffers();
190d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
191d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            OMX_ERRORTYPE err;
19243e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber            int32_t iteration = 0;
193d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            while ((err = OMX_GetState(mHandle, &state)) == OMX_ErrorNone
1940d681df3b0ded2c1e335b6b5785439da4ce2c238Andreas Huber                   && state != OMX_StateLoaded
1950d681df3b0ded2c1e335b6b5785439da4ce2c238Andreas Huber                   && state != OMX_StateInvalid) {
19643e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber                if (++iteration > kMaxNumIterations) {
19729357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block                    ALOGE("component failed to enter Loaded state, aborting.");
19843e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber                    state = OMX_StateInvalid;
19943e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber                    break;
20043e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber                }
20143e5eca7048a3b7b3ee0223b7f3cbd837ed10ae5Andreas Huber
2023856b090cd04ba5dd4a59a12430ed724d5995909Steve Block                ALOGV("waiting for Loaded state...");
203d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber                usleep(100000);
204d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            }
205d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            CHECK_EQ(err, OMX_ErrorNone);
206d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
207d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            // fall through
208d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        }
209d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
210d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        case OMX_StateLoaded:
211fa70cad40b01627ac1c22e04cdd548ece9c2654fAndreas Huber        case OMX_StateInvalid:
212d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            break;
213d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
214d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        default:
215d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            CHECK(!"should not be here, unknown state.");
216d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            break;
217d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    }
218d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
2193856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("calling destroyComponentInstance");
220f0fb96c352f30b812a4903a1d783a715e1e817bdAndreas Huber    OMX_ERRORTYPE err = master->destroyComponentInstance(
221f0fb96c352f30b812a4903a1d783a715e1e817bdAndreas Huber            static_cast<OMX_COMPONENTTYPE *>(mHandle));
2223856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("destroyComponentInstance returned err %d", err);
223f0fb96c352f30b812a4903a1d783a715e1e817bdAndreas Huber
224318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    mHandle = NULL;
225318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
226318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    if (err != OMX_ErrorNone) {
22729357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("FreeHandle FAILED with error 0x%08x.", err);
228318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
229318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
230318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    mOwner->invalidateNodeID(mNodeID);
231318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    mNodeID = NULL;
232318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
2333856b090cd04ba5dd4a59a12430ed724d5995909Steve Block    ALOGV("OMXNodeInstance going away.");
23447bed1a7755ed58fa5d4c0d35b20468deb83bd60Andreas Huber    delete this;
235318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
236318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
237318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
238318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
239318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::sendCommand(
240318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_COMMANDTYPE cmd, OMX_S32 param) {
241318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
242318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
243318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_SendCommand(mHandle, cmd, param, NULL);
244318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
245318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
246318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
247318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::getParameter(
248318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_INDEXTYPE index, void *params, size_t size) {
249318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
250318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
251318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_GetParameter(mHandle, index, params);
252bbba88cb1bdc34705d1477208990a06904c022e7Andreas Huber
253318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
254318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
255318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
256318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::setParameter(
257318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_INDEXTYPE index, const void *params, size_t size) {
258318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
259318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
260318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_SetParameter(
261318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            mHandle, index, const_cast<void *>(params));
262318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
263318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
264318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
265318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
266318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::getConfig(
267318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_INDEXTYPE index, void *params, size_t size) {
268318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
269318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
270318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_GetConfig(mHandle, index, params);
271318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
272318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
273318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
274318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::setConfig(
275318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_INDEXTYPE index, const void *params, size_t size) {
276318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
277318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
278318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_SetConfig(
279318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            mHandle, index, const_cast<void *>(params));
280318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
281318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
282b1d666f5cb555d135eb69e005e88a03330bbb54cJamie Gennis}
283b1d666f5cb555d135eb69e005e88a03330bbb54cJamie Gennis
284b1d666f5cb555d135eb69e005e88a03330bbb54cJamie Gennisstatus_t OMXNodeInstance::getState(OMX_STATETYPE* state) {
285b1d666f5cb555d135eb69e005e88a03330bbb54cJamie Gennis    Mutex::Autolock autoLock(mLock);
286b1d666f5cb555d135eb69e005e88a03330bbb54cJamie Gennis
287b1d666f5cb555d135eb69e005e88a03330bbb54cJamie Gennis    OMX_ERRORTYPE err = OMX_GetState(mHandle, state);
288b1d666f5cb555d135eb69e005e88a03330bbb54cJamie Gennis
289b1d666f5cb555d135eb69e005e88a03330bbb54cJamie Gennis    return StatusFromOMXError(err);
290318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
291318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
29283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennisstatus_t OMXNodeInstance::enableGraphicBuffers(
29383750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        OMX_U32 portIndex, OMX_BOOL enable) {
29483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    Mutex::Autolock autoLock(mLock);
295ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis    OMX_STRING name = const_cast<OMX_STRING>(
296ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis            "OMX.google.android.index.enableAndroidNativeBuffers");
29783750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
29883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    OMX_INDEXTYPE index;
299ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis    OMX_ERRORTYPE err = OMX_GetExtensionIndex(mHandle, name, &index);
30083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
30183750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    if (err != OMX_ErrorNone) {
302d8754298b576aca4e85a059ea7b7e8f7a9502226Jamie Gennis        if (enable) {
303d8754298b576aca4e85a059ea7b7e8f7a9502226Jamie Gennis            ALOGE("OMX_GetExtensionIndex %s failed", name);
304d8754298b576aca4e85a059ea7b7e8f7a9502226Jamie Gennis        }
30583750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
30683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        return StatusFromOMXError(err);
30783750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    }
30883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
30983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    OMX_VERSIONTYPE ver;
31083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    ver.s.nVersionMajor = 1;
31183750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    ver.s.nVersionMinor = 0;
31283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    ver.s.nRevision = 0;
31383750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    ver.s.nStep = 0;
31483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    EnableAndroidNativeBuffersParams params = {
31583750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        sizeof(EnableAndroidNativeBuffersParams), ver, portIndex, enable,
31683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    };
31783750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
31883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    err = OMX_SetParameter(mHandle, index, &params);
31983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
32083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    if (err != OMX_ErrorNone) {
32129357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("OMX_EnableAndroidNativeBuffers failed with error %d (0x%08x)",
32283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis                err, err);
32383750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
32483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        return UNKNOWN_ERROR;
32583750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    }
32683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
32783750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    return OK;
32883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis}
32983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
330e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennisstatus_t OMXNodeInstance::getGraphicBufferUsage(
331e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis        OMX_U32 portIndex, OMX_U32* usage) {
332e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    Mutex::Autolock autoLock(mLock);
333e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
334e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    OMX_INDEXTYPE index;
335ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis    OMX_STRING name = const_cast<OMX_STRING>(
336ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis            "OMX.google.android.index.getAndroidNativeBufferUsage");
337ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis    OMX_ERRORTYPE err = OMX_GetExtensionIndex(mHandle, name, &index);
338e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
339e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    if (err != OMX_ErrorNone) {
340ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis        ALOGE("OMX_GetExtensionIndex %s failed", name);
341e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
342e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis        return StatusFromOMXError(err);
343e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    }
344e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
345e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    OMX_VERSIONTYPE ver;
346e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    ver.s.nVersionMajor = 1;
347e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    ver.s.nVersionMinor = 0;
348e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    ver.s.nRevision = 0;
349e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    ver.s.nStep = 0;
350e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    GetAndroidNativeBufferUsageParams params = {
351e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis        sizeof(GetAndroidNativeBufferUsageParams), ver, portIndex, 0,
352e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    };
353e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
354e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    err = OMX_GetParameter(mHandle, index, &params);
355e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
356e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    if (err != OMX_ErrorNone) {
35729357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("OMX_GetAndroidNativeBufferUsage failed with error %d (0x%08x)",
358e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis                err, err);
359e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis        return UNKNOWN_ERROR;
360e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    }
361e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
362e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    *usage = params.nUsage;
363e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
364e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis    return OK;
365e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis}
366e2ce6458659c6e1bad420357b61dc10cd8bbe2abJamie Gennis
367e870772a78ffe08b1c14a791e368f1499f1be0f3James Dongstatus_t OMXNodeInstance::storeMetaDataInBuffers(
368e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong        OMX_U32 portIndex,
369e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong        OMX_BOOL enable) {
370e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    Mutex::Autolock autolock(mLock);
371f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    return storeMetaDataInBuffers_l(portIndex, enable);
372f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden}
373e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong
374f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFaddenstatus_t OMXNodeInstance::storeMetaDataInBuffers_l(
375f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        OMX_U32 portIndex,
376f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        OMX_BOOL enable) {
377e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    OMX_INDEXTYPE index;
378e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    OMX_STRING name = const_cast<OMX_STRING>(
379e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong            "OMX.google.android.index.storeMetaDataInBuffers");
380e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong
381e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    OMX_ERRORTYPE err = OMX_GetExtensionIndex(mHandle, name, &index);
382e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    if (err != OMX_ErrorNone) {
383d8754298b576aca4e85a059ea7b7e8f7a9502226Jamie Gennis        ALOGE("OMX_GetExtensionIndex %s failed", name);
384d8754298b576aca4e85a059ea7b7e8f7a9502226Jamie Gennis
385e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong        return StatusFromOMXError(err);
386e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    }
387e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong
388e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    StoreMetaDataInBuffersParams params;
389e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    memset(&params, 0, sizeof(params));
390e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    params.nSize = sizeof(params);
391e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong
392e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    // Version: 1.0.0.0
393e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    params.nVersion.s.nVersionMajor = 1;
394e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong
395e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    params.nPortIndex = portIndex;
396e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    params.bStoreMetaData = enable;
397e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    if ((err = OMX_SetParameter(mHandle, index, &params)) != OMX_ErrorNone) {
39829357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("OMX_SetParameter() failed for StoreMetaDataInBuffers: 0x%08x", err);
399e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong        return UNKNOWN_ERROR;
400e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    }
401e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong    return err;
402e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong}
403e870772a78ffe08b1c14a791e368f1499f1be0f3James Dong
404318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::useBuffer(
405318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_U32 portIndex, const sp<IMemory> &params,
406318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX::buffer_id *buffer) {
407318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
408318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
409318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta *buffer_meta = new BufferMeta(params);
410318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
411318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_BUFFERHEADERTYPE *header;
412318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
413318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_UseBuffer(
414318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            mHandle, &header, portIndex, buffer_meta,
415318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            params->size(), static_cast<OMX_U8 *>(params->pointer()));
416318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
417318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    if (err != OMX_ErrorNone) {
41829357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("OMX_UseBuffer failed with error %d (0x%08x)", err, err);
419318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
420318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        delete buffer_meta;
421318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        buffer_meta = NULL;
422318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
423318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        *buffer = 0;
424318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
425318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        return UNKNOWN_ERROR;
426318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
427318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
42803b268eac37ca2589bfff0bf58daf79d29cc14f4Andreas Huber    CHECK_EQ(header->pAppPrivate, buffer_meta);
42903b268eac37ca2589bfff0bf58daf79d29cc14f4Andreas Huber
430318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    *buffer = header;
431318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
432d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    addActiveBuffer(portIndex, *buffer);
433d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
434f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    sp<GraphicBufferSource> bufferSource(getGraphicBufferSource());
435f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if (bufferSource != NULL && portIndex == kPortIndexInput) {
436f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        bufferSource->addCodecBuffer(header);
437f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    }
438f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
439318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return OK;
440318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
441318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
442c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajanstatus_t OMXNodeInstance::useGraphicBuffer2_l(
443c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan        OMX_U32 portIndex, const sp<GraphicBuffer>& graphicBuffer,
444c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan        OMX::buffer_id *buffer) {
445c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
446c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    // port definition
447c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    OMX_PARAM_PORTDEFINITIONTYPE def;
448c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    def.nSize = sizeof(OMX_PARAM_PORTDEFINITIONTYPE);
449c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    def.nVersion.s.nVersionMajor = 1;
450c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    def.nVersion.s.nVersionMinor = 0;
451c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    def.nVersion.s.nRevision = 0;
452c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    def.nVersion.s.nStep = 0;
453c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    def.nPortIndex = portIndex;
454c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    OMX_ERRORTYPE err = OMX_GetParameter(mHandle, OMX_IndexParamPortDefinition, &def);
455a0dac9e24ae7520cb7d7f0505bf0936bffbcd047Jamie Gennis    if (err != OMX_ErrorNone)
456c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    {
45729357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("%s::%d:Error getting OMX_IndexParamPortDefinition", __FUNCTION__, __LINE__);
458c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan        return err;
459c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    }
460c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
461c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    BufferMeta *bufferMeta = new BufferMeta(graphicBuffer);
462c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
463c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    OMX_BUFFERHEADERTYPE *header = NULL;
464c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    OMX_U8* bufferHandle = const_cast<OMX_U8*>(
465c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            reinterpret_cast<const OMX_U8*>(graphicBuffer->handle));
466c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
467c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    err = OMX_UseBuffer(
468c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            mHandle,
469c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            &header,
470c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            portIndex,
471c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            bufferMeta,
472c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            def.nBufferSize,
473c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            bufferHandle);
474c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
475c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    if (err != OMX_ErrorNone) {
47629357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("OMX_UseBuffer failed with error %d (0x%08x)", err, err);
477c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan        delete bufferMeta;
478c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan        bufferMeta = NULL;
479c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan        *buffer = 0;
480c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan        return UNKNOWN_ERROR;
481c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    }
482c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
483c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    CHECK_EQ(header->pBuffer, bufferHandle);
484c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    CHECK_EQ(header->pAppPrivate, bufferMeta);
485c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
486c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    *buffer = header;
487c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
488c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    addActiveBuffer(portIndex, *buffer);
489c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
490c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    return OK;
491c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan}
492c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
493c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan// XXX: This function is here for backwards compatibility.  Once the OMX
494c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan// implementations have been updated this can be removed and useGraphicBuffer2
495c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan// can be renamed to useGraphicBuffer.
49683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennisstatus_t OMXNodeInstance::useGraphicBuffer(
49783750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        OMX_U32 portIndex, const sp<GraphicBuffer>& graphicBuffer,
49883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        OMX::buffer_id *buffer) {
49983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    Mutex::Autolock autoLock(mLock);
50083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
501c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    // See if the newer version of the extension is present.
50283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    OMX_INDEXTYPE index;
503c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    if (OMX_GetExtensionIndex(
504c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            mHandle,
505c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            const_cast<OMX_STRING>("OMX.google.android.index.useAndroidNativeBuffer2"),
506c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan            &index) == OMX_ErrorNone) {
507c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan        return useGraphicBuffer2_l(portIndex, graphicBuffer, buffer);
508c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan    }
509c5a57efb706ec79032fc09c43b16d11ed0876604Anu Sundararajan
510ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis    OMX_STRING name = const_cast<OMX_STRING>(
511ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis        "OMX.google.android.index.useAndroidNativeBuffer");
512ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis    OMX_ERRORTYPE err = OMX_GetExtensionIndex(mHandle, name, &index);
51383750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
51483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    if (err != OMX_ErrorNone) {
515ce18d7d85a78ac6642624fef1b5831eff4c72d56Jamie Gennis        ALOGE("OMX_GetExtensionIndex %s failed", name);
51683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
51783750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        return StatusFromOMXError(err);
51883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    }
51983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
52083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    BufferMeta *bufferMeta = new BufferMeta(graphicBuffer);
52183750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
52283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    OMX_BUFFERHEADERTYPE *header;
52383750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
52483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    OMX_VERSIONTYPE ver;
52583750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    ver.s.nVersionMajor = 1;
52683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    ver.s.nVersionMinor = 0;
52783750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    ver.s.nRevision = 0;
52883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    ver.s.nStep = 0;
52983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    UseAndroidNativeBufferParams params = {
53083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        sizeof(UseAndroidNativeBufferParams), ver, portIndex, bufferMeta,
53183750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        &header, graphicBuffer,
53283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    };
53383750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
53483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    err = OMX_SetParameter(mHandle, index, &params);
53583750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
53683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    if (err != OMX_ErrorNone) {
53729357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("OMX_UseAndroidNativeBuffer failed with error %d (0x%08x)", err,
53883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis                err);
53983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
54083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        delete bufferMeta;
54183750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        bufferMeta = NULL;
54283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
54383750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        *buffer = 0;
54483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
54583750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis        return UNKNOWN_ERROR;
54683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    }
54783750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
54883750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    CHECK_EQ(header->pAppPrivate, bufferMeta);
54983750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
55083750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    *buffer = header;
55183750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
55283750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    addActiveBuffer(portIndex, *buffer);
55383750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
55483750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis    return OK;
55583750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis}
55683750eaf5a3f38c243a9e7eb81d4b2421e3a0d88Jamie Gennis
557f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFaddenstatus_t OMXNodeInstance::createInputSurface(
558f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        OMX_U32 portIndex, sp<IGraphicBufferProducer> *bufferProducer) {
559f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    Mutex::Autolock autolock(mLock);
560f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    status_t err;
561f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
562f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    const sp<GraphicBufferSource>& surfaceCheck = getGraphicBufferSource();
563f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if (surfaceCheck != NULL) {
564f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        return ALREADY_EXISTS;
565f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    }
566f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
567f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    // Input buffers will hold meta-data (gralloc references).
568f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    err = storeMetaDataInBuffers_l(portIndex, OMX_TRUE);
569f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if (err != OK) {
570f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        return err;
571f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    }
572f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
573f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    // Retrieve the width and height of the graphic buffer, set when the
574f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    // codec was configured.
575f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    OMX_PARAM_PORTDEFINITIONTYPE def;
576f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    def.nSize = sizeof(def);
577f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    def.nVersion.s.nVersionMajor = 1;
578f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    def.nVersion.s.nVersionMinor = 0;
579f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    def.nVersion.s.nRevision = 0;
580f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    def.nVersion.s.nStep = 0;
581f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    def.nPortIndex = portIndex;
582f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    OMX_ERRORTYPE oerr = OMX_GetParameter(
583f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden            mHandle, OMX_IndexParamPortDefinition, &def);
584f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    CHECK(oerr == OMX_ErrorNone);
585f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
586ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden    if (def.format.video.eColorFormat != OMX_COLOR_FormatAndroidOpaque) {
587ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden        ALOGE("createInputSurface requires AndroidOpaque color format");
588ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden        return INVALID_OPERATION;
589ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden    }
590ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden
591f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    GraphicBufferSource* bufferSource = new GraphicBufferSource(
5920c37f9d1320bb87fd242f9425c67dacd6ce20112Andy McFadden            this, def.format.video.nFrameWidth, def.format.video.nFrameHeight,
5930c37f9d1320bb87fd242f9425c67dacd6ce20112Andy McFadden            def.nBufferCountActual);
594f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if ((err = bufferSource->initCheck()) != OK) {
595f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        delete bufferSource;
596f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        return err;
597f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    }
598f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    setGraphicBufferSource(bufferSource);
599f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
600f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    *bufferProducer = bufferSource->getIGraphicBufferProducer();
601f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    return OK;
602f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden}
603f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
604f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFaddenstatus_t OMXNodeInstance::signalEndOfInputStream() {
605f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    // For non-Surface input, the MediaCodec should convert the call to a
606f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    // pair of requests (dequeue input buffer, queue input buffer with EOS
607f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    // flag set).  Seems easier than doing the equivalent from here.
608f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    sp<GraphicBufferSource> bufferSource(getGraphicBufferSource());
609f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if (bufferSource == NULL) {
610ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden        ALOGW("signalEndOfInputStream can only be used with Surface input");
611f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        return INVALID_OPERATION;
612f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    };
613ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden    return bufferSource->signalEndOfInputStream();
614f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden}
615f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
616318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::allocateBuffer(
617570a3cb7582daa030cb38eedc5eb6a06f86ecc7fAndreas Huber        OMX_U32 portIndex, size_t size, OMX::buffer_id *buffer,
618570a3cb7582daa030cb38eedc5eb6a06f86ecc7fAndreas Huber        void **buffer_data) {
619318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
620318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
621318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta *buffer_meta = new BufferMeta(size);
622318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
623318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_BUFFERHEADERTYPE *header;
624318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
625318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_AllocateBuffer(
626318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            mHandle, &header, portIndex, buffer_meta, size);
627318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
628318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    if (err != OMX_ErrorNone) {
62929357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("OMX_AllocateBuffer failed with error %d (0x%08x)", err, err);
630318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
631318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        delete buffer_meta;
632318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        buffer_meta = NULL;
633318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
634318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        *buffer = 0;
635318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
636318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        return UNKNOWN_ERROR;
637318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
638318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
63903b268eac37ca2589bfff0bf58daf79d29cc14f4Andreas Huber    CHECK_EQ(header->pAppPrivate, buffer_meta);
64003b268eac37ca2589bfff0bf58daf79d29cc14f4Andreas Huber
641318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    *buffer = header;
642570a3cb7582daa030cb38eedc5eb6a06f86ecc7fAndreas Huber    *buffer_data = header->pBuffer;
643318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
644d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    addActiveBuffer(portIndex, *buffer);
645d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
646f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    sp<GraphicBufferSource> bufferSource(getGraphicBufferSource());
647f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if (bufferSource != NULL && portIndex == kPortIndexInput) {
648f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        bufferSource->addCodecBuffer(header);
649f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    }
650f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
651318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return OK;
652318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
653318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
654318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::allocateBufferWithBackup(
655318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_U32 portIndex, const sp<IMemory> &params,
656318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX::buffer_id *buffer) {
657318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
658318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
659318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta *buffer_meta = new BufferMeta(params, true);
660318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
661318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_BUFFERHEADERTYPE *header;
662318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
663318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_AllocateBuffer(
664318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            mHandle, &header, portIndex, buffer_meta, params->size());
665318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
666318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    if (err != OMX_ErrorNone) {
66729357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block        ALOGE("OMX_AllocateBuffer failed with error %d (0x%08x)", err, err);
668318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
669318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        delete buffer_meta;
670318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        buffer_meta = NULL;
671318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
672318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        *buffer = 0;
673318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
674318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        return UNKNOWN_ERROR;
675318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
676318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
67703b268eac37ca2589bfff0bf58daf79d29cc14f4Andreas Huber    CHECK_EQ(header->pAppPrivate, buffer_meta);
67803b268eac37ca2589bfff0bf58daf79d29cc14f4Andreas Huber
679318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    *buffer = header;
680318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
681d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    addActiveBuffer(portIndex, *buffer);
682d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
683f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    sp<GraphicBufferSource> bufferSource(getGraphicBufferSource());
684f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if (bufferSource != NULL && portIndex == kPortIndexInput) {
685f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        bufferSource->addCodecBuffer(header);
686f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    }
687f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
688318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return OK;
689318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
690318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
691318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::freeBuffer(
692318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_U32 portIndex, OMX::buffer_id buffer) {
693318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
694318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
695d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    removeActiveBuffer(portIndex, buffer);
696d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
697318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_BUFFERHEADERTYPE *header = (OMX_BUFFERHEADERTYPE *)buffer;
698318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta *buffer_meta = static_cast<BufferMeta *>(header->pAppPrivate);
699318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
700318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_FreeBuffer(mHandle, portIndex, header);
701318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
702318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    delete buffer_meta;
703318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    buffer_meta = NULL;
704318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
705318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
706318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
707318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
708318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::fillBuffer(OMX::buffer_id buffer) {
709318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
710318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
711318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_BUFFERHEADERTYPE *header = (OMX_BUFFERHEADERTYPE *)buffer;
712318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    header->nFilledLen = 0;
713318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    header->nOffset = 0;
714318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    header->nFlags = 0;
715318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
716318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_FillThisBuffer(mHandle, header);
717318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
718318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
719318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
720318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
721318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::emptyBuffer(
722318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX::buffer_id buffer,
723318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_U32 rangeOffset, OMX_U32 rangeLength,
724318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_U32 flags, OMX_TICKS timestamp) {
725318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
726318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
727318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_BUFFERHEADERTYPE *header = (OMX_BUFFERHEADERTYPE *)buffer;
728318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    header->nFilledLen = rangeLength;
729318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    header->nOffset = rangeOffset;
730318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    header->nFlags = flags;
731318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    header->nTimeStamp = timestamp;
732318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
733318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    BufferMeta *buffer_meta =
734318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        static_cast<BufferMeta *>(header->pAppPrivate);
735318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    buffer_meta->CopyToOMX(header);
736318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
737318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_EmptyThisBuffer(mHandle, header);
738318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
739318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
740318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
741318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
742f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden// like emptyBuffer, but the data is already in header->pBuffer
743f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFaddenstatus_t OMXNodeInstance::emptyDirectBuffer(
744f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        OMX_BUFFERHEADERTYPE *header,
745f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        OMX_U32 rangeOffset, OMX_U32 rangeLength,
746f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        OMX_U32 flags, OMX_TICKS timestamp) {
747f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    Mutex::Autolock autoLock(mLock);
748f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
749f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    header->nFilledLen = rangeLength;
750f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    header->nOffset = rangeOffset;
751f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    header->nFlags = flags;
752f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    header->nTimeStamp = timestamp;
753f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
754f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    OMX_ERRORTYPE err = OMX_EmptyThisBuffer(mHandle, header);
755f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if (err != OMX_ErrorNone) {
756f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        ALOGW("emptyDirectBuffer failed, OMX err=0x%x", err);
757f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    }
758f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
759f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    return StatusFromOMXError(err);
760f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden}
761f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
762318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huberstatus_t OMXNodeInstance::getExtensionIndex(
763318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        const char *parameterName, OMX_INDEXTYPE *index) {
764318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    Mutex::Autolock autoLock(mLock);
765318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
766318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMX_ERRORTYPE err = OMX_GetExtensionIndex(
767318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            mHandle, const_cast<char *>(parameterName), index);
768318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
769318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return StatusFromOMXError(err);
770318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
771318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
772318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Hubervoid OMXNodeInstance::onMessage(const omx_message &msg) {
773318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    if (msg.type == omx_message::FILL_BUFFER_DONE) {
774318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_BUFFERHEADERTYPE *buffer =
775318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            static_cast<OMX_BUFFERHEADERTYPE *>(
776318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber                    msg.u.extended_buffer_data.buffer);
777318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
778318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        BufferMeta *buffer_meta =
779318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            static_cast<BufferMeta *>(buffer->pAppPrivate);
780318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
781318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        buffer_meta->CopyFromOMX(buffer);
7821b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber    } else if (msg.type == omx_message::EMPTY_BUFFER_DONE) {
7831b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber        const sp<GraphicBufferSource>& bufferSource(getGraphicBufferSource());
7841b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber
7851b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber        if (bufferSource != NULL) {
7861b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber            // This is one of the buffers used exclusively by
7871b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber            // GraphicBufferSource.
7881b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber            // Don't dispatch a message back to ACodec, since it doesn't
7891b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber            // know that anyone asked to have the buffer emptied and will
7901b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber            // be very confused.
7911b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber
7921b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber            OMX_BUFFERHEADERTYPE *buffer =
7931b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber                static_cast<OMX_BUFFERHEADERTYPE *>(
7941b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber                        msg.u.buffer_data.buffer);
7951b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber
7961b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber            bufferSource->codecBufferEmptied(buffer);
7971b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber            return;
7981b4ca5cebd7f42a8f8842e45bfabe19001e9a435Andreas Huber        }
799318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    }
800318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
801318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    mObserver->onMessage(msg);
802318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
803318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
804f0fb96c352f30b812a4903a1d783a715e1e817bdAndreas Hubervoid OMXNodeInstance::onObserverDied(OMXMaster *master) {
80529357bc2c0dd7c43ad3bd0c8e3efa4e6fd9bfd47Steve Block    ALOGE("!!! Observer died. Quickly, do something, ... anything...");
806318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
807318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    // Try to force shutdown of the node and hope for the best.
808f0fb96c352f30b812a4903a1d783a715e1e817bdAndreas Huber    freeNode(master);
809318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
810318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
811318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Hubervoid OMXNodeInstance::onGetHandleFailed() {
812318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    delete this;
813318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
814318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
815f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden// OMXNodeInstance::OnEvent calls OMX::OnEvent, which then calls here.
816f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden// Don't try to acquire mLock here -- in rare circumstances this will hang.
817f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFaddenvoid OMXNodeInstance::onEvent(
818f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        OMX_EVENTTYPE event, OMX_U32 arg1, OMX_U32 arg2) {
819f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    const sp<GraphicBufferSource>& bufferSource(getGraphicBufferSource());
820f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
821f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    if (bufferSource != NULL && event == OMX_EventCmdComplete &&
822f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden            arg1 == OMX_CommandStateSet) {
823f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        if (arg2 == OMX_StateExecuting) {
824f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden            bufferSource->omxExecuting();
825ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden        } else if (arg2 == OMX_StateLoaded) {
826ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden            // Must be shutting down -- won't have a GraphicBufferSource
827ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden            // on the way up.
828ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden            bufferSource->omxLoaded();
829ba6218eae3dbcf3f962b3561b26374a214dbf5e2Andy McFadden            setGraphicBufferSource(NULL);
830f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden        }
831f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden    }
832f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden}
833f779bb50d9746d9526541c3e6dcdf619cac941b7Andy McFadden
834318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber// static
835318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas HuberOMX_ERRORTYPE OMXNodeInstance::OnEvent(
836318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_HANDLETYPE hComponent,
837318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_PTR pAppData,
838318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_EVENTTYPE eEvent,
839318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_U32 nData1,
840318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_U32 nData2,
841318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_PTR pEventData) {
842318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMXNodeInstance *instance = static_cast<OMXNodeInstance *>(pAppData);
843134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    if (instance->mDying) {
844134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber        return OMX_ErrorNone;
845134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    }
846318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return instance->owner()->OnEvent(
847318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber            instance->nodeID(), eEvent, nData1, nData2, pEventData);
848318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
849318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
850318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber// static
851318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas HuberOMX_ERRORTYPE OMXNodeInstance::OnEmptyBufferDone(
852318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_HANDLETYPE hComponent,
853318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_PTR pAppData,
854318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_BUFFERHEADERTYPE* pBuffer) {
855318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMXNodeInstance *instance = static_cast<OMXNodeInstance *>(pAppData);
856134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    if (instance->mDying) {
857134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber        return OMX_ErrorNone;
858134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    }
859318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return instance->owner()->OnEmptyBufferDone(instance->nodeID(), pBuffer);
860318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
861318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
862318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber// static
863318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas HuberOMX_ERRORTYPE OMXNodeInstance::OnFillBufferDone(
864318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_HANDLETYPE hComponent,
865318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_PTR pAppData,
866318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber        OMX_IN OMX_BUFFERHEADERTYPE* pBuffer) {
867318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    OMXNodeInstance *instance = static_cast<OMXNodeInstance *>(pAppData);
868134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    if (instance->mDying) {
869134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber        return OMX_ErrorNone;
870134ee6a324c35f39e3576172e4eae4c6de6eb9dcAndreas Huber    }
871318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber    return instance->owner()->OnFillBufferDone(instance->nodeID(), pBuffer);
872318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}
873318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber
874d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Hubervoid OMXNodeInstance::addActiveBuffer(OMX_U32 portIndex, OMX::buffer_id id) {
875d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    ActiveBuffer active;
876d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    active.mPortIndex = portIndex;
877d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    active.mID = id;
878d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    mActiveBuffers.push(active);
879d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber}
880d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
881d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Hubervoid OMXNodeInstance::removeActiveBuffer(
882d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        OMX_U32 portIndex, OMX::buffer_id id) {
883d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    bool found = false;
884d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    for (size_t i = 0; i < mActiveBuffers.size(); ++i) {
885d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        if (mActiveBuffers[i].mPortIndex == portIndex
886d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            && mActiveBuffers[i].mID == id) {
887d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            found = true;
888d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            mActiveBuffers.removeItemsAt(i);
889d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber            break;
890d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        }
891d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    }
892d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
893d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    if (!found) {
8945ff1dd576bb93c45b44088a51544a18fc43ebf58Steve Block        ALOGW("Attempt to remove an active buffer we know nothing about...");
895d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    }
896d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber}
897d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
898d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Hubervoid OMXNodeInstance::freeActiveBuffers() {
899d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    // Make sure to count down here, as freeBuffer will in turn remove
900d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    // the active buffer from the vector...
901d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    for (size_t i = mActiveBuffers.size(); i--;) {
902d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber        freeBuffer(mActiveBuffers[i].mPortIndex, mActiveBuffers[i].mID);
903d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber    }
904d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber}
905d6703ab22c85b43fdb2deb78a37e51465c902a5fAndreas Huber
906318ad9c1d9d6515026dfc2c021359d27decaa7a1Andreas Huber}  // namespace android
907