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
19255735a38b9d5c3755c7b819bdc8fdaf4357d860Pawin Vongmasa#include <media/stagefright/omx/1.0/WOmxNode.h>
20255735a38b9d5c3755c7b819bdc8fdaf4357d860Pawin Vongmasa#include <media/stagefright/omx/1.0/WOmxBufferSource.h>
21255735a38b9d5c3755c7b819bdc8fdaf4357d860Pawin Vongmasa#include <media/stagefright/omx/1.0/Conversion.h>
22517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
23517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace android {
24517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace hardware {
25517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace media {
26517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace omx {
27517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace V1_0 {
28517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasanamespace implementation {
29517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
30517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasausing ::android::hardware::Void;
31517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
32517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa// LWOmxNode
33517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaLWOmxNode::LWOmxNode(sp<IOmxNode> const& base) : mBase(base) {
34517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
35517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
36517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::freeNode() {
37517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->freeNode());
38517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
39517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
40517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::sendCommand(
41517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_COMMANDTYPE cmd, OMX_S32 param) {
42517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->sendCommand(
43517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawCommandType(cmd), param));
44517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
45517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
46517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getParameter(
47517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE index, void *params, size_t size) {
48517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> tParams = inHidlBytes(params, size);
49517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
50517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getParameter(
51517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawIndexType(index),
52517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            tParams,
536330ce561e401ca5bc65a74a323de32fc5bad7adYi Kong            [&fnStatus, params](
54517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status, hidl_vec<uint8_t> const& outParams) {
55517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
56517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                std::copy(
57517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        outParams.data(),
58517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        outParams.data() + outParams.size(),
59517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        static_cast<uint8_t*>(params));
60517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
61517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
62517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
63517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
64517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::setParameter(
65517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE index, const void *params, size_t size) {
66517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> tParams = inHidlBytes(params, size);
67517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->setParameter(
68517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawIndexType(index), tParams));
69517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
70517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
71517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getConfig(
72517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE index, void *params, size_t size) {
73517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> tParams = inHidlBytes(params, size);
74517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
75517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getConfig(
76517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawIndexType(index),
77517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            tParams,
78517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, params, size](
79517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status, hidl_vec<uint8_t> const& outParams) {
80517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
81517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                std::copy(
82517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        outParams.data(),
83517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        outParams.data() + size,
84517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        static_cast<uint8_t*>(params));
85517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
86517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
87517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
88517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
89517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::setConfig(
90517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE index, const void *params, size_t size) {
91517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> tParams = inHidlBytes(params, size);
92517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->setConfig(toRawIndexType(index), tParams));
93517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
94517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
95517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::setPortMode(
96517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 port_index, IOMX::PortMode mode) {
97517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->setPortMode(port_index, toHardwarePortMode(mode)));
98517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
99517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
100517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::prepareForAdaptivePlayback(
101517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, OMX_BOOL enable,
102517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 maxFrameWidth, OMX_U32 maxFrameHeight) {
103517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->prepareForAdaptivePlayback(
104517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex, toRawBool(enable), maxFrameWidth, maxFrameHeight));
105517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
106517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
107517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::configureVideoTunnelMode(
108517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, OMX_BOOL tunneled,
109517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 audioHwSync, native_handle_t **sidebandHandle) {
110517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
111517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->configureVideoTunnelMode(
112517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
113517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawBool(tunneled),
114517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            audioHwSync,
115517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, sidebandHandle](
116517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status, hidl_handle const& outSidebandHandle) {
117517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
118f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa                *sidebandHandle = outSidebandHandle == nullptr ?
119f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa                        nullptr : native_handle_clone(outSidebandHandle);
120517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
121517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
122517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
123517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
124517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getGraphicBufferUsage(
125517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, OMX_U32* usage) {
126517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
127517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getGraphicBufferUsage(
128517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
129517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, usage](
130517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status, uint32_t outUsage) {
131517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
132517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *usage = outUsage;
133517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
134517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
135517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
136517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
137517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::setInputSurface(
138517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const sp<IOMXBufferSource> &bufferSource) {
139517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->setInputSurface(
140517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            new TWOmxBufferSource(bufferSource)));
141517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
142517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
143517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::allocateSecureBuffer(
144517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, size_t size, buffer_id *buffer,
145517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        void **buffer_data, sp<NativeHandle> *native_handle) {
146517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    *buffer_data = nullptr;
147517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
148517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->allocateSecureBuffer(
149517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
150517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<uint64_t>(size),
1516330ce561e401ca5bc65a74a323de32fc5bad7adYi Kong            [&fnStatus, buffer, native_handle](
152517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    Status status,
153517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    uint32_t outBuffer,
154517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                    hidl_handle const& outNativeHandle) {
155517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
156517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *buffer = outBuffer;
157fad26c14c7e68c3fe40bda8fd5692b8dbfac1000Santhosh Behara                *native_handle = outNativeHandle.getNativeHandle() == nullptr ?
158fad26c14c7e68c3fe40bda8fd5692b8dbfac1000Santhosh Behara                        nullptr : NativeHandle::create(
159517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        native_handle_clone(outNativeHandle), true);
160517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
161517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
162517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
163517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
164517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::useBuffer(
165517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, const OMXBuffer &omxBuffer, buffer_id *buffer) {
166517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
167517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
168517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
169517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
170517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
171517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->useBuffer(
172517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
173517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            codecBuffer,
174517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, buffer](Status status, uint32_t outBuffer) {
175517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
176517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *buffer = outBuffer;
177517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
178517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
179517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
180517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
181517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::freeBuffer(
182517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, buffer_id buffer) {
183517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->freeBuffer(portIndex, buffer));
184517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
185517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
186517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::fillBuffer(
187517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        buffer_id buffer, const OMXBuffer &omxBuffer, int fenceFd) {
188517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
189517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
190517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
191517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
192517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* fenceNh = native_handle_create_from_fd(fenceFd);
193517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!fenceNh) {
194517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
195517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
196517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->fillBuffer(
197517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer, codecBuffer, fenceNh));
1988a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(fenceNh);
199517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(fenceNh);
200517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
201517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
202517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
203517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::emptyBuffer(
204517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        buffer_id buffer, const OMXBuffer &omxBuffer,
205517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 flags, OMX_TICKS timestamp, int fenceFd) {
206517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
207517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
208517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
209517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
210517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* fenceNh = native_handle_create_from_fd(fenceFd);
211517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!fenceNh) {
212517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
213517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
214517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->emptyBuffer(
215517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
216517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            codecBuffer,
217517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            flags,
218517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawTicks(timestamp),
219517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            fenceNh));
2208a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(fenceNh);
221517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(fenceNh);
222517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
223517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
224517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getExtensionIndex(
225517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const char *parameter_name,
226517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE *index) {
227517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
228517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getExtensionIndex(
229517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            hidl_string(parameter_name),
230517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, index](Status status, uint32_t outIndex) {
231517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
232517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *index = toEnumIndexType(outIndex);
233517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
234517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
235517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
236517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
237517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::dispatchMessage(const omx_message &lMsg) {
238517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Message tMsg;
239517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* nh;
240517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&tMsg, &nh, lMsg)) {
241517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
242517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
243517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->dispatchMessage(tMsg));
2448a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(nh);
245517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(nh);
246517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
247517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
248517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
249517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa// TWOmxNode
250517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaTWOmxNode::TWOmxNode(sp<IOMXNode> const& base) : mBase(base) {
251517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
252517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
253517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::freeNode() {
254517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->freeNode());
255517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
256517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
257517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::sendCommand(uint32_t cmd, int32_t param) {
258517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->sendCommand(toEnumCommandType(cmd), param));
259517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
260517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
261517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getParameter(
262517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t index, hidl_vec<uint8_t> const& inParams,
263517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getParameter_cb _hidl_cb) {
264517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> params(inParams);
265517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getParameter(
266517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
267517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void*>(params.data()),
268517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            params.size()));
269517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, params);
270517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
271517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
272517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
273517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setParameter(
2748ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa        uint32_t index, hidl_vec<uint8_t> const& inParams) {
2758ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa    hidl_vec<uint8_t> params(inParams);
276517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setParameter(
277517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
278517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void const*>(params.data()),
279517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            params.size()));
280517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
281517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
282517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getConfig(
283517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t index, const hidl_vec<uint8_t>& inConfig,
284517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getConfig_cb _hidl_cb) {
285517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> config(inConfig);
286517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getConfig(
287517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
288517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void*>(config.data()),
289517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            config.size()));
290517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, config);
291517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
292517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
293517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
294517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setConfig(
2958ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa        uint32_t index, const hidl_vec<uint8_t>& inConfig) {
2968ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa    hidl_vec<uint8_t> config(inConfig);
297517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setConfig(
298517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
299517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void const*>(config.data()),
300517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            config.size()));
301517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
302517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
303517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setPortMode(uint32_t portIndex, PortMode mode) {
304517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setPortMode(portIndex, toIOMXPortMode(mode)));
305517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
306517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
307517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::prepareForAdaptivePlayback(
308517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, bool enable,
309517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t maxFrameWidth, uint32_t maxFrameHeight) {
310517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->prepareForAdaptivePlayback(
311517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
312517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumBool(enable),
313517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            maxFrameWidth,
314517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            maxFrameHeight));
315517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
316517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
317517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::configureVideoTunnelMode(
318517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, bool tunneled, uint32_t audioHwSync,
319517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        configureVideoTunnelMode_cb _hidl_cb) {
320f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa    native_handle_t* sidebandHandle = nullptr;
321517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->configureVideoTunnelMode(
322517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
323517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumBool(tunneled),
324517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            audioHwSync,
325517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &sidebandHandle));
326517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, hidl_handle(sidebandHandle));
327517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
328517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
329517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
330517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getGraphicBufferUsage(
331517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, getGraphicBufferUsage_cb _hidl_cb) {
332517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMX_U32 usage;
333517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getGraphicBufferUsage(
334517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex, &usage));
335517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, usage);
336517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
337517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
338517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
339517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setInputSurface(
340517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const sp<IOmxBufferSource>& bufferSource) {
341517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setInputSurface(new LWOmxBufferSource(
342517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            bufferSource)));
343517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
344517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
345517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::allocateSecureBuffer(
346517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, uint64_t size,
347517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        allocateSecureBuffer_cb _hidl_cb) {
348517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    IOMX::buffer_id buffer;
349517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    void* bufferData;
350517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    sp<NativeHandle> nativeHandle;
351517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->allocateSecureBuffer(
352517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
353517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<size_t>(size),
354517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &buffer,
355517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &bufferData,
356517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &nativeHandle));
357c7455a0bb4909d1d48c86e4a9b699ddda65f87f4Pawin Vongmasa    _hidl_cb(status, buffer, nativeHandle == nullptr ?
358c7455a0bb4909d1d48c86e4a9b699ddda65f87f4Pawin Vongmasa            nullptr : nativeHandle->handle());
359517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
360517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
361517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
362517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::useBuffer(
363517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, const CodecBuffer& codecBuffer,
364517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        useBuffer_cb _hidl_cb) {
365517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    IOMX::buffer_id buffer;
366517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
367517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
368517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        _hidl_cb(Status::BAD_VALUE, 0);
369517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Void();
370517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
371517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->useBuffer(
372517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex, omxBuffer, &buffer));
373517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, buffer);
374517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
375517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
376517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
377517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::freeBuffer(uint32_t portIndex, uint32_t buffer) {
378517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->freeBuffer(portIndex, buffer));
379517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
380517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
381517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::fillBuffer(
382517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t buffer, const CodecBuffer& codecBuffer,
383517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const hidl_handle& fence) {
384517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
385517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
386517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
387517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
388517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->fillBuffer(
389517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
390517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            omxBuffer,
3918a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa            dup(native_handle_read_fd(fence))));
392517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
393517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
394517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::emptyBuffer(
395517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t buffer, const CodecBuffer& codecBuffer, uint32_t flags,
396517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint64_t timestampUs, const hidl_handle& fence) {
397517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
398517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
399517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
400517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
401517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->emptyBuffer(
402517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
403517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            omxBuffer,
404517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            flags,
405517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toOMXTicks(timestampUs),
4068a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa            dup(native_handle_read_fd(fence))));
407517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
408517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
409517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getExtensionIndex(
410517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const hidl_string& parameterName,
411517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getExtensionIndex_cb _hidl_cb) {
412517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMX_INDEXTYPE index;
413517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getExtensionIndex(
414c1d17710bde127ad6c4533490b27effb3016f1b4Scott Randolph            parameterName.c_str(), &index));
415517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, toRawIndexType(index));
416517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
417517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
418517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
419517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::dispatchMessage(const Message& tMsg) {
420517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    omx_message lMsg;
4218a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    if (!convertTo(&lMsg, tMsg)) {
422517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
423517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
424517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->dispatchMessage(lMsg));
425517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
426517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
427517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace implementation
428517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace V1_0
429517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace omx
430517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace media
431517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace hardware
432517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace android
433