ACodec.cpp revision 9bc7af17974f448291a44912566ec7472a0d798b
127c174483a8ae9688d5d4897c19074f62c7f1701James Dong/*
227c174483a8ae9688d5d4897c19074f62c7f1701James Dong * Copyright (C) 2010 The Android Open Source Project
327c174483a8ae9688d5d4897c19074f62c7f1701James Dong *
427c174483a8ae9688d5d4897c19074f62c7f1701James Dong * Licensed under the Apache License, Version 2.0 (the "License");
527c174483a8ae9688d5d4897c19074f62c7f1701James Dong * you may not use this file except in compliance with the License.
627c174483a8ae9688d5d4897c19074f62c7f1701James Dong * You may obtain a copy of the License at
727c174483a8ae9688d5d4897c19074f62c7f1701James Dong *
827c174483a8ae9688d5d4897c19074f62c7f1701James Dong *      http://www.apache.org/licenses/LICENSE-2.0
927c174483a8ae9688d5d4897c19074f62c7f1701James Dong *
1027c174483a8ae9688d5d4897c19074f62c7f1701James Dong * Unless required by applicable law or agreed to in writing, software
1127c174483a8ae9688d5d4897c19074f62c7f1701James Dong * distributed under the License is distributed on an "AS IS" BASIS,
1227c174483a8ae9688d5d4897c19074f62c7f1701James Dong * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1327c174483a8ae9688d5d4897c19074f62c7f1701James Dong * See the License for the specific language governing permissions and
1427c174483a8ae9688d5d4897c19074f62c7f1701James Dong * limitations under the License.
1527c174483a8ae9688d5d4897c19074f62c7f1701James Dong */
1627c174483a8ae9688d5d4897c19074f62c7f1701James Dong
17f933441648ef6a71dee783d733aac17b9508b452Andreas Huber//#define LOG_NDEBUG 0
18f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#define LOG_TAG "ACodec"
19f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
20f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/ACodec.h>
21f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
22f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <binder/MemoryDealer.h>
23f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
24f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/foundation/hexdump.h>
25f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/foundation/ABuffer.h>
26f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/foundation/ADebug.h>
27f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/foundation/AMessage.h>
28f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
29f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/MediaDefs.h>
301173118eace0e9e347cb007f0da817cee87579edGlenn Kasten#include <media/stagefright/NativeWindowWrapper.h>
31f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <media/stagefright/OMXClient.h>
321065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber#include <media/stagefright/OMXCodec.h>
33f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
34f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <surfaceflinger/Surface.h>
351173118eace0e9e347cb007f0da817cee87579edGlenn Kasten#include <gui/SurfaceTextureClient.h>
36f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
37f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#include <OMX_Component.h>
38f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
39f933441648ef6a71dee783d733aac17b9508b452Andreas Hubernamespace android {
40f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
41f933441648ef6a71dee783d733aac17b9508b452Andreas Hubertemplate<class T>
42f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatic void InitOMXParams(T *params) {
43f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    params->nSize = sizeof(T);
44f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    params->nVersion.s.nVersionMajor = 1;
45f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    params->nVersion.s.nVersionMinor = 0;
46f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    params->nVersion.s.nRevision = 0;
47f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    params->nVersion.s.nStep = 0;
48f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
49f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
50f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct CodecObserver : public BnOMXObserver {
51f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CodecObserver() {}
52f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
53f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    void setNotificationMessage(const sp<AMessage> &msg) {
54f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mNotify = msg;
55f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
56f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
57f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    // from IOMXObserver
58f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void onMessage(const omx_message &omx_msg) {
59f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        sp<AMessage> msg = mNotify->dup();
60f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
61f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        msg->setInt32("type", omx_msg.type);
62f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        msg->setPointer("node", omx_msg.node);
63f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
64f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        switch (omx_msg.type) {
65f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            case omx_message::EVENT:
66f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            {
67f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setInt32("event", omx_msg.u.event_data.event);
68f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setInt32("data1", omx_msg.u.event_data.data1);
69f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setInt32("data2", omx_msg.u.event_data.data2);
70f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                break;
71f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
72f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
73f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            case omx_message::EMPTY_BUFFER_DONE:
74f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            {
75f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setPointer("buffer", omx_msg.u.buffer_data.buffer);
76f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                break;
77f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
78f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
79f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            case omx_message::FILL_BUFFER_DONE:
80f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            {
81f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setPointer(
82f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        "buffer", omx_msg.u.extended_buffer_data.buffer);
83f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setInt32(
84f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        "range_offset",
85f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        omx_msg.u.extended_buffer_data.range_offset);
86f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setInt32(
87f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        "range_length",
88f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        omx_msg.u.extended_buffer_data.range_length);
89f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setInt32(
90f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        "flags",
91f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        omx_msg.u.extended_buffer_data.flags);
92f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setInt64(
93f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        "timestamp",
94f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        omx_msg.u.extended_buffer_data.timestamp);
95f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setPointer(
96f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        "platform_private",
97f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        omx_msg.u.extended_buffer_data.platform_private);
98f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                msg->setPointer(
99f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        "data_ptr",
100f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        omx_msg.u.extended_buffer_data.data_ptr);
101f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                break;
102f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
103f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
104f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            default:
105f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                TRESPASS();
106f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                break;
107f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
108f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
109f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        msg->post();
110f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
111f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
112f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
113f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual ~CodecObserver() {}
114f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
115f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
116f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    sp<AMessage> mNotify;
117f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
118f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(CodecObserver);
119f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
120f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
121f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
122f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
123f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::BaseState : public AState {
124f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BaseState(ACodec *codec, const sp<AState> &parentState = NULL);
125f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
126f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
127f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    enum PortMode {
128f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        KEEP_BUFFERS,
129f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        RESUBMIT_BUFFERS,
130f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        FREE_BUFFERS,
131f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    };
132f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
133f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    ACodec *mCodec;
134f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
135f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual PortMode getPortMode(OMX_U32 portIndex);
136f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
137f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
138f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
139f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
140f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
141f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void onOutputBufferDrained(const sp<AMessage> &msg);
142f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void onInputBufferFilled(const sp<AMessage> &msg);
143f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
144f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    void postFillThisBuffer(BufferInfo *info);
145f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
146f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
147f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool onOMXMessage(const sp<AMessage> &msg);
148f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
149f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool onOMXEmptyBufferDone(IOMX::buffer_id bufferID);
150f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
151f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool onOMXFillBufferDone(
152f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            IOMX::buffer_id bufferID,
153f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            size_t rangeOffset, size_t rangeLength,
154f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            OMX_U32 flags,
155f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            int64_t timeUs,
156f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            void *platformPrivate,
157f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            void *dataPtr);
158f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
159f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    void getMoreInputDataIfPossible();
160f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
161f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(BaseState);
162f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
163f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
164f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
165f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
166f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::UninitializedState : public ACodec::BaseState {
167f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    UninitializedState(ACodec *codec);
168f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
169f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
170f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
171f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
172f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
173f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    void onSetup(const sp<AMessage> &msg);
174f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
175f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(UninitializedState);
176f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
177f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
178f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
179f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
180f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::LoadedToIdleState : public ACodec::BaseState {
181f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    LoadedToIdleState(ACodec *codec);
182f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
183f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
184f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
185f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
186f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void stateEntered();
187f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
188f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
189f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t allocateBuffers();
190f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
191f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(LoadedToIdleState);
192f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
193f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
194f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
195f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
196f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::IdleToExecutingState : public ACodec::BaseState {
197f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    IdleToExecutingState(ACodec *codec);
198f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
199f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
200f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
201f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
202f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void stateEntered();
203f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
204f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
205f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(IdleToExecutingState);
206f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
207f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
208f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
209f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
210f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::ExecutingState : public ACodec::BaseState {
211f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    ExecutingState(ACodec *codec);
212f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
213f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    void submitOutputBuffers();
214f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
215f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    // Submit output buffers to the decoder, submit input buffers to client
216f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    // to fill with data.
217f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    void resume();
218f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
219349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    // Returns true iff input and output buffers are in play.
220349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    bool active() const { return mActive; }
221349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
222f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
223f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual PortMode getPortMode(OMX_U32 portIndex);
224f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
225f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void stateEntered();
226f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
227f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
228f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
229f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
230349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    bool mActive;
231349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
232f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(ExecutingState);
233f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
234f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
235f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
236f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
237f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::OutputPortSettingsChangedState : public ACodec::BaseState {
238f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OutputPortSettingsChangedState(ACodec *codec);
239f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
240f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
241f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual PortMode getPortMode(OMX_U32 portIndex);
242f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
243f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void stateEntered();
244f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
245f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
246f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
247f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
248f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(OutputPortSettingsChangedState);
249f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
250f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
251f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
252f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
253f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::ExecutingToIdleState : public ACodec::BaseState {
254f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    ExecutingToIdleState(ACodec *codec);
255f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
256f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
257f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
258f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void stateEntered();
259f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
260f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
261f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
262f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void onOutputBufferDrained(const sp<AMessage> &msg);
263f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void onInputBufferFilled(const sp<AMessage> &msg);
264f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
265f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
266f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    void changeStateIfWeOwnAllBuffers();
267f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
268f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(ExecutingToIdleState);
269f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
270f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
271f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
272f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
273f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::IdleToLoadedState : public ACodec::BaseState {
274f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    IdleToLoadedState(ACodec *codec);
275f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
276f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
277f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
278f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void stateEntered();
279f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
280f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
281f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
282f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
283f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(IdleToLoadedState);
284f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
285f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
286f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
287f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
288f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::ErrorState : public ACodec::BaseState {
289f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    ErrorState(ACodec *codec);
290f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
291f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
292f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
293f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void stateEntered();
294f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
295f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
296f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
297f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
298f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(ErrorState);
299f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
300f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
301f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
302f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
303f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstruct ACodec::FlushingState : public ACodec::BaseState {
304f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    FlushingState(ACodec *codec);
305f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
306f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprotected:
307f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onMessageReceived(const sp<AMessage> &msg);
308f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void stateEntered();
309f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
310f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual bool onOMXEvent(OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2);
311f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
312f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void onOutputBufferDrained(const sp<AMessage> &msg);
313f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    virtual void onInputBufferFilled(const sp<AMessage> &msg);
314f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
315f933441648ef6a71dee783d733aac17b9508b452Andreas Huberprivate:
316f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool mFlushComplete[2];
317f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
318f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    void changeStateIfWeOwnAllBuffers();
319f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
320f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    DISALLOW_EVIL_CONSTRUCTORS(FlushingState);
321f933441648ef6a71dee783d733aac17b9508b452Andreas Huber};
322f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
323f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
324f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
325f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::ACodec()
32631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    : mNode(NULL),
32731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber      mSentFormat(false) {
328f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mUninitializedState = new UninitializedState(this);
329f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mLoadedToIdleState = new LoadedToIdleState(this);
330f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mIdleToExecutingState = new IdleToExecutingState(this);
331f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mExecutingState = new ExecutingState(this);
332f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
333f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mOutputPortSettingsChangedState =
334f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        new OutputPortSettingsChangedState(this);
335f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
336f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mExecutingToIdleState = new ExecutingToIdleState(this);
337f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mIdleToLoadedState = new IdleToLoadedState(this);
338f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mErrorState = new ErrorState(this);
339f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mFlushingState = new FlushingState(this);
340f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
341f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mPortEOS[kPortIndexInput] = mPortEOS[kPortIndexOutput] = false;
342f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
343f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    changeState(mUninitializedState);
344f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
345f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
346f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::~ACodec() {
347f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
348f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
349f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::setNotificationMessage(const sp<AMessage> &msg) {
350f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mNotify = msg;
351f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
352f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
353f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::initiateSetup(const sp<AMessage> &msg) {
354f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    msg->setWhat(kWhatSetup);
355f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    msg->setTarget(id());
356f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    msg->post();
357f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
358f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
359f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::signalFlush() {
360f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    (new AMessage(kWhatFlush, id()))->post();
361f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
362f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
363f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::signalResume() {
364f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    (new AMessage(kWhatResume, id()))->post();
365f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
366f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
367f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::initiateShutdown() {
368f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    (new AMessage(kWhatShutdown, id()))->post();
369f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
370f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
371f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::allocateBuffersOnPort(OMX_U32 portIndex) {
372f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(portIndex == kPortIndexInput || portIndex == kPortIndexOutput);
373f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
374f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(mDealer[portIndex] == NULL);
375f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(mBuffers[portIndex].isEmpty());
376f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
377f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (mNativeWindow != NULL && portIndex == kPortIndexOutput) {
378f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return allocateOutputBuffersFromNativeWindow();
379f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
380f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
381f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_PARAM_PORTDEFINITIONTYPE def;
382f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    InitOMXParams(&def);
383f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    def.nPortIndex = portIndex;
384f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
385f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = mOMX->getParameter(
386f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamPortDefinition, &def, sizeof(def));
387f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
388f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
389f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
390f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
391f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
392f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    LOGV("[%s] Allocating %lu buffers of size %lu on %s port",
393f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mComponentName.c_str(),
394f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            def.nBufferCountActual, def.nBufferSize,
395f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            portIndex == kPortIndexInput ? "input" : "output");
396f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
397f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    size_t totalSize = def.nBufferCountActual * def.nBufferSize;
398f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mDealer[portIndex] = new MemoryDealer(totalSize, "OMXCodec");
399f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
400f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (OMX_U32 i = 0; i < def.nBufferCountActual; ++i) {
401f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        sp<IMemory> mem = mDealer[portIndex]->allocate(def.nBufferSize);
402f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK(mem.get() != NULL);
403f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
404f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        IOMX::buffer_id buffer;
4051065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber
4061065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber        if (!strcasecmp(
4071065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber                    mComponentName.c_str(), "OMX.TI.DUCATI1.VIDEO.DECODER")) {
4081065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            if (portIndex == kPortIndexInput && i == 0) {
4091065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber                // Only log this warning once per allocation round.
4101065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber
4111065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber                LOGW("OMX.TI.DUCATI1.VIDEO.DECODER requires the use of "
4121065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber                     "OMX_AllocateBuffer instead of the preferred "
4131065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber                     "OMX_UseBuffer. Vendor must fix this.");
4141065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            }
4151065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber
4161065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            err = mOMX->allocateBufferWithBackup(
4171065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber                    mNode, portIndex, mem, &buffer);
4181065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber        } else {
4191065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            err = mOMX->useBuffer(mNode, portIndex, mem, &buffer);
4201065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber        }
421f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
422f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (err != OK) {
423f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return err;
424f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
425f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
426f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        BufferInfo info;
427f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        info.mBufferID = buffer;
428f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        info.mStatus = BufferInfo::OWNED_BY_US;
429f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        info.mData = new ABuffer(mem->pointer(), def.nBufferSize);
430f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mBuffers[portIndex].push(info);
431f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
432f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
433f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
434f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
435f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
436f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::allocateOutputBuffersFromNativeWindow() {
437f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_PARAM_PORTDEFINITIONTYPE def;
438f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    InitOMXParams(&def);
439f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    def.nPortIndex = kPortIndexOutput;
440f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
441f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = mOMX->getParameter(
442f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamPortDefinition, &def, sizeof(def));
443f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
444f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
445f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
446f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
447f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
4489bc7af17974f448291a44912566ec7472a0d798bMathias Agopian    err = native_window_set_scaling_mode(mNativeWindow.get(),
4499bc7af17974f448291a44912566ec7472a0d798bMathias Agopian            NATIVE_WINDOW_SCALING_MODE_SCALE_TO_WINDOW);
4509bc7af17974f448291a44912566ec7472a0d798bMathias Agopian
4519bc7af17974f448291a44912566ec7472a0d798bMathias Agopian    if (err != OK) {
4529bc7af17974f448291a44912566ec7472a0d798bMathias Agopian        return err;
4539bc7af17974f448291a44912566ec7472a0d798bMathias Agopian    }
4549bc7af17974f448291a44912566ec7472a0d798bMathias Agopian
455f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = native_window_set_buffers_geometry(
456f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNativeWindow.get(),
457f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            def.format.video.nFrameWidth,
458f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            def.format.video.nFrameHeight,
459f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            def.format.video.eColorFormat);
460f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
461f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != 0) {
462f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        LOGE("native_window_set_buffers_geometry failed: %s (%d)",
463f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                strerror(-err), -err);
464f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
465f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
466f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
467f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    // Set up the native window.
4683c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis    OMX_U32 usage = 0;
4693c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis    err = mOMX->getGraphicBufferUsage(mNode, kPortIndexOutput, &usage);
4703c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis    if (err != 0) {
4713c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis        LOGW("querying usage flags from OMX IL component failed: %d", err);
4723c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis        // XXX: Currently this error is logged, but not fatal.
4733c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis        usage = 0;
4743c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis    }
4753c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis
476f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = native_window_set_usage(
477f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNativeWindow.get(),
4783c14b9745c4afc88cec247d9dd0b003e087cbb52Jamie Gennis            usage | GRALLOC_USAGE_HW_TEXTURE | GRALLOC_USAGE_EXTERNAL_DISP);
479f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
480f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != 0) {
481f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        LOGE("native_window_set_usage failed: %s (%d)", strerror(-err), -err);
482f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
483f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
484f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
485258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    int minUndequeuedBufs = 0;
486258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    err = mNativeWindow->query(
487258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis            mNativeWindow.get(), NATIVE_WINDOW_MIN_UNDEQUEUED_BUFFERS,
488258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis            &minUndequeuedBufs);
489258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis
490258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    if (err != 0) {
491258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis        LOGE("NATIVE_WINDOW_MIN_UNDEQUEUED_BUFFERS query failed: %s (%d)",
492258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis                strerror(-err), -err);
493258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis        return err;
494258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    }
495258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis
496258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    // XXX: Is this the right logic to use?  It's not clear to me what the OMX
497258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    // buffer counts refer to - how do they account for the renderer holding on
498258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    // to buffers?
499258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    if (def.nBufferCountActual < def.nBufferCountMin + minUndequeuedBufs) {
500258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis        OMX_U32 newBufferCount = def.nBufferCountMin + minUndequeuedBufs;
501258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis        def.nBufferCountActual = newBufferCount;
502258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis        err = mOMX->setParameter(
503258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis                mNode, OMX_IndexParamPortDefinition, &def, sizeof(def));
504258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis
505258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis        if (err != OK) {
506258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis            LOGE("[%s] setting nBufferCountActual to %lu failed: %d",
507258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis                    mComponentName.c_str(), newBufferCount, err);
508258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis            return err;
509258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis        }
510258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis    }
511258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis
512f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = native_window_set_buffer_count(
513f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNativeWindow.get(), def.nBufferCountActual);
514f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
515f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != 0) {
516f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        LOGE("native_window_set_buffer_count failed: %s (%d)", strerror(-err),
517f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                -err);
518f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
519f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
520f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
521f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    LOGV("[%s] Allocating %lu buffers from a native window of size %lu on "
522f933441648ef6a71dee783d733aac17b9508b452Andreas Huber         "output port",
523f933441648ef6a71dee783d733aac17b9508b452Andreas Huber         mComponentName.c_str(), def.nBufferCountActual, def.nBufferSize);
524f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
525f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    // Dequeue buffers and send them to OMX
52674006804065941841883c4b46ee785070164023fJamie Gennis    for (OMX_U32 i = 0; i < def.nBufferCountActual; i++) {
5278ce2364512f7c32c824f5ec5719688830ba72427Iliyan Malchev        ANativeWindowBuffer *buf;
528f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        err = mNativeWindow->dequeueBuffer(mNativeWindow.get(), &buf);
529f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (err != 0) {
530f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            LOGE("dequeueBuffer failed: %s (%d)", strerror(-err), -err);
531f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
532f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
533f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
534f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        sp<GraphicBuffer> graphicBuffer(new GraphicBuffer(buf, false));
53574006804065941841883c4b46ee785070164023fJamie Gennis        BufferInfo info;
53674006804065941841883c4b46ee785070164023fJamie Gennis        info.mStatus = BufferInfo::OWNED_BY_US;
53774006804065941841883c4b46ee785070164023fJamie Gennis        info.mData = new ABuffer(0);
53874006804065941841883c4b46ee785070164023fJamie Gennis        info.mGraphicBuffer = graphicBuffer;
53974006804065941841883c4b46ee785070164023fJamie Gennis        mBuffers[kPortIndexOutput].push(info);
54074006804065941841883c4b46ee785070164023fJamie Gennis
541f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        IOMX::buffer_id bufferId;
542f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        err = mOMX->useGraphicBuffer(mNode, kPortIndexOutput, graphicBuffer,
543f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                &bufferId);
544f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (err != 0) {
54574006804065941841883c4b46ee785070164023fJamie Gennis            LOGE("registering GraphicBuffer %lu with OMX IL component failed: "
54674006804065941841883c4b46ee785070164023fJamie Gennis                 "%d", i, err);
547f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
548f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
549f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
55074006804065941841883c4b46ee785070164023fJamie Gennis        mBuffers[kPortIndexOutput].editItemAt(i).mBufferID = bufferId;
55174006804065941841883c4b46ee785070164023fJamie Gennis
552f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        LOGV("[%s] Registered graphic buffer with ID %p (pointer = %p)",
553f933441648ef6a71dee783d733aac17b9508b452Andreas Huber             mComponentName.c_str(),
554f933441648ef6a71dee783d733aac17b9508b452Andreas Huber             bufferId, graphicBuffer.get());
555f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
556f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
557f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_U32 cancelStart;
558f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_U32 cancelEnd;
559f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
560f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != 0) {
561f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        // If an error occurred while dequeuing we need to cancel any buffers
562f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        // that were dequeued.
563f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        cancelStart = 0;
56474006804065941841883c4b46ee785070164023fJamie Gennis        cancelEnd = mBuffers[kPortIndexOutput].size();
565f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else {
566f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        // Return the last two buffers to the native window.
567258d4e3aef7984574b0972a66871afc8a13d8e4eJamie Gennis        cancelStart = def.nBufferCountActual - minUndequeuedBufs;
568f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        cancelEnd = def.nBufferCountActual;
569f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
570f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
571f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (OMX_U32 i = cancelStart; i < cancelEnd; i++) {
572f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        BufferInfo *info = &mBuffers[kPortIndexOutput].editItemAt(i);
573f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        cancelBufferToNativeWindow(info);
574f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
575f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
576f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return err;
577f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
578f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
579f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::cancelBufferToNativeWindow(BufferInfo *info) {
580f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((int)info->mStatus, (int)BufferInfo::OWNED_BY_US);
581f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
582f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    LOGV("[%s] Calling cancelBuffer on buffer %p",
583f933441648ef6a71dee783d733aac17b9508b452Andreas Huber         mComponentName.c_str(), info->mBufferID);
584f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
585f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    int err = mNativeWindow->cancelBuffer(
586f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mNativeWindow.get(), info->mGraphicBuffer.get());
587f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
588f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(err, 0);
589f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
590f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    info->mStatus = BufferInfo::OWNED_BY_NATIVE_WINDOW;
591f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
592f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
593f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
594f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
595f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::BufferInfo *ACodec::dequeueBufferFromNativeWindow() {
5968ce2364512f7c32c824f5ec5719688830ba72427Iliyan Malchev    ANativeWindowBuffer *buf;
597f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(mNativeWindow->dequeueBuffer(mNativeWindow.get(), &buf), 0);
598f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
599f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (size_t i = mBuffers[kPortIndexOutput].size(); i-- > 0;) {
600f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        BufferInfo *info =
601f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            &mBuffers[kPortIndexOutput].editItemAt(i);
602f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
603f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (info->mGraphicBuffer->handle == buf->handle) {
604f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ((int)info->mStatus,
605f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                     (int)BufferInfo::OWNED_BY_NATIVE_WINDOW);
606f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
607f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            info->mStatus = BufferInfo::OWNED_BY_US;
608f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
609f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return info;
610f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
611f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
612f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
613f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    TRESPASS();
614f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
615f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return NULL;
616f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
617f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
618f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::freeBuffersOnPort(OMX_U32 portIndex) {
619f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (size_t i = mBuffers[portIndex].size(); i-- > 0;) {
620f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ((status_t)OK, freeBuffer(portIndex, i));
621f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
622f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
623f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mDealer[portIndex].clear();
624f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
625f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
626f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
627f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
628349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huberstatus_t ACodec::freeOutputBuffersNotOwnedByComponent() {
629f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (size_t i = mBuffers[kPortIndexOutput].size(); i-- > 0;) {
630f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        BufferInfo *info =
631f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            &mBuffers[kPortIndexOutput].editItemAt(i);
632f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
633349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        if (info->mStatus !=
634349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                BufferInfo::OWNED_BY_COMPONENT) {
635349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            // We shouldn't have sent out any buffers to the client at this
636349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            // point.
637349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            CHECK_NE((int)info->mStatus, (int)BufferInfo::OWNED_BY_DOWNSTREAM);
638349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
639f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ((status_t)OK, freeBuffer(kPortIndexOutput, i));
640f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
641f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
642f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
643f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
644f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
645f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
646f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::freeBuffer(OMX_U32 portIndex, size_t i) {
647f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BufferInfo *info = &mBuffers[portIndex].editItemAt(i);
648f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
649f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(info->mStatus == BufferInfo::OWNED_BY_US
650f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            || info->mStatus == BufferInfo::OWNED_BY_NATIVE_WINDOW);
651f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
652f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (portIndex == kPortIndexOutput && mNativeWindow != NULL
653f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            && info->mStatus == BufferInfo::OWNED_BY_US) {
654f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ((status_t)OK, cancelBufferToNativeWindow(info));
655f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
656f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
657f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(mOMX->freeBuffer(
658f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mNode, portIndex, info->mBufferID),
659f933441648ef6a71dee783d733aac17b9508b452Andreas Huber             (status_t)OK);
660f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
661f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mBuffers[portIndex].removeAt(i);
662f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
663f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
664f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
665f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
666f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::BufferInfo *ACodec::findBufferByID(
667f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        uint32_t portIndex, IOMX::buffer_id bufferID,
668f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        ssize_t *index) {
669f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (size_t i = 0; i < mBuffers[portIndex].size(); ++i) {
670f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        BufferInfo *info = &mBuffers[portIndex].editItemAt(i);
671f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
672f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (info->mBufferID == bufferID) {
673f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (index != NULL) {
674f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                *index = i;
675f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
676f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return info;
677f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
678f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
679f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
680f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    TRESPASS();
681f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
682f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return NULL;
683f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
684f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
685f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::setComponentRole(
686f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        bool isEncoder, const char *mime) {
687f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    struct MimeToRole {
688f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const char *mime;
689f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const char *decoderRole;
690f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const char *encoderRole;
691f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    };
692f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
693f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    static const MimeToRole kMimeToRole[] = {
694f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        { MEDIA_MIMETYPE_AUDIO_MPEG,
695f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            "audio_decoder.mp3", "audio_encoder.mp3" },
696f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        { MEDIA_MIMETYPE_AUDIO_AMR_NB,
697f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            "audio_decoder.amrnb", "audio_encoder.amrnb" },
698f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        { MEDIA_MIMETYPE_AUDIO_AMR_WB,
699f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            "audio_decoder.amrwb", "audio_encoder.amrwb" },
700f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        { MEDIA_MIMETYPE_AUDIO_AAC,
701f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            "audio_decoder.aac", "audio_encoder.aac" },
702f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        { MEDIA_MIMETYPE_VIDEO_AVC,
703f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            "video_decoder.avc", "video_encoder.avc" },
704f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        { MEDIA_MIMETYPE_VIDEO_MPEG4,
705f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            "video_decoder.mpeg4", "video_encoder.mpeg4" },
706f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        { MEDIA_MIMETYPE_VIDEO_H263,
707f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            "video_decoder.h263", "video_encoder.h263" },
708f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    };
709f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
710f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    static const size_t kNumMimeToRole =
711f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        sizeof(kMimeToRole) / sizeof(kMimeToRole[0]);
712f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
713f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    size_t i;
714f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (i = 0; i < kNumMimeToRole; ++i) {
715f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (!strcasecmp(mime, kMimeToRole[i].mime)) {
716f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
717f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
718f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
719f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
720f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (i == kNumMimeToRole) {
721f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return;
722f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
723f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
724f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    const char *role =
725f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        isEncoder ? kMimeToRole[i].encoderRole
726f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                  : kMimeToRole[i].decoderRole;
727f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
728f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (role != NULL) {
729f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_PARAM_COMPONENTROLETYPE roleParams;
730f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        InitOMXParams(&roleParams);
731f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
732f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        strncpy((char *)roleParams.cRole,
733f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                role, OMX_MAX_STRINGNAME_SIZE - 1);
734f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
735f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        roleParams.cRole[OMX_MAX_STRINGNAME_SIZE - 1] = '\0';
736f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
737f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        status_t err = mOMX->setParameter(
738f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mNode, OMX_IndexParamStandardComponentRole,
739f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                &roleParams, sizeof(roleParams));
740f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
741f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (err != OK) {
742f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            LOGW("[%s] Failed to set standard component role '%s'.",
743f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                 mComponentName.c_str(), role);
744f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
745f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
746f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
747f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
748f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::configureCodec(
749f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const char *mime, const sp<AMessage> &msg) {
750f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    setComponentRole(false /* isEncoder */, mime);
751f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
752f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (!strncasecmp(mime, "video/", 6)) {
753f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        int32_t width, height;
754f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK(msg->findInt32("width", &width));
755f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK(msg->findInt32("height", &height));
756f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
757f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(setupVideoDecoder(mime, width, height),
758f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                 (status_t)OK);
759f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else if (!strcasecmp(mime, MEDIA_MIMETYPE_AUDIO_AAC)) {
760f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        int32_t numChannels, sampleRate;
761f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK(msg->findInt32("channel-count", &numChannels));
762f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK(msg->findInt32("sample-rate", &sampleRate));
763f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
764f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(setupAACDecoder(numChannels, sampleRate), (status_t)OK);
765f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else if (!strcasecmp(mime, MEDIA_MIMETYPE_AUDIO_MPEG)) {
766f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else {
767f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        TRESPASS();
768f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
769f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
770f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    int32_t maxInputSize;
771f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (msg->findInt32("max-input-size", &maxInputSize)) {
772f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(setMinBufferSize(kPortIndexInput, (size_t)maxInputSize),
773f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                 (status_t)OK);
774f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else if (!strcmp("OMX.Nvidia.aac.decoder", mComponentName.c_str())) {
775f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(setMinBufferSize(kPortIndexInput, 8192),  // XXX
776f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                 (status_t)OK);
777f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
778f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
779f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
780f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::setMinBufferSize(OMX_U32 portIndex, size_t size) {
781f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_PARAM_PORTDEFINITIONTYPE def;
782f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    InitOMXParams(&def);
783f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    def.nPortIndex = portIndex;
784f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
785f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = mOMX->getParameter(
786f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamPortDefinition, &def, sizeof(def));
787f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
788f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
789f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
790f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
791f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
792f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (def.nBufferSize >= size) {
793f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return OK;
794f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
795f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
796f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    def.nBufferSize = size;
797f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
798f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = mOMX->setParameter(
799f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamPortDefinition, &def, sizeof(def));
800f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
801f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
802f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
803f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
804f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
805f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = mOMX->getParameter(
806f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamPortDefinition, &def, sizeof(def));
807f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
808f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
809f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
810f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
811f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
812f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(def.nBufferSize >= size);
813f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
814f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
815f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
816f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
817f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::setupAACDecoder(int32_t numChannels, int32_t sampleRate) {
818f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_AUDIO_PARAM_AACPROFILETYPE profile;
819f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    InitOMXParams(&profile);
820f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    profile.nPortIndex = kPortIndexInput;
821f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
822f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = mOMX->getParameter(
823f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamAudioAac, &profile, sizeof(profile));
824f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
825f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
826f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
827f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
828f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
829f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    profile.nChannels = numChannels;
830f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    profile.nSampleRate = sampleRate;
831f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    profile.eAACStreamFormat = OMX_AUDIO_AACStreamFormatMP4ADTS;
832f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
833f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = mOMX->setParameter(
834f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamAudioAac, &profile, sizeof(profile));
835f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
836f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return err;
837f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
838f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
839f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::setVideoPortFormatType(
840f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_U32 portIndex,
841f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_VIDEO_CODINGTYPE compressionFormat,
842f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_COLOR_FORMATTYPE colorFormat) {
843f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_VIDEO_PARAM_PORTFORMATTYPE format;
844f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    InitOMXParams(&format);
845f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    format.nPortIndex = portIndex;
846f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    format.nIndex = 0;
847f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool found = false;
848f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
849f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_U32 index = 0;
850f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (;;) {
851f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        format.nIndex = index;
852f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        status_t err = mOMX->getParameter(
853f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mNode, OMX_IndexParamVideoPortFormat,
854f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                &format, sizeof(format));
855f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
856f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (err != OK) {
857f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return err;
858f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
859f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
860f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        // The following assertion is violated by TI's video decoder.
861f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        // CHECK_EQ(format.nIndex, index);
862f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
863f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (!strcmp("OMX.TI.Video.encoder", mComponentName.c_str())) {
864f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (portIndex == kPortIndexInput
865f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    && colorFormat == format.eColorFormat) {
866f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                // eCompressionFormat does not seem right.
867f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                found = true;
868f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                break;
869f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
870f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (portIndex == kPortIndexOutput
871f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    && compressionFormat == format.eCompressionFormat) {
872f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                // eColorFormat does not seem right.
873f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                found = true;
874f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                break;
875f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
876f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
877f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
878f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (format.eCompressionFormat == compressionFormat
879f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            && format.eColorFormat == colorFormat) {
880f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            found = true;
881f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
882f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
883f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
884f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        ++index;
885f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
886f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
887f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (!found) {
888f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return UNKNOWN_ERROR;
889f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
890f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
891f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = mOMX->setParameter(
892f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamVideoPortFormat,
893f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            &format, sizeof(format));
894f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
895f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return err;
896f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
897f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
898f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::setSupportedOutputFormat() {
899f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_VIDEO_PARAM_PORTFORMATTYPE format;
900f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    InitOMXParams(&format);
901f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    format.nPortIndex = kPortIndexOutput;
902f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    format.nIndex = 0;
903f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
904f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = mOMX->getParameter(
905f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamVideoPortFormat,
906f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            &format, sizeof(format));
907f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(err, (status_t)OK);
908f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((int)format.eCompressionFormat, (int)OMX_VIDEO_CodingUnused);
909f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
910f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(format.eColorFormat == OMX_COLOR_FormatYUV420Planar
911f933441648ef6a71dee783d733aac17b9508b452Andreas Huber           || format.eColorFormat == OMX_COLOR_FormatYUV420SemiPlanar
912f933441648ef6a71dee783d733aac17b9508b452Andreas Huber           || format.eColorFormat == OMX_COLOR_FormatCbYCrY
9131065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber           || format.eColorFormat == OMX_TI_COLOR_FormatYUV420PackedSemiPlanar
914f933441648ef6a71dee783d733aac17b9508b452Andreas Huber           || format.eColorFormat == OMX_QCOM_COLOR_FormatYVU420SemiPlanar);
915f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
916f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return mOMX->setParameter(
917f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamVideoPortFormat,
918f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            &format, sizeof(format));
919f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
920f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
921f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::setupVideoDecoder(
922f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const char *mime, int32_t width, int32_t height) {
923f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_VIDEO_CODINGTYPE compressionFormat = OMX_VIDEO_CodingUnused;
924f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (!strcasecmp(MEDIA_MIMETYPE_VIDEO_AVC, mime)) {
925f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        compressionFormat = OMX_VIDEO_CodingAVC;
926f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else if (!strcasecmp(MEDIA_MIMETYPE_VIDEO_MPEG4, mime)) {
927f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        compressionFormat = OMX_VIDEO_CodingMPEG4;
928f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else if (!strcasecmp(MEDIA_MIMETYPE_VIDEO_H263, mime)) {
929f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        compressionFormat = OMX_VIDEO_CodingH263;
930386d609dc513e838c7e7c4c46c604493ccd560beAndreas Huber    } else if (!strcasecmp(MEDIA_MIMETYPE_VIDEO_MPEG2, mime)) {
931386d609dc513e838c7e7c4c46c604493ccd560beAndreas Huber        compressionFormat = OMX_VIDEO_CodingMPEG2;
932f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else {
933f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        TRESPASS();
934f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
935f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
936f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = setVideoPortFormatType(
937f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            kPortIndexInput, compressionFormat, OMX_COLOR_FormatUnused);
938f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
939f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
940f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
941f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
942f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
943f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = setSupportedOutputFormat();
944f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
945f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
946f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
947f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
948f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
949f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = setVideoFormatOnPort(
950f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            kPortIndexInput, width, height, compressionFormat);
951f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
952f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
953f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
954f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
955f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
956f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = setVideoFormatOnPort(
957f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            kPortIndexOutput, width, height, OMX_VIDEO_CodingUnused);
958f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
959f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
960f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
961f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
962f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
963f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
964f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
965f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
966f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::setVideoFormatOnPort(
967f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_U32 portIndex,
968f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        int32_t width, int32_t height, OMX_VIDEO_CODINGTYPE compressionFormat) {
969f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_PARAM_PORTDEFINITIONTYPE def;
970f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    InitOMXParams(&def);
971f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    def.nPortIndex = portIndex;
972f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
973f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMX_VIDEO_PORTDEFINITIONTYPE *video_def = &def.format.video;
974f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
975f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = mOMX->getParameter(
976f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamPortDefinition, &def, sizeof(def));
977f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
978f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(err, (status_t)OK);
979f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
980f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (portIndex == kPortIndexInput) {
981f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        // XXX Need a (much) better heuristic to compute input buffer sizes.
982f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const size_t X = 64 * 1024;
983f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (def.nBufferSize < X) {
984f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            def.nBufferSize = X;
985f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
986f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
987f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
988f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((int)def.eDomain, (int)OMX_PortDomainVideo);
989f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
990f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    video_def->nFrameWidth = width;
991f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    video_def->nFrameHeight = height;
992f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
993f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (portIndex == kPortIndexInput) {
994f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        video_def->eCompressionFormat = compressionFormat;
995f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        video_def->eColorFormat = OMX_COLOR_FormatUnused;
996f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
997f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
998f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    err = mOMX->setParameter(
999f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mNode, OMX_IndexParamPortDefinition, &def, sizeof(def));
1000f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1001f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return err;
1002f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1003f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1004f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::initNativeWindow() {
1005f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (mNativeWindow != NULL) {
1006f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return mOMX->enableGraphicBuffers(mNode, kPortIndexOutput, OMX_TRUE);
1007f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1008f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1009f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mOMX->enableGraphicBuffers(mNode, kPortIndexOutput, OMX_FALSE);
1010f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return OK;
1011f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1012f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1013f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::allYourBuffersAreBelongToUs(
1014f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_U32 portIndex) {
1015f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (size_t i = 0; i < mBuffers[portIndex].size(); ++i) {
1016f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        BufferInfo *info = &mBuffers[portIndex].editItemAt(i);
1017f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1018f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (info->mStatus != BufferInfo::OWNED_BY_US
1019f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                && info->mStatus != BufferInfo::OWNED_BY_NATIVE_WINDOW) {
1020f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            LOGV("[%s] Buffer %p on port %ld still has status %d",
1021f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    mComponentName.c_str(),
1022f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    info->mBufferID, portIndex, info->mStatus);
1023f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return false;
1024f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1025f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1026f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1027f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return true;
1028f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1029f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1030f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::allYourBuffersAreBelongToUs() {
1031f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return allYourBuffersAreBelongToUs(kPortIndexInput)
1032f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        && allYourBuffersAreBelongToUs(kPortIndexOutput);
1033f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1034f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1035f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::deferMessage(const sp<AMessage> &msg) {
1036f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool wasEmptyBefore = mDeferredQueue.empty();
1037f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mDeferredQueue.push_back(msg);
1038f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1039f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1040f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::processDeferredMessages() {
1041f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    List<sp<AMessage> > queue = mDeferredQueue;
1042f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mDeferredQueue.clear();
1043f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1044f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    List<sp<AMessage> >::iterator it = queue.begin();
1045f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    while (it != queue.end()) {
1046f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        onMessageReceived(*it++);
1047f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1048f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1049f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
105031e2508c75018145a8238925ff1a08cbde4e799aAndreas Hubervoid ACodec::sendFormatChange() {
105131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    sp<AMessage> notify = mNotify->dup();
105231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    notify->setInt32("what", kWhatOutputFormatChanged);
105331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
105431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    OMX_PARAM_PORTDEFINITIONTYPE def;
105531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    InitOMXParams(&def);
105631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    def.nPortIndex = kPortIndexOutput;
105731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
105831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    CHECK_EQ(mOMX->getParameter(
105931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                mNode, OMX_IndexParamPortDefinition, &def, sizeof(def)),
106031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber             (status_t)OK);
106131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
106231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    CHECK_EQ((int)def.eDir, (int)OMX_DirOutput);
106331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
106431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    switch (def.eDomain) {
106531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber        case OMX_PortDomainVideo:
106631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber        {
106731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            OMX_VIDEO_PORTDEFINITIONTYPE *videoDef = &def.format.video;
106831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
106931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            notify->setString("mime", MEDIA_MIMETYPE_VIDEO_RAW);
107031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            notify->setInt32("width", videoDef->nFrameWidth);
107131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            notify->setInt32("height", videoDef->nFrameHeight);
107231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
107331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            OMX_CONFIG_RECTTYPE rect;
107431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            InitOMXParams(&rect);
107531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            rect.nPortIndex = kPortIndexOutput;
107631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
107731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            if (mOMX->getConfig(
107831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                        mNode, OMX_IndexConfigCommonOutputCrop,
107931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                        &rect, sizeof(rect)) != OK) {
108031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                rect.nLeft = 0;
108131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                rect.nTop = 0;
108231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                rect.nWidth = videoDef->nFrameWidth;
108331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                rect.nHeight = videoDef->nFrameHeight;
108431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            }
108531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
108631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_GE(rect.nLeft, 0);
108731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_GE(rect.nTop, 0);
108831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_GE(rect.nWidth, 0u);
108931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_GE(rect.nHeight, 0u);
109031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_LE(rect.nLeft + rect.nWidth - 1, videoDef->nFrameWidth);
109131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_LE(rect.nTop + rect.nHeight - 1, videoDef->nFrameHeight);
109231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
109331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            notify->setRect(
109431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                    "crop",
109531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                    rect.nLeft,
109631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                    rect.nTop,
109731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                    rect.nLeft + rect.nWidth - 1,
109831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                    rect.nTop + rect.nHeight - 1);
109931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
110031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            if (mNativeWindow != NULL) {
110131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                android_native_rect_t crop;
110231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                crop.left = rect.nLeft;
110331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                crop.top = rect.nTop;
110489c120e7adbe09c6283591789594c5e591aa5032Andreas Huber                crop.right = rect.nLeft + rect.nWidth;
110589c120e7adbe09c6283591789594c5e591aa5032Andreas Huber                crop.bottom = rect.nTop + rect.nHeight;
110631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
110731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                CHECK_EQ(0, native_window_set_crop(
110831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                            mNativeWindow.get(), &crop));
110931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            }
111031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            break;
111131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber        }
111231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
111331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber        case OMX_PortDomainAudio:
111431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber        {
111531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            OMX_AUDIO_PORTDEFINITIONTYPE *audioDef = &def.format.audio;
111631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_EQ((int)audioDef->eEncoding, (int)OMX_AUDIO_CodingPCM);
111731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
111831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            OMX_AUDIO_PARAM_PCMMODETYPE params;
111931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            InitOMXParams(&params);
112031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            params.nPortIndex = kPortIndexOutput;
112131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
112231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_EQ(mOMX->getParameter(
112331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                        mNode, OMX_IndexParamAudioPcm,
112431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                        &params, sizeof(params)),
112531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                     (status_t)OK);
112631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
112731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK(params.nChannels == 1 || params.bInterleaved);
112831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_EQ(params.nBitPerSample, 16u);
112931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_EQ((int)params.eNumData, (int)OMX_NumericalDataSigned);
113031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            CHECK_EQ((int)params.ePCMMode, (int)OMX_AUDIO_PCMModeLinear);
113131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
113231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            notify->setString("mime", MEDIA_MIMETYPE_AUDIO_RAW);
113331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            notify->setInt32("channel-count", params.nChannels);
113431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            notify->setInt32("sample-rate", params.nSamplingRate);
113531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            break;
113631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber        }
113731e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
113831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber        default:
113931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            TRESPASS();
114031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    }
114131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
114231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    notify->post();
114331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
114431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    mSentFormat = true;
114531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber}
114631e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
1147f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
1148f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1149f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::BaseState::BaseState(ACodec *codec, const sp<AState> &parentState)
1150f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : AState(parentState),
1151f933441648ef6a71dee783d733aac17b9508b452Andreas Huber      mCodec(codec) {
1152f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1153f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1154f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::BaseState::PortMode ACodec::BaseState::getPortMode(OMX_U32 portIndex) {
1155f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return KEEP_BUFFERS;
1156f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1157f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1158f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::BaseState::onMessageReceived(const sp<AMessage> &msg) {
1159f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
1160f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatInputBufferFilled:
1161f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1162f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            onInputBufferFilled(msg);
1163f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1164f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1165f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1166f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatOutputBufferDrained:
1167f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1168f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            onOutputBufferDrained(msg);
1169f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1170f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1171f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1172f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case ACodec::kWhatOMXMessage:
1173f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1174f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return onOMXMessage(msg);
1175f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1176f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1177f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1178f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return false;
1179f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1180f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1181f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return true;
1182f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1183f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1184f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::BaseState::onOMXMessage(const sp<AMessage> &msg) {
1185f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    int32_t type;
1186f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(msg->findInt32("type", &type));
1187f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1188f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    IOMX::node_id nodeID;
1189f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(msg->findPointer("node", &nodeID));
1190f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(nodeID, mCodec->mNode);
1191f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1192f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (type) {
1193f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case omx_message::EVENT:
1194f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1195f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            int32_t event, data1, data2;
1196f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findInt32("event", &event));
1197f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findInt32("data1", &data1));
1198f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findInt32("data2", &data2));
1199f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
12000af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber            if (event == OMX_EventCmdComplete
12010af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber                    && data1 == OMX_CommandFlush
12020af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber                    && data2 == (int32_t)OMX_ALL) {
12030af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber                // Use of this notification is not consistent across
12040af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber                // implementations. We'll drop this notification and rely
12050af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber                // on flush-complete notifications on the individual port
12060af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber                // indices instead.
12070af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber
12080af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber                return true;
12090af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber            }
12100af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber
1211f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return onOMXEvent(
1212f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    static_cast<OMX_EVENTTYPE>(event),
1213f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    static_cast<OMX_U32>(data1),
1214f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    static_cast<OMX_U32>(data2));
1215f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1216f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1217f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case omx_message::EMPTY_BUFFER_DONE:
1218f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1219f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            IOMX::buffer_id bufferID;
1220f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findPointer("buffer", &bufferID));
1221f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1222f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return onOMXEmptyBufferDone(bufferID);
1223f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1224f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1225f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case omx_message::FILL_BUFFER_DONE:
1226f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1227f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            IOMX::buffer_id bufferID;
1228f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findPointer("buffer", &bufferID));
1229f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1230f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            int32_t rangeOffset, rangeLength, flags;
1231f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            int64_t timeUs;
1232f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            void *platformPrivate;
1233f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            void *dataPtr;
1234f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1235f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findInt32("range_offset", &rangeOffset));
1236f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findInt32("range_length", &rangeLength));
1237f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findInt32("flags", &flags));
1238f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findInt64("timestamp", &timeUs));
1239f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findPointer("platform_private", &platformPrivate));
1240f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(msg->findPointer("data_ptr", &dataPtr));
1241f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1242f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return onOMXFillBufferDone(
1243f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    bufferID,
1244f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    (size_t)rangeOffset, (size_t)rangeLength,
1245f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    (OMX_U32)flags,
1246f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    timeUs,
1247f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    platformPrivate,
1248f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    dataPtr);
1249f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1250f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1251f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1252f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            TRESPASS();
1253f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1254f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1255f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1256f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1257f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::BaseState::onOMXEvent(
1258f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
1259f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (event != OMX_EventError) {
12605bc087c573c70c84c6a39946457590b42d392a33Andreas Huber        LOGV("[%s] EVENT(%d, 0x%08lx, 0x%08lx)",
1261f933441648ef6a71dee783d733aac17b9508b452Andreas Huber             mCodec->mComponentName.c_str(), event, data1, data2);
1262f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1263f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return false;
1264f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1265f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1266f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    LOGE("[%s] ERROR(0x%08lx, 0x%08lx)",
1267f933441648ef6a71dee783d733aac17b9508b452Andreas Huber         mCodec->mComponentName.c_str(), data1, data2);
1268f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1269f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mCodec->changeState(mCodec->mErrorState);
1270f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1271f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return true;
1272f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1273f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1274f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::BaseState::onOMXEmptyBufferDone(IOMX::buffer_id bufferID) {
1275349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    LOGV("[%s] onOMXEmptyBufferDone %p",
1276349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber         mCodec->mComponentName.c_str(), bufferID);
1277349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1278f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BufferInfo *info =
1279f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mCodec->findBufferByID(kPortIndexInput, bufferID);
1280f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1281f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((int)info->mStatus, (int)BufferInfo::OWNED_BY_COMPONENT);
1282f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    info->mStatus = BufferInfo::OWNED_BY_US;
1283f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1284f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    PortMode mode = getPortMode(kPortIndexInput);
1285f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1286f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (mode) {
1287f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case KEEP_BUFFERS:
1288f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1289f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1290f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case RESUBMIT_BUFFERS:
1291f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            postFillThisBuffer(info);
1292f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1293f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1294f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1295f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1296f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ((int)mode, (int)FREE_BUFFERS);
1297f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            TRESPASS();  // Not currently used
1298f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1299f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1300f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1301f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1302f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return true;
1303f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1304f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1305f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::BaseState::postFillThisBuffer(BufferInfo *info) {
1306f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (mCodec->mPortEOS[kPortIndexInput]) {
1307f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return;
1308f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1309f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1310f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((int)info->mStatus, (int)BufferInfo::OWNED_BY_US);
1311f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1312f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    sp<AMessage> notify = mCodec->mNotify->dup();
1313f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    notify->setInt32("what", ACodec::kWhatFillThisBuffer);
1314f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    notify->setPointer("buffer-id", info->mBufferID);
1315f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1316f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    info->mData->meta()->clear();
1317f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    notify->setObject("buffer", info->mData);
1318f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1319f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    sp<AMessage> reply = new AMessage(kWhatInputBufferFilled, mCodec->id());
1320f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    reply->setPointer("buffer-id", info->mBufferID);
1321f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1322f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    notify->setMessage("reply", reply);
1323f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1324f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    notify->post();
1325f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1326f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    info->mStatus = BufferInfo::OWNED_BY_UPSTREAM;
1327f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1328f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1329f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::BaseState::onInputBufferFilled(const sp<AMessage> &msg) {
1330f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    IOMX::buffer_id bufferID;
1331f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(msg->findPointer("buffer-id", &bufferID));
1332f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1333f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    sp<RefBase> obj;
1334f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    int32_t err = OK;
1335f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (!msg->findObject("buffer", &obj)) {
1336f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK(msg->findInt32("err", &err));
1337f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
13383831a066bcf1019864a94d2bc7b4c9241efc5c22Andreas Huber        LOGV("[%s] saw error %d instead of an input buffer",
13393831a066bcf1019864a94d2bc7b4c9241efc5c22Andreas Huber             mCodec->mComponentName.c_str(), err);
13403831a066bcf1019864a94d2bc7b4c9241efc5c22Andreas Huber
1341f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        obj.clear();
1342f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1343f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1344f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    sp<ABuffer> buffer = static_cast<ABuffer *>(obj.get());
1345f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1346f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BufferInfo *info = mCodec->findBufferByID(kPortIndexInput, bufferID);
1347f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((int)info->mStatus, (int)BufferInfo::OWNED_BY_UPSTREAM);
1348f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1349f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    info->mStatus = BufferInfo::OWNED_BY_US;
1350f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1351f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    PortMode mode = getPortMode(kPortIndexInput);
1352f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1353f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (mode) {
1354f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case KEEP_BUFFERS:
1355f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1356f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (buffer == NULL) {
1357f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mCodec->mPortEOS[kPortIndexInput] = true;
1358f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
1359f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1360f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1361f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1362f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case RESUBMIT_BUFFERS:
1363f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1364f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (buffer != NULL) {
1365f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK(!mCodec->mPortEOS[kPortIndexInput]);
1366f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1367f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                int64_t timeUs;
1368f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK(buffer->meta()->findInt64("timeUs", &timeUs));
1369f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1370f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                OMX_U32 flags = OMX_BUFFERFLAG_ENDOFFRAME;
1371f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1372f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                int32_t isCSD;
1373f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                if (buffer->meta()->findInt32("csd", &isCSD) && isCSD != 0) {
1374f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    flags |= OMX_BUFFERFLAG_CODECCONFIG;
1375f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                }
1376f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1377f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                if (buffer != info->mData) {
1378349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                    if (0 && !(flags & OMX_BUFFERFLAG_CODECCONFIG)) {
1379f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        LOGV("[%s] Needs to copy input data.",
1380f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                             mCodec->mComponentName.c_str());
1381f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    }
1382f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1383f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    CHECK_LE(buffer->size(), info->mData->capacity());
1384f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    memcpy(info->mData->data(), buffer->data(), buffer->size());
1385f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                }
1386f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1387349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                LOGV("[%s] calling emptyBuffer %p",
1388349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                     mCodec->mComponentName.c_str(), bufferID);
1389349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1390f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(mCodec->mOMX->emptyBuffer(
1391f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            mCodec->mNode,
1392f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            bufferID,
1393f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            0,
1394f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            buffer->size(),
1395f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            flags,
1396f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            timeUs),
1397f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                         (status_t)OK);
1398f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1399f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                info->mStatus = BufferInfo::OWNED_BY_COMPONENT;
1400f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1401f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                getMoreInputDataIfPossible();
1402f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            } else if (!mCodec->mPortEOS[kPortIndexInput]) {
1403f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                LOGV("[%s] Signalling EOS on the input port",
1404f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                     mCodec->mComponentName.c_str());
1405f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1406349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                LOGV("[%s] calling emptyBuffer %p",
1407349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                     mCodec->mComponentName.c_str(), bufferID);
1408349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1409f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(mCodec->mOMX->emptyBuffer(
1410f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            mCodec->mNode,
1411f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            bufferID,
1412f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            0,
1413f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            0,
1414f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            OMX_BUFFERFLAG_EOS,
1415f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            0),
1416f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                         (status_t)OK);
1417f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1418f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                info->mStatus = BufferInfo::OWNED_BY_COMPONENT;
1419f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1420f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mCodec->mPortEOS[kPortIndexInput] = true;
1421f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
1422f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1423f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1424f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            default:
1425f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ((int)mode, (int)FREE_BUFFERS);
1426f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                break;
1427f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1428f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1429f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1430f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1431f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::BaseState::getMoreInputDataIfPossible() {
1432f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (mCodec->mPortEOS[kPortIndexInput]) {
1433f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return;
1434f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1435f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1436f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BufferInfo *eligible = NULL;
1437f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1438f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (size_t i = 0; i < mCodec->mBuffers[kPortIndexInput].size(); ++i) {
1439f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        BufferInfo *info = &mCodec->mBuffers[kPortIndexInput].editItemAt(i);
1440f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1441f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#if 0
1442f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (info->mStatus == BufferInfo::OWNED_BY_UPSTREAM) {
1443f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // There's already a "read" pending.
1444f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return;
1445f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1446f933441648ef6a71dee783d733aac17b9508b452Andreas Huber#endif
1447f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1448f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (info->mStatus == BufferInfo::OWNED_BY_US) {
1449f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            eligible = info;
1450f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1451f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1452f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1453f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (eligible == NULL) {
1454f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return;
1455f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1456f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1457f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    postFillThisBuffer(eligible);
1458f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1459f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1460f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::BaseState::onOMXFillBufferDone(
1461f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        IOMX::buffer_id bufferID,
1462f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        size_t rangeOffset, size_t rangeLength,
1463f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_U32 flags,
1464f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        int64_t timeUs,
1465f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        void *platformPrivate,
1466f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        void *dataPtr) {
1467349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    LOGV("[%s] onOMXFillBufferDone %p",
1468349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber         mCodec->mComponentName.c_str(), bufferID);
1469349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1470f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    ssize_t index;
1471f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BufferInfo *info =
1472f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mCodec->findBufferByID(kPortIndexOutput, bufferID, &index);
1473f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1474f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((int)info->mStatus, (int)BufferInfo::OWNED_BY_COMPONENT);
1475f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1476f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    info->mStatus = BufferInfo::OWNED_BY_US;
1477f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1478f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    PortMode mode = getPortMode(kPortIndexOutput);
1479f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1480f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (mode) {
1481f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case KEEP_BUFFERS:
1482f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1483f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1484f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case RESUBMIT_BUFFERS:
1485f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1486f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (rangeLength == 0) {
1487f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                if (!(flags & OMX_BUFFERFLAG_EOS)) {
1488349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                    LOGV("[%s] calling fillBuffer %p",
1489349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                         mCodec->mComponentName.c_str(), info->mBufferID);
1490349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1491f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    CHECK_EQ(mCodec->mOMX->fillBuffer(
1492f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                                mCodec->mNode, info->mBufferID),
1493f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                             (status_t)OK);
1494f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1495f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    info->mStatus = BufferInfo::OWNED_BY_COMPONENT;
1496f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                }
1497f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            } else {
149831e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                if (!mCodec->mSentFormat) {
149931e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                    mCodec->sendFormatChange();
150031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                }
150131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
1502f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                if (mCodec->mNativeWindow == NULL) {
1503f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    info->mData->setRange(rangeOffset, rangeLength);
1504f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                }
1505f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1506f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                info->mData->meta()->setInt64("timeUs", timeUs);
1507f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1508f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                sp<AMessage> notify = mCodec->mNotify->dup();
1509f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                notify->setInt32("what", ACodec::kWhatDrainThisBuffer);
1510f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                notify->setPointer("buffer-id", info->mBufferID);
1511f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                notify->setObject("buffer", info->mData);
1512f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1513f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                sp<AMessage> reply =
1514f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    new AMessage(kWhatOutputBufferDrained, mCodec->id());
1515f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1516f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                reply->setPointer("buffer-id", info->mBufferID);
1517f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1518f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                notify->setMessage("reply", reply);
1519f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1520f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                notify->post();
1521f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1522f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                info->mStatus = BufferInfo::OWNED_BY_DOWNSTREAM;
1523f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
1524f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1525f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (flags & OMX_BUFFERFLAG_EOS) {
1526f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                sp<AMessage> notify = mCodec->mNotify->dup();
1527f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                notify->setInt32("what", ACodec::kWhatEOS);
1528f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                notify->post();
1529f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1530f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mCodec->mPortEOS[kPortIndexOutput] = true;
1531f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
1532f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1533f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1534f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1535f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1536f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1537f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ((int)mode, (int)FREE_BUFFERS);
1538f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1539f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ((status_t)OK,
1540f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                     mCodec->freeBuffer(kPortIndexOutput, index));
1541f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1542f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1543f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1544f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1545f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return true;
1546f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1547f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1548f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::BaseState::onOutputBufferDrained(const sp<AMessage> &msg) {
1549f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    IOMX::buffer_id bufferID;
1550f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(msg->findPointer("buffer-id", &bufferID));
1551f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1552f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    ssize_t index;
1553f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BufferInfo *info =
1554f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mCodec->findBufferByID(kPortIndexOutput, bufferID, &index);
1555f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((int)info->mStatus, (int)BufferInfo::OWNED_BY_DOWNSTREAM);
1556f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1557f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    int32_t render;
1558f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (mCodec->mNativeWindow != NULL
1559f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            && msg->findInt32("render", &render) && render != 0) {
1560f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        // The client wants this buffer to be rendered.
1561f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1562f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(mCodec->mNativeWindow->queueBuffer(
1563f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    mCodec->mNativeWindow.get(),
1564f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    info->mGraphicBuffer.get()),
1565f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                 0);
1566f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1567f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        info->mStatus = BufferInfo::OWNED_BY_NATIVE_WINDOW;
1568f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    } else {
1569f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        info->mStatus = BufferInfo::OWNED_BY_US;
1570f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1571f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1572f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    PortMode mode = getPortMode(kPortIndexOutput);
1573f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1574f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (mode) {
1575f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case KEEP_BUFFERS:
1576f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1577f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // XXX fishy, revisit!!! What about the FREE_BUFFERS case below?
1578f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1579f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (info->mStatus == BufferInfo::OWNED_BY_NATIVE_WINDOW) {
1580f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                // We cannot resubmit the buffer we just rendered, dequeue
1581f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                // the spare instead.
1582f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1583f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                info = mCodec->dequeueBufferFromNativeWindow();
1584f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
1585f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1586f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1587f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1588f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case RESUBMIT_BUFFERS:
1589f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1590f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (!mCodec->mPortEOS[kPortIndexOutput]) {
1591f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                if (info->mStatus == BufferInfo::OWNED_BY_NATIVE_WINDOW) {
1592f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    // We cannot resubmit the buffer we just rendered, dequeue
1593f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    // the spare instead.
1594f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1595f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    info = mCodec->dequeueBufferFromNativeWindow();
1596f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                }
1597f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1598349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                LOGV("[%s] calling fillBuffer %p",
1599349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                     mCodec->mComponentName.c_str(), info->mBufferID);
1600349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1601f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(mCodec->mOMX->fillBuffer(mCodec->mNode, info->mBufferID),
1602f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                         (status_t)OK);
1603f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1604f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                info->mStatus = BufferInfo::OWNED_BY_COMPONENT;
1605f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
1606f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1607f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1608f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1609f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1610f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1611f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ((int)mode, (int)FREE_BUFFERS);
1612f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1613f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ((status_t)OK,
1614f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                     mCodec->freeBuffer(kPortIndexOutput, index));
1615f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1616f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1617f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1618f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1619f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1620f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
1621f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1622f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::UninitializedState::UninitializedState(ACodec *codec)
1623f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : BaseState(codec) {
1624f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1625f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1626f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::UninitializedState::onMessageReceived(const sp<AMessage> &msg) {
1627f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool handled = false;
1628f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1629f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
1630f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case ACodec::kWhatSetup:
1631f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1632f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            onSetup(msg);
1633f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1634f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
1635f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1636f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1637f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1638f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case ACodec::kWhatShutdown:
1639f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1640f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            sp<AMessage> notify = mCodec->mNotify->dup();
1641f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            notify->setInt32("what", ACodec::kWhatShutdownCompleted);
1642f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            notify->post();
1643f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1644f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
1645f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1646f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1647f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case ACodec::kWhatFlush:
1648f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1649f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            sp<AMessage> notify = mCodec->mNotify->dup();
1650f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            notify->setInt32("what", ACodec::kWhatFlushCompleted);
1651f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            notify->post();
1652f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1653f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
1654f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1655f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1656f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1657f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onMessageReceived(msg);
1658f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1659f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1660f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return handled;
1661f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1662f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1663f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::UninitializedState::onSetup(
1664f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const sp<AMessage> &msg) {
1665f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    OMXClient client;
1666f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(client.connect(), (status_t)OK);
1667f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1668f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    sp<IOMX> omx = client.interface();
1669f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1670f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    AString mime;
1671f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK(msg->findString("mime", &mime));
1672f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
16731065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber    Vector<String8> matchingCodecs;
16741065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber    OMXCodec::findMatchingCodecs(
16751065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            mime.c_str(),
16761065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            false, // createEncoder
16771065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            NULL,  // matchComponentName
16781065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            0,     // flags
16791065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            &matchingCodecs);
16801065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber
16811065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber    sp<CodecObserver> observer = new CodecObserver;
16821065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber    IOMX::node_id node = NULL;
16831065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber
1684f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    AString componentName;
1685f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
16861065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber    for (size_t matchIndex = 0; matchIndex < matchingCodecs.size();
16871065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            ++matchIndex) {
16881065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber        componentName = matchingCodecs.itemAt(matchIndex).string();
1689f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
16901065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber        status_t err = omx->allocateNode(componentName.c_str(), observer, &node);
1691f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
16921065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber        if (err == OK) {
16931065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber            break;
16941065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber        }
16951065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber
16961065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber        node = NULL;
16971065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber    }
16981065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber
16991065b3f17d3048948e7d522049d1980b90df3dc1Andreas Huber    CHECK(node != NULL);
1700f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1701f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    sp<AMessage> notify = new AMessage(kWhatOMXMessage, mCodec->id());
1702f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    observer->setNotificationMessage(notify);
1703f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1704f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mCodec->mComponentName = componentName;
1705f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mCodec->mOMX = omx;
1706f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mCodec->mNode = node;
1707f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1708349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    mCodec->mPortEOS[kPortIndexInput] =
1709349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        mCodec->mPortEOS[kPortIndexOutput] = false;
1710349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1711f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mCodec->configureCodec(mime.c_str(), msg);
1712f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1713f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    sp<RefBase> obj;
1714386d609dc513e838c7e7c4c46c604493ccd560beAndreas Huber    if (msg->findObject("native-window", &obj)
1715386d609dc513e838c7e7c4c46c604493ccd560beAndreas Huber            && strncmp("OMX.google.", componentName.c_str(), 11)) {
17161173118eace0e9e347cb007f0da817cee87579edGlenn Kasten        sp<NativeWindowWrapper> nativeWindow(
17171173118eace0e9e347cb007f0da817cee87579edGlenn Kasten                static_cast<NativeWindowWrapper *>(obj.get()));
17181173118eace0e9e347cb007f0da817cee87579edGlenn Kasten        CHECK(nativeWindow != NULL);
17191173118eace0e9e347cb007f0da817cee87579edGlenn Kasten        mCodec->mNativeWindow = nativeWindow->getNativeWindow();
1720f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1721f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1722f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ((status_t)OK, mCodec->initNativeWindow());
1723f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1724f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(omx->sendCommand(node, OMX_CommandStateSet, OMX_StateIdle),
1725f933441648ef6a71dee783d733aac17b9508b452Andreas Huber             (status_t)OK);
1726f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1727f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mCodec->changeState(mCodec->mLoadedToIdleState);
1728f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1729f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1730f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
1731f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1732f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::LoadedToIdleState::LoadedToIdleState(ACodec *codec)
1733f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : BaseState(codec) {
1734f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1735f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1736f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::LoadedToIdleState::stateEntered() {
17375bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("[%s] Now Loaded->Idle", mCodec->mComponentName.c_str());
1738f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1739f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(allocateBuffers(), (status_t)OK);
1740f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1741f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1742f933441648ef6a71dee783d733aac17b9508b452Andreas Huberstatus_t ACodec::LoadedToIdleState::allocateBuffers() {
1743f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    status_t err = mCodec->allocateBuffersOnPort(kPortIndexInput);
1744f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1745f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (err != OK) {
1746f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return err;
1747f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1748f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1749f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return mCodec->allocateBuffersOnPort(kPortIndexOutput);
1750f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1751f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1752f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::LoadedToIdleState::onMessageReceived(const sp<AMessage> &msg) {
1753f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
1754f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatShutdown:
1755f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1756f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->deferMessage(msg);
1757f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
1758f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1759f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1760f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1761f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onMessageReceived(msg);
1762f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1763f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1764f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1765f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::LoadedToIdleState::onOMXEvent(
1766f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
1767f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (event) {
1768f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case OMX_EventCmdComplete:
1769f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1770f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data1, (OMX_U32)OMX_CommandStateSet);
1771f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data2, (OMX_U32)OMX_StateIdle);
1772f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1773f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(mCodec->mOMX->sendCommand(
1774f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        mCodec->mNode, OMX_CommandStateSet, OMX_StateExecuting),
1775f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                     (status_t)OK);
1776f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1777f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->changeState(mCodec->mIdleToExecutingState);
1778f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1779f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
1780f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1781f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1782f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1783f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onOMXEvent(event, data1, data2);
1784f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1785f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1786f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1787f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
1788f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1789f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::IdleToExecutingState::IdleToExecutingState(ACodec *codec)
1790f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : BaseState(codec) {
1791f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1792f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1793f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::IdleToExecutingState::stateEntered() {
17945bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("[%s] Now Idle->Executing", mCodec->mComponentName.c_str());
1795f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1796f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1797f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::IdleToExecutingState::onMessageReceived(const sp<AMessage> &msg) {
1798f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
1799f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatShutdown:
1800f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1801f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->deferMessage(msg);
1802f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
1803f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1804f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1805f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1806f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onMessageReceived(msg);
1807f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1808f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1809f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1810f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::IdleToExecutingState::onOMXEvent(
1811f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
1812f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (event) {
1813f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case OMX_EventCmdComplete:
1814f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1815f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data1, (OMX_U32)OMX_CommandStateSet);
1816f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data2, (OMX_U32)OMX_StateExecuting);
1817f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1818f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->mExecutingState->resume();
1819f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->changeState(mCodec->mExecutingState);
1820f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1821f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
1822f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1823f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1824f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1825f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onOMXEvent(event, data1, data2);
1826f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1827f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1828f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1829f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
1830f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1831f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::ExecutingState::ExecutingState(ACodec *codec)
1832349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    : BaseState(codec),
1833349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber      mActive(false) {
1834f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1835f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1836f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::BaseState::PortMode ACodec::ExecutingState::getPortMode(
1837f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_U32 portIndex) {
1838f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return RESUBMIT_BUFFERS;
1839f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1840f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1841f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::ExecutingState::submitOutputBuffers() {
1842f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    for (size_t i = 0; i < mCodec->mBuffers[kPortIndexOutput].size(); ++i) {
1843f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        BufferInfo *info = &mCodec->mBuffers[kPortIndexOutput].editItemAt(i);
1844f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1845f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        if (mCodec->mNativeWindow != NULL) {
1846f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK(info->mStatus == BufferInfo::OWNED_BY_US
1847f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    || info->mStatus == BufferInfo::OWNED_BY_NATIVE_WINDOW);
1848f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1849f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (info->mStatus == BufferInfo::OWNED_BY_NATIVE_WINDOW) {
1850f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                continue;
1851f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
1852f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1853f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            status_t err = mCodec->mNativeWindow->lockBuffer(
1854f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    mCodec->mNativeWindow.get(),
1855f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    info->mGraphicBuffer.get());
1856f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(err, (status_t)OK);
1857f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        } else {
1858f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ((int)info->mStatus, (int)BufferInfo::OWNED_BY_US);
1859f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1860f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1861349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        LOGV("[%s] calling fillBuffer %p",
1862349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber             mCodec->mComponentName.c_str(), info->mBufferID);
1863349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1864f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(mCodec->mOMX->fillBuffer(mCodec->mNode, info->mBufferID),
1865f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                 (status_t)OK);
1866f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1867f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        info->mStatus = BufferInfo::OWNED_BY_COMPONENT;
1868f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1869f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1870f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1871f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::ExecutingState::resume() {
1872349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    if (mActive) {
1873349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        LOGV("[%s] We're already active, no need to resume.",
1874349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber             mCodec->mComponentName.c_str());
1875349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1876349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        return;
1877349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    }
1878349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1879f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    submitOutputBuffers();
1880f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1881f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    // Post the first input buffer.
1882f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_GT(mCodec->mBuffers[kPortIndexInput].size(), 0u);
1883f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BufferInfo *info = &mCodec->mBuffers[kPortIndexInput].editItemAt(0);
1884f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1885f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    postFillThisBuffer(info);
1886349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1887349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber    mActive = true;
1888f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1889f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1890f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::ExecutingState::stateEntered() {
18915bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("[%s] Now Executing", mCodec->mComponentName.c_str());
1892f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1893f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mCodec->processDeferredMessages();
1894f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1895f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1896f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::ExecutingState::onMessageReceived(const sp<AMessage> &msg) {
1897f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool handled = false;
1898f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1899f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
1900f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatShutdown:
1901f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1902349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            mActive = false;
1903349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1904f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(mCodec->mOMX->sendCommand(
1905f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        mCodec->mNode, OMX_CommandStateSet, OMX_StateIdle),
1906f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                     (status_t)OK);
1907f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1908f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->changeState(mCodec->mExecutingToIdleState);
1909f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1910f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
1911f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1912f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1913f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1914f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatFlush:
1915f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1916349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            mActive = false;
1917349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
1918f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(mCodec->mOMX->sendCommand(
1919f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        mCodec->mNode, OMX_CommandFlush, OMX_ALL),
1920f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                     (status_t)OK);
1921f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1922f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->changeState(mCodec->mFlushingState);
1923f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1924f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
1925f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1926f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1927f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1928f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatResume:
1929f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1930f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            resume();
1931f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1932f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
1933f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1934f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1935f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1936f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1937f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = BaseState::onMessageReceived(msg);
1938f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
1939f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1940f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1941f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return handled;
1942f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1943f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1944f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::ExecutingState::onOMXEvent(
1945f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
1946f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (event) {
1947f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case OMX_EventPortSettingsChanged:
1948f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1949f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data1, (OMX_U32)kPortIndexOutput);
1950f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
195131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            if (data2 == 0 || data2 == OMX_IndexParamPortDefinition) {
1952f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(mCodec->mOMX->sendCommand(
1953f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            mCodec->mNode,
1954f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            OMX_CommandPortDisable, kPortIndexOutput),
1955f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                         (status_t)OK);
1956f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1957349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                mCodec->freeOutputBuffersNotOwnedByComponent();
1958f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1959f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mCodec->changeState(mCodec->mOutputPortSettingsChangedState);
196031e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber            } else if (data2 == OMX_IndexConfigCommonOutputCrop) {
196131e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                mCodec->mSentFormat = false;
1962f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            } else {
1963f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                LOGV("[%s] OMX_EventPortSettingsChanged 0x%08lx",
1964f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                     mCodec->mComponentName.c_str(), data2);
1965f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
1966f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1967f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
1968f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1969f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1970f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case OMX_EventBufferFlag:
1971f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
1972f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
1973f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
1974f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1975f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
1976f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onOMXEvent(event, data1, data2);
1977f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1978f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1979f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1980f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
1981f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1982f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::OutputPortSettingsChangedState::OutputPortSettingsChangedState(
1983f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        ACodec *codec)
1984f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : BaseState(codec) {
1985f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1986f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1987f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::BaseState::PortMode ACodec::OutputPortSettingsChangedState::getPortMode(
1988f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_U32 portIndex) {
1989f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (portIndex == kPortIndexOutput) {
1990f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        return FREE_BUFFERS;
1991f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
1992f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1993f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    CHECK_EQ(portIndex, (OMX_U32)kPortIndexInput);
1994f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1995f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return RESUBMIT_BUFFERS;
1996f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
1997f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
1998f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::OutputPortSettingsChangedState::onMessageReceived(
1999f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const sp<AMessage> &msg) {
2000f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool handled = false;
2001f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2002f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
2003f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatFlush:
2004f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatShutdown:
2005349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        case kWhatResume:
2006f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2007349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            if (msg->what() == kWhatResume) {
2008349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                LOGV("[%s] Deferring resume", mCodec->mComponentName.c_str());
2009349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            }
2010349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
2011f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->deferMessage(msg);
2012f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
2013f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2014f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2015f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2016f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
2017f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = BaseState::onMessageReceived(msg);
2018f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2019f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2020f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2021f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return handled;
2022f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2023f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2024f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::OutputPortSettingsChangedState::stateEntered() {
20255bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("[%s] Now handling output port settings change",
2026f933441648ef6a71dee783d733aac17b9508b452Andreas Huber         mCodec->mComponentName.c_str());
2027f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2028f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2029f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::OutputPortSettingsChangedState::onOMXEvent(
2030f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
2031f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (event) {
2032f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case OMX_EventCmdComplete:
2033f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2034f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (data1 == (OMX_U32)OMX_CommandPortDisable) {
2035f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(data2, (OMX_U32)kPortIndexOutput);
2036f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2037f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                LOGV("[%s] Output port now disabled.",
2038f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        mCodec->mComponentName.c_str());
2039f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2040f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK(mCodec->mBuffers[kPortIndexOutput].isEmpty());
2041f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mCodec->mDealer[kPortIndexOutput].clear();
2042f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2043f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(mCodec->mOMX->sendCommand(
2044f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                            mCodec->mNode, OMX_CommandPortEnable, kPortIndexOutput),
2045f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                         (status_t)OK);
2046f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2047f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(mCodec->allocateBuffersOnPort(kPortIndexOutput),
2048f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                         (status_t)OK);
2049f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2050f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                return true;
2051f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            } else if (data1 == (OMX_U32)OMX_CommandPortEnable) {
2052f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(data2, (OMX_U32)kPortIndexOutput);
2053f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
205431e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber                mCodec->mSentFormat = false;
205531e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
2056f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                LOGV("[%s] Output port now reenabled.",
2057f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                        mCodec->mComponentName.c_str());
2058f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2059349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                if (mCodec->mExecutingState->active()) {
2060349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                    mCodec->mExecutingState->submitOutputBuffers();
2061349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                }
2062349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
2063f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mCodec->changeState(mCodec->mExecutingState);
2064f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2065f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                return true;
2066f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
2067f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2068f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return false;
2069f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2070f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2071f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
2072f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return false;
2073f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2074f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2075f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2076f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
2077f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2078f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::ExecutingToIdleState::ExecutingToIdleState(ACodec *codec)
2079f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : BaseState(codec) {
2080f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2081f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2082f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::ExecutingToIdleState::onMessageReceived(const sp<AMessage> &msg) {
2083f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool handled = false;
2084f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2085f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
2086f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatFlush:
2087f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2088f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // Don't send me a flush request if you previously wanted me
2089f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // to shutdown.
2090f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            TRESPASS();
2091f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2092f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2093f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2094f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatShutdown:
2095f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2096f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // We're already doing that...
2097f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2098f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
2099f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2100f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2101f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2102f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
2103f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = BaseState::onMessageReceived(msg);
2104f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2105f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2106f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2107f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return handled;
2108f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2109f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2110f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::ExecutingToIdleState::stateEntered() {
21115bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("[%s] Now Executing->Idle", mCodec->mComponentName.c_str());
211231e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber
211331e2508c75018145a8238925ff1a08cbde4e799aAndreas Huber    mCodec->mSentFormat = false;
2114f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2115f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2116f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::ExecutingToIdleState::onOMXEvent(
2117f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
2118f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (event) {
2119f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case OMX_EventCmdComplete:
2120f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2121f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data1, (OMX_U32)OMX_CommandStateSet);
2122f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data2, (OMX_U32)OMX_StateIdle);
2123f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2124f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            changeStateIfWeOwnAllBuffers();
2125f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2126f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
2127f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2128f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2129349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        case OMX_EventPortSettingsChanged:
2130349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        case OMX_EventBufferFlag:
2131349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        {
2132349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            // We're shutting down and don't care about this anymore.
2133349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            return true;
2134349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        }
2135349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
2136f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
2137f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onOMXEvent(event, data1, data2);
2138f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2139f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
21400af941927ef8f35f2da5380dfd8d04b7f4ed3532Andreas Huber
2141f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::ExecutingToIdleState::changeStateIfWeOwnAllBuffers() {
2142f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (mCodec->allYourBuffersAreBelongToUs()) {
2143f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(mCodec->mOMX->sendCommand(
2144f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                    mCodec->mNode, OMX_CommandStateSet, OMX_StateLoaded),
2145f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                 (status_t)OK);
2146f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2147f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(mCodec->freeBuffersOnPort(kPortIndexInput), (status_t)OK);
2148f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        CHECK_EQ(mCodec->freeBuffersOnPort(kPortIndexOutput), (status_t)OK);
2149f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2150f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mCodec->changeState(mCodec->mIdleToLoadedState);
2151f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2152f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2153f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2154f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::ExecutingToIdleState::onInputBufferFilled(
2155f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const sp<AMessage> &msg) {
2156f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BaseState::onInputBufferFilled(msg);
2157f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2158f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    changeStateIfWeOwnAllBuffers();
2159f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2160f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2161f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::ExecutingToIdleState::onOutputBufferDrained(
2162f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        const sp<AMessage> &msg) {
2163f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BaseState::onOutputBufferDrained(msg);
2164f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2165f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    changeStateIfWeOwnAllBuffers();
2166f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2167f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2168f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
2169f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2170f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::IdleToLoadedState::IdleToLoadedState(ACodec *codec)
2171f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : BaseState(codec) {
2172f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2173f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2174f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::IdleToLoadedState::onMessageReceived(const sp<AMessage> &msg) {
2175f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool handled = false;
2176f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2177f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
2178f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatShutdown:
2179f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2180f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // We're already doing that...
2181f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2182f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
2183f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2184f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2185f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2186f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatFlush:
2187f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2188f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // Don't send me a flush request if you previously wanted me
2189f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // to shutdown.
2190f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            TRESPASS();
2191f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2192f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2193f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2194f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
2195f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = BaseState::onMessageReceived(msg);
2196f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2197f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2198f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2199f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return handled;
2200f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2201f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2202f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::IdleToLoadedState::stateEntered() {
22035bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("[%s] Now Idle->Loaded", mCodec->mComponentName.c_str());
2204f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2205f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2206f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::IdleToLoadedState::onOMXEvent(
2207f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
2208f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (event) {
2209f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case OMX_EventCmdComplete:
2210f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2211f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data1, (OMX_U32)OMX_CommandStateSet);
2212f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data2, (OMX_U32)OMX_StateLoaded);
2213f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
22145bc087c573c70c84c6a39946457590b42d392a33Andreas Huber            LOGV("[%s] Now Loaded", mCodec->mComponentName.c_str());
2215f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2216f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(mCodec->mOMX->freeNode(mCodec->mNode), (status_t)OK);
2217f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2218f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->mNativeWindow.clear();
2219f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->mNode = NULL;
2220f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->mOMX.clear();
2221f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->mComponentName.clear();
2222f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2223f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->changeState(mCodec->mUninitializedState);
2224f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2225f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            sp<AMessage> notify = mCodec->mNotify->dup();
2226f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            notify->setInt32("what", ACodec::kWhatShutdownCompleted);
2227f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            notify->post();
2228f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2229f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
2230f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2231f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2232f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
2233f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onOMXEvent(event, data1, data2);
2234f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2235f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2236f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2237f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
2238f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2239f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::ErrorState::ErrorState(ACodec *codec)
2240f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : BaseState(codec) {
2241f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2242f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2243f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::ErrorState::onMessageReceived(const sp<AMessage> &msg) {
2244f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return BaseState::onMessageReceived(msg);
2245f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2246f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2247f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::ErrorState::stateEntered() {
22485bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("[%s] Now in ErrorState", mCodec->mComponentName.c_str());
2249f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2250f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2251f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::ErrorState::onOMXEvent(
2252f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
22535bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("EVENT(%d, 0x%08lx, 0x%08lx)", event, data1, data2);
2254f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return true;
2255f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2256f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2257f933441648ef6a71dee783d733aac17b9508b452Andreas Huber////////////////////////////////////////////////////////////////////////////////
2258f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2259f933441648ef6a71dee783d733aac17b9508b452Andreas HuberACodec::FlushingState::FlushingState(ACodec *codec)
2260f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    : BaseState(codec) {
2261f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2262f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2263f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::FlushingState::stateEntered() {
22645bc087c573c70c84c6a39946457590b42d392a33Andreas Huber    LOGV("[%s] Now Flushing", mCodec->mComponentName.c_str());
2265f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2266f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    mFlushComplete[kPortIndexInput] = mFlushComplete[kPortIndexOutput] = false;
2267f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2268f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2269f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::FlushingState::onMessageReceived(const sp<AMessage> &msg) {
2270f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    bool handled = false;
2271f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2272f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (msg->what()) {
2273f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatShutdown:
2274f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2275f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->deferMessage(msg);
2276f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2277f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2278f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2279f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case kWhatFlush:
2280f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2281f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            // We're already doing this right now.
2282f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = true;
2283f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2284f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2285f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2286f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
2287f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            handled = BaseState::onMessageReceived(msg);
2288f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            break;
2289f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2290f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2291f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return handled;
2292f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2293f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2294f933441648ef6a71dee783d733aac17b9508b452Andreas Huberbool ACodec::FlushingState::onOMXEvent(
2295f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        OMX_EVENTTYPE event, OMX_U32 data1, OMX_U32 data2) {
2296f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    switch (event) {
2297f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        case OMX_EventCmdComplete:
2298f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        {
2299f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            CHECK_EQ(data1, (OMX_U32)OMX_CommandFlush);
2300f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2301f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            if (data2 == kPortIndexInput || data2 == kPortIndexOutput) {
2302f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK(!mFlushComplete[data2]);
2303f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                mFlushComplete[data2] = true;
2304e5bf6409774fe73f968b7db215f535b64de66139Andreas Huber
2305e5bf6409774fe73f968b7db215f535b64de66139Andreas Huber                if (mFlushComplete[kPortIndexInput]
2306e5bf6409774fe73f968b7db215f535b64de66139Andreas Huber                        && mFlushComplete[kPortIndexOutput]) {
2307e5bf6409774fe73f968b7db215f535b64de66139Andreas Huber                    changeStateIfWeOwnAllBuffers();
2308e5bf6409774fe73f968b7db215f535b64de66139Andreas Huber                }
2309f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            } else {
2310f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK_EQ(data2, OMX_ALL);
2311f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK(mFlushComplete[kPortIndexInput]);
2312f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                CHECK(mFlushComplete[kPortIndexOutput]);
2313f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2314f933441648ef6a71dee783d733aac17b9508b452Andreas Huber                changeStateIfWeOwnAllBuffers();
2315f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            }
2316f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2317f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return true;
2318f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        }
2319f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2320349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        case OMX_EventPortSettingsChanged:
2321349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        {
2322349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            sp<AMessage> msg = new AMessage(kWhatOMXMessage, mCodec->id());
2323349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            msg->setInt32("type", omx_message::EVENT);
2324349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            msg->setPointer("node", mCodec->mNode);
2325349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            msg->setInt32("event", event);
2326349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            msg->setInt32("data1", data1);
2327349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            msg->setInt32("data2", data2);
2328349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
2329349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            LOGV("[%s] Deferring OMX_EventPortSettingsChanged",
2330349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber                 mCodec->mComponentName.c_str());
2331349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
2332349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            mCodec->deferMessage(msg);
2333349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
2334349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber            return true;
2335349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber        }
2336349d3fcb4afacf754f7b5b5186d2f258f5bf35e7Andreas Huber
2337f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        default:
2338f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            return BaseState::onOMXEvent(event, data1, data2);
2339f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2340f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2341f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    return true;
2342f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2343f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2344f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::FlushingState::onOutputBufferDrained(const sp<AMessage> &msg) {
2345f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BaseState::onOutputBufferDrained(msg);
2346f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2347f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    changeStateIfWeOwnAllBuffers();
2348f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2349f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2350f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::FlushingState::onInputBufferFilled(const sp<AMessage> &msg) {
2351f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    BaseState::onInputBufferFilled(msg);
2352f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2353f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    changeStateIfWeOwnAllBuffers();
2354f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2355f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2356f933441648ef6a71dee783d733aac17b9508b452Andreas Hubervoid ACodec::FlushingState::changeStateIfWeOwnAllBuffers() {
2357f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    if (mFlushComplete[kPortIndexInput]
2358f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            && mFlushComplete[kPortIndexOutput]
2359f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            && mCodec->allYourBuffersAreBelongToUs()) {
2360f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        sp<AMessage> notify = mCodec->mNotify->dup();
2361f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        notify->setInt32("what", ACodec::kWhatFlushCompleted);
2362f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        notify->post();
2363f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2364f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mCodec->mPortEOS[kPortIndexInput] =
2365f933441648ef6a71dee783d733aac17b9508b452Andreas Huber            mCodec->mPortEOS[kPortIndexOutput] = false;
2366f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2367f933441648ef6a71dee783d733aac17b9508b452Andreas Huber        mCodec->changeState(mCodec->mExecutingState);
2368f933441648ef6a71dee783d733aac17b9508b452Andreas Huber    }
2369f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}
2370f933441648ef6a71dee783d733aac17b9508b452Andreas Huber
2371f933441648ef6a71dee783d733aac17b9508b452Andreas Huber}  // namespace android
2372