Files
NxpNfcRdLib/.svn/pristine/15/157a09aa0d2567f43defea67f1e1c5f873a0aed5.svn-base
2024-07-08 21:03:06 +08:00

364 lines
12 KiB
Plaintext

/*
* Copyright (c), NXP Semiconductors Gratkorn / Austria
*
* (C)NXP Semiconductors
* All rights are reserved. Reproduction in whole or in part is
* prohibited without the written consent of the copyright owner.
* NXP reserves the right to make changes without notice at any time.
* NXP makes no warranty, expressed, implied or statutory, including but
* not limited to any implied warranty of merchantability or fitness for any
*particular purpose, or that the use will not infringe any third party patent,
* copyright or trademark. NXP must not be liable for any loss or damage
* arising from its use.
*/
/** \file
* Rc663 Keystore Component of Reader Library Framework.
* $Author$
* $Revision$ (v07.10.00)
* $Date$
*
* History:
* RSn: Generated 5. May 2010
*
*/
#include <ph_Status.h>
#include <ph_RefDefs.h>
#include <phhalHw.h>
#include <phKeyStore.h>
#ifdef NXPBUILD__PH_KEYSTORE_RC663
#include "phKeyStore_Rc663.h"
#include "phKeyStore_Rc663_Int.h"
#include <phhalHw_Rc663_Reg.h>
phStatus_t phKeyStore_Rc663_Init(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wSizeOfDataParams,
void * pHalDataParams
)
{
/* Dataparam structure check */
if (sizeof(phKeyStore_Rc663_DataParams_t) != wSizeOfDataParams)
{
return PH_ADD_COMPCODE_FIXED(PH_ERR_INVALID_DATA_PARAMS, PH_COMP_KEYSTORE);
}
PH_ASSERT_NULL (pDataParams);
PH_ASSERT_NULL (pHalDataParams);
/* Init private data */
pDataParams->wId = PH_COMP_KEYSTORE| PH_KEYSTORE_RC663_ID;
pDataParams->pHalDataParams = pHalDataParams;
return PH_ERR_SUCCESS;
}
phStatus_t phKeyStore_Rc663_FormatKeyEntry(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wKeyNo,
uint16_t wNewKeyType
)
{
uint8_t PH_MEMLOC_BUF bKey[PH_KEYSTORE_KEY_TYPE_MIFARE_SIZE];
/* clear key buffer */
(void)memset(bKey, 0x00, PH_KEYSTORE_KEY_TYPE_MIFARE_SIZE);
return phKeyStore_Rc663_SetKeyAtPos(pDataParams, wKeyNo, 0, wNewKeyType, bKey, 0);
}
phStatus_t phKeyStore_Rc663_SetKey(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wKeyNo,
uint16_t wKeyVersion,
uint16_t wKeyType,
uint8_t * pNewKey,
uint16_t wNewKeyVersion
)
{
/* satisfy compiler */
if (0U != (wKeyVersion));
return (phKeyStore_Rc663_SetKeyAtPos(pDataParams, wKeyNo, 0, wKeyType, pNewKey, wNewKeyVersion));
}
phStatus_t phKeyStore_Rc663_SetKeyAtPos(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wKeyNo,
uint16_t wPos,
uint16_t wKeyType,
uint8_t * pNewKey,
uint16_t wNewKeyVersion
)
{
phStatus_t PH_MEMLOC_REM statusTmp;
uint8_t PH_MEMLOC_BUF bKeyNoInt;
/* satisfy compiler */
if (wPos || wNewKeyVersion);
/* Check if wKeyNo is out of range */
if (wKeyNo >= PH_KEYSTORE_RC663_NUM_KEYS)
{
return PH_ADD_COMPCODE_FIXED(PH_ERR_INVALID_PARAMETER, PH_COMP_KEYSTORE);
}
/* Retrieve Key type */
switch(wKeyType)
{
/* MIFARE keys are the only supported keys */
case PH_KEYSTORE_KEY_TYPE_MIFARE:
/* prepare the command to be sent */
bKeyNoInt = (uint8_t)(wKeyNo << 1U);
PH_CHECK_SUCCESS_FCT(statusTmp, phKeyStore_Rc663_StoreKeyE2_Int(
pDataParams,
bKeyNoInt,
pNewKey,
2));
break;
case PH_KEYSTORE_KEY_TYPE_AES128:
case PH_KEYSTORE_KEY_TYPE_AES192:
case PH_KEYSTORE_KEY_TYPE_AES256:
case PH_KEYSTORE_KEY_TYPE_DES:
case PH_KEYSTORE_KEY_TYPE_2K3DES:
case PH_KEYSTORE_KEY_TYPE_3K3DES:
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_PARAMETER, PH_COMP_KEYSTORE);
default:
return PH_ADD_COMPCODE_FIXED(PH_ERR_INVALID_PARAMETER, PH_COMP_KEYSTORE);
}
return PH_ERR_SUCCESS;
}
phStatus_t phKeyStore_Rc663_SetKUC(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wKeyNo,
uint16_t wRefNoKUC
)
{
/* satisfy compiler */
if (pDataParams || wKeyNo || wRefNoKUC);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_COMMAND, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_SetFullKeyEntry(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wNoOfKeys,
uint16_t wKeyNo,
uint16_t wNewRefNoKUC,
uint16_t wNewKeyType,
uint8_t * pNewKeys,
uint16_t * pNewKeyVersionList
)
{
phStatus_t PH_MEMLOC_REM statusTmp;
uint16_t PH_MEMLOC_REM wKeyVersion = 0;
uint16_t PH_MEMLOC_COUNT i;
/* satisfy compiler */
if (wNewRefNoKUC || pNewKeyVersionList);
/* check wNoOfKeys */
if (wNoOfKeys > PH_KEYSTORE_RC663_NUM_VERSIONS)
{
return PH_ADD_COMPCODE_FIXED(PH_ERR_INVALID_PARAMETER, PH_COMP_KEYSTORE);
}
/* set keys */
for (i = 0; i < wNoOfKeys; ++i)
{
PH_CHECK_SUCCESS_FCT(statusTmp, phKeyStore_Rc663_SetKeyAtPos(pDataParams, wKeyNo, i, wNewKeyType, &pNewKeys[i*PH_KEYSTORE_KEY_TYPE_MIFARE_SIZE], wKeyVersion));
}
return PH_ERR_SUCCESS;
}
phStatus_t phKeyStore_Rc663_GetKeyEntry(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wKeyNo,
uint16_t wKeyVersionBufSize,
uint16_t * wKeyVersion,
uint16_t * wKeyVersionLength,
uint16_t * pKeyType
)
{
/* satisfy compiler */
if (pDataParams || wKeyNo || wKeyVersionBufSize || wKeyVersion || wKeyVersionLength || pKeyType);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_COMMAND, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_GetKey(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wKeyNo,
uint16_t wKeyVersion,
uint8_t bKeyBufSize,
uint8_t * pKey,
uint16_t * pKeyType
)
{
/* satisfy compiler */
if (pDataParams || wKeyNo || wKeyVersion || bKeyBufSize || pKey || pKeyType);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_COMMAND, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_SetConfig(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wConfig,
uint16_t wValue
)
{
/* satisfy compiler */
if (pDataParams || wConfig || wValue);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_PARAMETER, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_SetConfigStr(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wConfig,
uint8_t *pBuffer,
uint16_t wBufferLength
)
{
/* satisfy compiler */
if (pDataParams || wConfig || pBuffer || wBufferLength);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_PARAMETER, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_GetConfig(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wConfig,
uint16_t * pValue
)
{
/* satisfy compiler */
if (pDataParams || wConfig || pValue);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_PARAMETER, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_GetConfigStr(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wConfig,
uint8_t ** ppBuffer,
uint16_t * pBufferLength
)
{
/* satisfy compiler */
if (pDataParams || wConfig || ppBuffer || pBufferLength);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_PARAMETER, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_ChangeKUC(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wRefNoKUC,
uint32_t dwLimit
)
{
/* satisfy compiler */
if (pDataParams || wRefNoKUC || dwLimit);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_COMMAND, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_GetKUC(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint16_t wRefNoKUC,
uint32_t * pdwLimit,
uint32_t * pdwCurVal
)
{
/* satisfy compiler */
if (pDataParams || wRefNoKUC || pdwLimit || pdwCurVal);
return PH_ADD_COMPCODE_FIXED(PH_ERR_UNSUPPORTED_COMMAND, PH_COMP_KEYSTORE);
}
phStatus_t phKeyStore_Rc663_StoreKeyE2_Int(
phKeyStore_Rc663_DataParams_t * pDataParams,
uint8_t bKeyNumber,
uint8_t * pKey,
uint8_t bNumKeys
)
{
phStatus_t PH_MEMLOC_REM statusTmp;
uint8_t PH_MEMLOC_REM bRegValue;
uint16_t PH_MEMLOC_COUNT wIndex;
/* clear all IRQ0 flags */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_WriteRegister(
pDataParams->pHalDataParams,
PH_KEYSTORE_RC663_REG_IRQ0,
(uint8_t)~(uint8_t)PH_KEYSTORE_RC663_BIT_IRQ_SET));
/* clear all IRQ1 flags */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_WriteRegister(
pDataParams->pHalDataParams,
PH_KEYSTORE_RC663_REG_IRQ1,
(uint8_t)~(uint8_t)PH_KEYSTORE_RC663_BIT_IRQ_SET));
/* Stop an eventual previous Command (enter Idle state) */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_WriteRegister(
pDataParams->pHalDataParams,
PH_KEYSTORE_RC663_REG_COMMAND,
PH_KEYSTORE_RC663_CMD_IDLE
));
/* Flush Rc663 fifo */
/* Read FIFO Control register*/
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_ReadRegister(pDataParams->pHalDataParams, PH_KEYSTORE_RC663_REG_FIFOCONTROL, &bRegValue));
/* Set FlushFifo bit */
bRegValue |= PH_KEYSTORE_RC663_BIT_FLUSHFIFO;
/* Write to FIFO Control register */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_WriteRegister(pDataParams->pHalDataParams, PH_KEYSTORE_RC663_REG_FIFOCONTROL, bRegValue));
/* Write the Key number */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_WriteRegister(pDataParams->pHalDataParams, PH_KEYSTORE_RC663_REG_FIFODATA, bKeyNumber));
/* Write each single key byte */
for (wIndex = 0; wIndex < (bNumKeys * PH_KEYSTORE_KEY_TYPE_MIFARE_SIZE); ++wIndex)
{
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_WriteRegister(pDataParams->pHalDataParams, PH_KEYSTORE_RC663_REG_FIFODATA, pKey[wIndex]));
}
/* start the command */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_WriteRegister(pDataParams->pHalDataParams, PH_KEYSTORE_RC663_REG_COMMAND, PH_KEYSTORE_RC663_CMD_STOREKEYE2));
/* wait for the EE programming to be finished */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Wait(pDataParams->pHalDataParams, PHHAL_HW_TIME_MILLISECONDS, PH_KEYSTORE_RC663_EEP_WR_TO_MS * bNumKeys));
/* take a look at the IDLE IRQ */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_ReadRegister(pDataParams->pHalDataParams, PH_KEYSTORE_RC663_REG_IRQ0, &bRegValue));
if ( (0U == ((PHHAL_HW_RC663_BIT_IDLEIRQ & bRegValue))))
{
/* stop the command */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_WriteRegister(
pDataParams->pHalDataParams,
PH_KEYSTORE_RC663_REG_COMMAND,
PH_KEYSTORE_RC663_CMD_IDLE));
return PH_ADD_COMPCODE_FIXED(PH_ERR_READ_WRITE_ERROR, PH_COMP_KEYSTORE);
}
/* read the error register */
PH_CHECK_SUCCESS_FCT(statusTmp, phhalHw_Rc663_ReadRegister(pDataParams->pHalDataParams, PHHAL_HW_RC663_REG_ERROR, &bRegValue));
/* check for EEPROM error */
if (0U != (bRegValue & PHHAL_HW_RC663_BIT_EE_ERR))
{
return PH_ADD_COMPCODE_FIXED(PH_ERR_READ_WRITE_ERROR, PH_COMP_KEYSTORE);
}
return PH_ERR_SUCCESS;
}
#endif /* NXPBUILD__PH_KEYSTORE_RC663 */