| /****************************************************************************** |
| * |
| * 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 "OverrideLog.h" |
| #include "StartupConfig.h" |
| |
| |
| const UINT8 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* 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* newContent, UINT8 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 bitmask) |
| { |
| const UINT8 maxLen = mBuffer[0]; |
| UINT8 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 tlv [] = {0x04, 0xC2, 0x02, 0x61, 0x00}; |
| tlv [4] = tlv [4] | bitmask; |
| found0xC2 = append (tlv, 5); |
| } |
| return found0xC2; |
| } |