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
19517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa#include "WOmxNode.h"
20517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa#include "WOmxBufferSource.h"
21517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa#include "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,
53517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, params, size](
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),
151517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, buffer, buffer_data, 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;
157517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *native_handle = NativeHandle::create(
158517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                        native_handle_clone(outNativeHandle), true);
159517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
160517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
161517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
162517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
163517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::useBuffer(
164517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, const OMXBuffer &omxBuffer, buffer_id *buffer) {
165517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
166517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
167517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
168517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
169517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
170517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->useBuffer(
171517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
172517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            codecBuffer,
173517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, buffer](Status status, uint32_t outBuffer) {
174517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
175517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *buffer = outBuffer;
176517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
177517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
178517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
179517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
180517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::freeBuffer(
181517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 portIndex, buffer_id buffer) {
182517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatusT(mBase->freeBuffer(portIndex, buffer));
183517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
184517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
185517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::fillBuffer(
186517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        buffer_id buffer, const OMXBuffer &omxBuffer, int fenceFd) {
187517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
188517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
189517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
190517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
191517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* fenceNh = native_handle_create_from_fd(fenceFd);
192517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!fenceNh) {
193517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
194517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
195517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->fillBuffer(
196517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer, codecBuffer, fenceNh));
1978a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(fenceNh);
198517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(fenceNh);
199517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
200517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
201517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
202517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::emptyBuffer(
203517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        buffer_id buffer, const OMXBuffer &omxBuffer,
204517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_U32 flags, OMX_TICKS timestamp, int fenceFd) {
205517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    CodecBuffer codecBuffer;
206517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&codecBuffer, omxBuffer)) {
207517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return BAD_VALUE;
208517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
209517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* fenceNh = native_handle_create_from_fd(fenceFd);
210517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!fenceNh) {
211517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
212517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
213517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->emptyBuffer(
214517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
215517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            codecBuffer,
216517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            flags,
217517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toRawTicks(timestamp),
218517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            fenceNh));
2198a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(fenceNh);
220517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(fenceNh);
221517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
222517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
223517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::getExtensionIndex(
224517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const char *parameter_name,
225517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        OMX_INDEXTYPE *index) {
226517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t fnStatus;
227517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t transStatus = toStatusT(mBase->getExtensionIndex(
228517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            hidl_string(parameter_name),
229517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            [&fnStatus, index](Status status, uint32_t outIndex) {
230517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                fnStatus = toStatusT(status);
231517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa                *index = toEnumIndexType(outIndex);
232517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            }));
233517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return transStatus == NO_ERROR ? fnStatus : transStatus;
234517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
235517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
236517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasastatus_t LWOmxNode::dispatchMessage(const omx_message &lMsg) {
237517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Message tMsg;
238517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_t* nh;
239517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!wrapAs(&tMsg, &nh, lMsg)) {
240517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return NO_MEMORY;
241517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
242517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    status_t status = toStatusT(mBase->dispatchMessage(tMsg));
2438a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    native_handle_close(nh);
244517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    native_handle_delete(nh);
245517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return status;
246517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
247517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
248517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa// TWOmxNode
249517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaTWOmxNode::TWOmxNode(sp<IOMXNode> const& base) : mBase(base) {
250517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
251517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
252517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::freeNode() {
253517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->freeNode());
254517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
255517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
256517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::sendCommand(uint32_t cmd, int32_t param) {
257517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->sendCommand(toEnumCommandType(cmd), param));
258517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
259517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
260517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getParameter(
261517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t index, hidl_vec<uint8_t> const& inParams,
262517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getParameter_cb _hidl_cb) {
263517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> params(inParams);
264517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getParameter(
265517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
266517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void*>(params.data()),
267517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            params.size()));
268517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, params);
269517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
270517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
271517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
272517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setParameter(
2738ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa        uint32_t index, hidl_vec<uint8_t> const& inParams) {
2748ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa    hidl_vec<uint8_t> params(inParams);
275517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setParameter(
276517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
277517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void const*>(params.data()),
278517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            params.size()));
279517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
280517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
281517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getConfig(
282517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t index, const hidl_vec<uint8_t>& inConfig,
283517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getConfig_cb _hidl_cb) {
284517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    hidl_vec<uint8_t> config(inConfig);
285517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getConfig(
286517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
287517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void*>(config.data()),
288517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            config.size()));
289517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, config);
290517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
291517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
292517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
293517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setConfig(
2948ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa        uint32_t index, const hidl_vec<uint8_t>& inConfig) {
2958ff40189817e95c7a56e347398d20e60d7534ee6Pawin Vongmasa    hidl_vec<uint8_t> config(inConfig);
296517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setConfig(
297517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumIndexType(index),
298517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<void const*>(config.data()),
299517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            config.size()));
300517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
301517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
302517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setPortMode(uint32_t portIndex, PortMode mode) {
303517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setPortMode(portIndex, toIOMXPortMode(mode)));
304517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
305517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
306517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::prepareForAdaptivePlayback(
307517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, bool enable,
308517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t maxFrameWidth, uint32_t maxFrameHeight) {
309517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->prepareForAdaptivePlayback(
310517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
311517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumBool(enable),
312517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            maxFrameWidth,
313517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            maxFrameHeight));
314517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
315517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
316517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::configureVideoTunnelMode(
317517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, bool tunneled, uint32_t audioHwSync,
318517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        configureVideoTunnelMode_cb _hidl_cb) {
319f62ea8018813951e8f6a182880cadb3217e4ce37Pawin Vongmasa    native_handle_t* sidebandHandle = nullptr;
320517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->configureVideoTunnelMode(
321517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
322517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toEnumBool(tunneled),
323517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            audioHwSync,
324517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &sidebandHandle));
325517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, hidl_handle(sidebandHandle));
326517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
327517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
328517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
329517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getGraphicBufferUsage(
330517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, getGraphicBufferUsage_cb _hidl_cb) {
331517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMX_U32 usage;
332517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getGraphicBufferUsage(
333517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex, &usage));
334517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, usage);
335517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
336517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
337517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
338517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::setInputSurface(
339517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const sp<IOmxBufferSource>& bufferSource) {
340517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->setInputSurface(new LWOmxBufferSource(
341517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            bufferSource)));
342517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
343517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
344517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::allocateSecureBuffer(
345517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, uint64_t size,
346517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        allocateSecureBuffer_cb _hidl_cb) {
347517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    IOMX::buffer_id buffer;
348517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    void* bufferData;
349517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    sp<NativeHandle> nativeHandle;
350517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->allocateSecureBuffer(
351517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex,
352517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            static_cast<size_t>(size),
353517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &buffer,
354517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &bufferData,
355517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            &nativeHandle));
356c7455a0bb4909d1d48c86e4a9b699ddda65f87f4Pawin Vongmasa    _hidl_cb(status, buffer, nativeHandle == nullptr ?
357c7455a0bb4909d1d48c86e4a9b699ddda65f87f4Pawin Vongmasa            nullptr : nativeHandle->handle());
358517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
359517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
360517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
361517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::useBuffer(
362517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t portIndex, const CodecBuffer& codecBuffer,
363517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        useBuffer_cb _hidl_cb) {
364517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    IOMX::buffer_id buffer;
365517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
366517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
367517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        _hidl_cb(Status::BAD_VALUE, 0);
368517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Void();
369517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
370517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->useBuffer(
371517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            portIndex, omxBuffer, &buffer));
372517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, buffer);
373517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
374517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
375517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
376517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::freeBuffer(uint32_t portIndex, uint32_t buffer) {
377517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->freeBuffer(portIndex, buffer));
378517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
379517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
380517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::fillBuffer(
381517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t buffer, const CodecBuffer& codecBuffer,
382517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const hidl_handle& fence) {
383517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
384517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
385517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
386517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
387517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->fillBuffer(
388517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
389517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            omxBuffer,
3908a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa            dup(native_handle_read_fd(fence))));
391517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
392517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
393517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::emptyBuffer(
394517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint32_t buffer, const CodecBuffer& codecBuffer, uint32_t flags,
395517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        uint64_t timestampUs, const hidl_handle& fence) {
396517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMXBuffer omxBuffer;
397517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    if (!convertTo(&omxBuffer, codecBuffer)) {
398517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
399517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
400517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->emptyBuffer(
401517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            buffer,
402517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            omxBuffer,
403517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            flags,
404517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa            toOMXTicks(timestampUs),
4058a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa            dup(native_handle_read_fd(fence))));
406517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
407517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
408517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<void> TWOmxNode::getExtensionIndex(
409517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        const hidl_string& parameterName,
410517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        getExtensionIndex_cb _hidl_cb) {
411517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    OMX_INDEXTYPE index;
412517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    Status status = toStatus(mBase->getExtensionIndex(
413c1d17710bde127ad6c4533490b27effb3016f1b4Scott Randolph            parameterName.c_str(), &index));
414517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    _hidl_cb(status, toRawIndexType(index));
415517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return Void();
416517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
417517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
418517b0e090680e378f056677201426ed9dc325c65Pawin VongmasaReturn<Status> TWOmxNode::dispatchMessage(const Message& tMsg) {
419517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    omx_message lMsg;
4208a21c0191f974a0b9cbd5818052e2655e0aaa306Pawin Vongmasa    if (!convertTo(&lMsg, tMsg)) {
421517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa        return Status::BAD_VALUE;
422517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    }
423517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa    return toStatus(mBase->dispatchMessage(lMsg));
424517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}
425517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa
426517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace implementation
427517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace V1_0
428517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace omx
429517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace media
430517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace hardware
431517b0e090680e378f056677201426ed9dc325c65Pawin Vongmasa}  // namespace android
432