You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
66 lines
2.3 KiB
66 lines
2.3 KiB
/******************************************************************************
|
|
*
|
|
* Copyright 2018 NXP
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
******************************************************************************/
|
|
|
|
#include <log/log.h>
|
|
|
|
#include "NxpNfc.h"
|
|
#include "phNxpNciHal_Adaptation.h"
|
|
|
|
extern bool nfc_debug_enabled;
|
|
|
|
namespace vendor {
|
|
namespace nxp {
|
|
namespace nxpnfc {
|
|
namespace V1_0 {
|
|
namespace implementation {
|
|
// Methods from ::vendor::nxp::nxpnfc::V1_0::INxpNfc follow.
|
|
Return<void> NxpNfc::ioctl(uint64_t ioctlType,
|
|
const hidl_vec<uint8_t>& inOutData,
|
|
ioctl_cb _hidl_cb) {
|
|
int status;
|
|
nfc_nci_IoctlInOutData_t inpOutData;
|
|
NfcData outputData;
|
|
nfc_nci_IoctlInOutData_t* pInOutData =
|
|
(nfc_nci_IoctlInOutData_t*)&inOutData[0];
|
|
|
|
if (inOutData.size() < sizeof(nfc_nci_IoctlInOutData_t)) {
|
|
ALOGE("%s invalid inOutData size, size = %d", __func__,
|
|
(int)inOutData.size());
|
|
return Void();
|
|
}
|
|
/*data from proxy->stub is copied to local data which can be updated by
|
|
* underlying HAL implementation since its an inout argument*/
|
|
memcpy(&inpOutData, pInOutData, sizeof(nfc_nci_IoctlInOutData_t));
|
|
status = phNxpNciHal_ioctl(ioctlType, &inpOutData);
|
|
/*copy data and additional fields indicating status of ioctl operation
|
|
* and context of the caller. Then invoke the corresponding proxy callback*/
|
|
inpOutData.out.ioctlType = ioctlType;
|
|
inpOutData.out.context = pInOutData->inp.context;
|
|
inpOutData.out.result = status;
|
|
outputData.setToExternal((uint8_t*)&inpOutData.out,
|
|
sizeof(nfc_nci_ExtnOutputData_t));
|
|
_hidl_cb(outputData);
|
|
return Void();
|
|
}
|
|
|
|
} // namespace implementation
|
|
} // namespace V1_0
|
|
} // namespace nxpnfc
|
|
} // namespace nxp
|
|
} // namespace vendor
|