/****************************************************************************** * * Copyright (C) 1999-2012 Broadcom Corporation * * 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. * ******************************************************************************/ /****************************************************************************** * Construct a buffer that contains multiple Type-Length-Value contents * that is used by the HAL in a CORE_SET_CONFIG NCI command. ******************************************************************************/ #define LOG_TAG "NfcNciHal" #include "StartupConfig.h" #include "_OverrideLog.h" const uint8_t StartupConfig::mMaxLength = 255; /******************************************************************************* ** ** Function: initialize ** ** Description: Initialize all member variables. ** ** Returns: None ** *******************************************************************************/ StartupConfig::StartupConfig() { // set first byte to 0, which is length of payload mBuffer.append((uint8_string::size_type)1, (uint8_string::value_type)0); } /******************************************************************************* ** ** Function: initialize ** ** Description: Reset all member variables. ** ** Returns: None ** *******************************************************************************/ void StartupConfig::initialize() { mBuffer.clear(); // set first byte to 0, which is length of payload mBuffer.append((uint8_string::size_type)1, (uint8_string::value_type)0); } /******************************************************************************* ** ** Function: getInternalBuffer ** ** Description: Get the pointer to buffer that contains multiple ** Type-Length-Value contents. ** ** Returns: Pointer to buffer. ** *******************************************************************************/ const uint8_t* StartupConfig::getInternalBuffer() { return mBuffer.data(); } /******************************************************************************* ** ** Function: append ** ** Description: Append new config data to internal buffer. ** newContent: buffer containing new content; newContent[0] is ** payload length; newContent[1..end] is payload. ** newContentLen: total length of newContent. ** ** Returns: True if ok. ** *******************************************************************************/ bool StartupConfig::append(const uint8_t* newContent, uint8_t newContentLen) { static const char fn[] = "StartupConfig::append"; if ((newContentLen + mBuffer.size()) > mMaxLength) { ALOGE("%s: exceed max length", fn); return false; } ALOGD("%s: try append %u bytes", fn, (uint8_string::size_type)(newContentLen)); // append new payload into private buffer mBuffer.append(newContent + 1, (uint8_string::size_type)(newContentLen - 1)); // increase size counter of payload in private buffer mBuffer[0] = mBuffer[0] + newContentLen - 1; ALOGD("%s: new size %u bytes", fn, mBuffer[0]); return true; }; /******************************************************************************* ** ** Function: disableSecureElement ** ** Description: Adjust a TLV to disable secure element(s). The TLV's type *is 0xC2. ** bitmask: 0xC0 = do not detect any secure element. ** 0x40 = do not detect secure element in slot 0. ** 0x80 = do not detect secure element in slot 1. ** ** Returns: True if ok. ** *******************************************************************************/ bool StartupConfig::disableSecureElement(uint8_t bitmask) { const uint8_t maxLen = mBuffer[0]; uint8_t index = 1, tlvType = 0, tlvLen = 0; bool found0xC2 = false; while (true) { if (index > maxLen) break; tlvType = mBuffer[index]; index++; tlvLen = mBuffer[index]; index++; if (tlvType == 0xC2) // this TLV controls secure elements { index++; // index of second byte in TLV's value mBuffer[index] = mBuffer[index] | bitmask; // turn on certain bits found0xC2 = true; } else index += tlvLen; } if (found0xC2 == false) { uint8_t tlv[] = {0x04, 0xC2, 0x02, 0x61, 0x00}; tlv[4] = tlv[4] | bitmask; found0xC2 = append(tlv, 5); } return found0xC2; }