1f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa/*
2f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * Copyright 2016, The Android Open Source Project
3f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa *
4f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * Licensed under the Apache License, Version 2.0 (the "License");
5f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * you may not use this file except in compliance with the License.
6f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * You may obtain a copy of the License at
7f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa *
8f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa *      http://www.apache.org/licenses/LICENSE-2.0
9f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa *
10f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * Unless required by applicable law or agreed to in writing, software
11f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * distributed under the License is distributed on an "AS IS" BASIS,
12f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * See the License for the specific language governing permissions and
14f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa * limitations under the License.
15f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa */
16f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa
170d3a5edf232916e81adbc46fc0f4a1753166b066Pawin Vongmasa#include <algorithm>
180d3a5edf232916e81adbc46fc0f4a1753166b066Pawin Vongmasa
19ac7d4125516299b8a3e6f2b25822a692bdd96311Pawin Vongmasa#include <media/omx/1.0/WOmxNode.h>
20ac7d4125516299b8a3e6f2b25822a692bdd96311Pawin Vongmasa#include <media/omx/1.0/WOmxBufferSource.h>
21ac7d4125516299b8a3e6f2b25822a692bdd96311Pawin Vongmasa#include <media/omx/1.0/Conversion.h>
22517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
23517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace android {
24517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace hardware {
25517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace media {
26517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace omx {
27517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace V1_0 {
28eeac97b18ca5c939bf2ac59334d36d54f705af3dPawin Vongmasanamespace utils {
29517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
30517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasausing ::android::hardware::Void;
31517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
32517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa// LWOmxNode
33517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::freeNode() {
34517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->freeNode());
35517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
36517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
37517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::sendCommand(
38517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_COMMANDTYPE cmd, OMX_S32 param) {
39517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->sendCommand(
40517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawCommandType(cmd), param));
41517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
42517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
43517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getParameter(
44517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE index, void *params, size_t size) {
45517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> tParams = inHidlBytes(params, size);
46517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
47517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getParameter(
48517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawIndexType(index),
49517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            tParams,
50517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, params, size](
51517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status, hidl_vec<uint8_t> const& outParams) {
52517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
53517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                std::copy(
54517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        outParams.data(),
55517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        outParams.data() + outParams.size(),
56517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        static_cast<uint8_t*>(params));
57517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
58517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
59517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
60517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
61517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::setParameter(
62517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE index, const void *params, size_t size) {
63517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> tParams = inHidlBytes(params, size);
64517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->setParameter(
65517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawIndexType(index), tParams));
66517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
67517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
68517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getConfig(
69517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE index, void *params, size_t size) {
70517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> tParams = inHidlBytes(params, size);
71517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
72517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getConfig(
73517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawIndexType(index),
74517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            tParams,
75517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, params, size](
76517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status, hidl_vec<uint8_t> const& outParams) {
77517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
78517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                std::copy(
79517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        outParams.data(),
80517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        outParams.data() + size,
81517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        static_cast<uint8_t*>(params));
82517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
83517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
84517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
85517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
86517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::setConfig(
87517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE index, const void *params, size_t size) {
88517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> tParams = inHidlBytes(params, size);
89517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->setConfig(toRawIndexType(index), tParams));
90517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
91517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
92517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::setPortMode(
93517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 port_index, IOMX::PortMode mode) {
94517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->setPortMode(port_index, toHardwarePortMode(mode)));
95517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
96517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
97517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::prepareForAdaptivePlayback(
98517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, OMX_BOOL enable,
99517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 maxFrameWidth, OMX_U32 maxFrameHeight) {
100517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->prepareForAdaptivePlayback(
101517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex, toRawBool(enable), maxFrameWidth, maxFrameHeight));
102517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
103517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
104517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::configureVideoTunnelMode(
105517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, OMX_BOOL tunneled,
106517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 audioHwSync, native_handle_t **sidebandHandle) {
107517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
108517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->configureVideoTunnelMode(
109517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
110517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawBool(tunneled),
111517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            audioHwSync,
112517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, sidebandHandle](
113517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status, hidl_handle const& outSidebandHandle) {
114517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
115f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa                *sidebandHandle = outSidebandHandle == nullptr ?
116f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa                        nullptr : native_handle_clone(outSidebandHandle);
117517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
118517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
119517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
120517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
121517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getGraphicBufferUsage(
122517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, OMX_U32* usage) {
123517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
124517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getGraphicBufferUsage(
125517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
126517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, usage](
127517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status, uint32_t outUsage) {
128517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
129517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *usage = outUsage;
130517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
131517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
132517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
133517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
134517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::setInputSurface(
135517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const sp<IOMXBufferSource> &bufferSource) {
136517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->setInputSurface(
137517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            new TWOmxBufferSource(bufferSource)));
138517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
139517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
140517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::allocateSecureBuffer(
141517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, size_t size, buffer_id *buffer,
142517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        void **buffer_data, sp<NativeHandle> *native_handle) {
143517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    *buffer_data = nullptr;
144517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
145517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->allocateSecureBuffer(
146517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
147517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<uint64_t>(size),
148517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, buffer, buffer_data, native_handle](
149517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status,
150517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    uint32_t outBuffer,
151517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    hidl_handle const& outNativeHandle) {
152517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
153517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *buffer = outBuffer;
154517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *native_handle = NativeHandle::create(
155517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        native_handle_clone(outNativeHandle), true);
156517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
157517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
158517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
159517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
160517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::useBuffer(
161517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, const OMXBuffer &omxBuffer, buffer_id *buffer) {
162517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
163517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
164517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
165517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
166517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
167517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->useBuffer(
168517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
169517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            codecBuffer,
170517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, buffer](Status status, uint32_t outBuffer) {
171517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
172517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *buffer = outBuffer;
173517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
174517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
175517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
176517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
177517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::freeBuffer(
178517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, buffer_id buffer) {
179517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->freeBuffer(portIndex, buffer));
180517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
181517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
182517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::fillBuffer(
183517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        buffer_id buffer, const OMXBuffer &omxBuffer, int fenceFd) {
184517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
185517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
186517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
187517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
188517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* fenceNh = native_handle_create_from_fd(fenceFd);
189517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!fenceNh) {
190517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
191517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
192517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->fillBuffer(
193517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer, codecBuffer, fenceNh));
1948a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(fenceNh);
195517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(fenceNh);
196517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
197517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
198517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
199517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::emptyBuffer(
200517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        buffer_id buffer, const OMXBuffer &omxBuffer,
201517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 flags, OMX_TICKS timestamp, int fenceFd) {
202517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
203517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
204517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
205517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
206517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* fenceNh = native_handle_create_from_fd(fenceFd);
207517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!fenceNh) {
208517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
209517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
210517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->emptyBuffer(
211517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
212517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            codecBuffer,
213517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            flags,
214517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawTicks(timestamp),
215517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            fenceNh));
2168a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(fenceNh);
217517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(fenceNh);
218517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
219517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
220517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getExtensionIndex(
221517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const char *parameter_name,
222517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE *index) {
223517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
224517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getExtensionIndex(
225517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            hidl_string(parameter_name),
226517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, index](Status status, uint32_t outIndex) {
227517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
228517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *index = toEnumIndexType(outIndex);
229517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
230517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
231517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
232517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
233517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::dispatchMessage(const omx_message &lMsg) {
234517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Message tMsg;
235517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* nh;
236517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&tMsg, &nh, lMsg)) {
237517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
238517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
239517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->dispatchMessage(tMsg));
2408a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(nh);
241517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(nh);
242517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
243517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
244517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
245517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa// TWOmxNode
246517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaTWOmxNode::TWOmxNode(sp<IOMXNode> const& base) : mBase(base) {
247517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
248517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
249517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::freeNode() {
250517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->freeNode());
251517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
252517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
253517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::sendCommand(uint32_t cmd, int32_t param) {
254517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->sendCommand(toEnumCommandType(cmd), param));
255517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
256517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
257517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getParameter(
258517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t index, hidl_vec<uint8_t> const& inParams,
259517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getParameter_cb _hidl_cb) {
260517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> params(inParams);
261517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getParameter(
262517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
263517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void*>(params.data()),
264517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            params.size()));
265517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, params);
266517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
267517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
268517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
269517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setParameter(
2708ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa        uint32_t index, hidl_vec<uint8_t> const& inParams) {
2718ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa    hidl_vec<uint8_t> params(inParams);
272517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setParameter(
273517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
274517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void const*>(params.data()),
275517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            params.size()));
276517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
277517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
278517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getConfig(
279517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t index, const hidl_vec<uint8_t>& inConfig,
280517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getConfig_cb _hidl_cb) {
281517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> config(inConfig);
282517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getConfig(
283517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
284517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void*>(config.data()),
285517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            config.size()));
286517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, config);
287517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
288517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
289517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
290517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setConfig(
2918ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa        uint32_t index, const hidl_vec<uint8_t>& inConfig) {
2928ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa    hidl_vec<uint8_t> config(inConfig);
293517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setConfig(
294517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
295517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void const*>(config.data()),
296517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            config.size()));
297517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
298517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
299517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setPortMode(uint32_t portIndex, PortMode mode) {
300517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setPortMode(portIndex, toIOMXPortMode(mode)));
301517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
302517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
303517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::prepareForAdaptivePlayback(
304517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, bool enable,
305517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t maxFrameWidth, uint32_t maxFrameHeight) {
306517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->prepareForAdaptivePlayback(
307517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
308517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumBool(enable),
309517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            maxFrameWidth,
310517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            maxFrameHeight));
311517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
312517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
313517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::configureVideoTunnelMode(
314517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, bool tunneled, uint32_t audioHwSync,
315517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        configureVideoTunnelMode_cb _hidl_cb) {
316f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa    native_handle_t* sidebandHandle = nullptr;
317517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->configureVideoTunnelMode(
318517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
319517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumBool(tunneled),
320517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            audioHwSync,
321517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &sidebandHandle));
322517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, hidl_handle(sidebandHandle));
323517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
324517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
325517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
326517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getGraphicBufferUsage(
327517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, getGraphicBufferUsage_cb _hidl_cb) {
328517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMX_U32 usage;
329517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getGraphicBufferUsage(
330517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex, &usage));
331517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, usage);
332517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
333517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
334517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
335517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setInputSurface(
336517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const sp<IOmxBufferSource>& bufferSource) {
337517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setInputSurface(new LWOmxBufferSource(
338517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            bufferSource)));
339517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
340517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
341517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::allocateSecureBuffer(
342517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, uint64_t size,
343517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        allocateSecureBuffer_cb _hidl_cb) {
344517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    IOMX::buffer_id buffer;
345517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    void* bufferData;
346517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    sp<NativeHandle> nativeHandle;
347517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->allocateSecureBuffer(
348517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
349517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<size_t>(size),
350517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &buffer,
351517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &bufferData,
352517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &nativeHandle));
353c7455a0bb4909d1d48c86e4a9b699ddda65f87f4Pawin Vongmasa    _hidl_cb(status, buffer, nativeHandle == nullptr ?
354c7455a0bb4909d1d48c86e4a9b699ddda65f87f4Pawin Vongmasa            nullptr : nativeHandle->handle());
355517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
356517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
357517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
358517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::useBuffer(
359517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, const CodecBuffer& codecBuffer,
360517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        useBuffer_cb _hidl_cb) {
361517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    IOMX::buffer_id buffer;
362517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
363517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
364517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        _hidl_cb(Status::BAD_VALUE, 0);
365517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Void();
366517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
367517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->useBuffer(
368517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex, omxBuffer, &buffer));
369517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, buffer);
370517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
371517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
372517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
373517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::freeBuffer(uint32_t portIndex, uint32_t buffer) {
374517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->freeBuffer(portIndex, buffer));
375517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
376517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
377517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::fillBuffer(
378517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t buffer, const CodecBuffer& codecBuffer,
379517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const hidl_handle& fence) {
380517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
381517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
382517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
383517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
384517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->fillBuffer(
385517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
386517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            omxBuffer,
3878a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa            dup(native_handle_read_fd(fence))));
388517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
389517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
390517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::emptyBuffer(
391517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t buffer, const CodecBuffer& codecBuffer, uint32_t flags,
392517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint64_t timestampUs, const hidl_handle& fence) {
393517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
394517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
395517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
396517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
397517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->emptyBuffer(
398517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
399517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            omxBuffer,
400517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            flags,
401517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toOMXTicks(timestampUs),
4028a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa            dup(native_handle_read_fd(fence))));
403517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
404517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
405517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getExtensionIndex(
406517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const hidl_string& parameterName,
407517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getExtensionIndex_cb _hidl_cb) {
408517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMX_INDEXTYPE index;
409517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getExtensionIndex(
410c1d17710bde127ad6c4533490b27effb3016f1b4Scott Randolph            parameterName.c_str(), &index));
411517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, toRawIndexType(index));
412517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
413517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
414517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
415517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::dispatchMessage(const Message& tMsg) {
416517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    omx_message lMsg;
4178a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    if (!convertTo(&lMsg, tMsg)) {
418517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
419517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
420517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->dispatchMessage(lMsg));
421517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
422517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
423eeac97b18ca5c939bf2ac59334d36d54f705af3dPawin Vongmasa}  // namespace utils
424517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace V1_0
425517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace omx
426517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace media
427517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace hardware
428517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace android
429