|
NXP Reader Library
v17.1.0.2535
|
|
Example code to configure HAL and BAL for Pegoda 2 (RD710) reader with SAM AV3 in S (NonX) mode.
More...
|
| | RD710 Initialization |
| | Example code to configure PAL 3A, 4A, 4, MIFARE and SLI15693 to work in RD710 mode. This is valid for RD710 / CM1 reader only.
|
| |
| | Software Initialization |
| | Example code to configure PAL 3A, 4A, 4, MIFARE and SLI15693 to work in software mode.
|
| |
Example code to configure HAL and BAL for Pegoda 2 (RD710) reader with SAM AV3 in S (NonX) mode.
#define CHECK_SUCCESS(x) \
if ( (x) != PH_ERR_SUCCESS ) \
{ \
printf ( "\n\n" ); \
printf ( "An error occurred: (0x%04X)\n", (x) ); \
printf ( "Pressing any key will exit the demo.\n" ); \
_getch (); \
return 0; \
}
uint8_t aHostAuthKey[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
void* pBal_Generic = NULL;
void* pHal_Generic = NULL;
aKeyUsageCounter, 0xFF );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
memset ( aSeed, 0x00, 0x08 );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
sizeof ( aTx_HalBuffer ), aRx_HalBuffer, sizeof ( aRx_HalBuffer ) );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
sizeof ( aTx_BalBuffer ), aRx_BalBuffer, sizeof ( aRx_BalBuffer ) ) );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
&stCryptoSym_Enc, &stCryptoSym_MAC, &stCryptoRng_Rng, &stCryptoSym_Enc_PLUpload, &stCryptoSym_Mac_PLUpload,
sizeof ( aRx_SamBuffer ), aPLUploadBuffer );
CHECK_SUCCESS ( wStatus );
pBal_Generic = &stBal_Sam;
pHal_Generic = &stHal_SamAv3;
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
CHECK_SUCCESS ( wStatus );
0x00, 0x00, 0x00 );
CHECK_SUCCESS ( wStatus );
PCSC (Windows) BAL parameter structure.
Definition: phbalReg.h:600
phStatus_t phKeyStore_Sw_Init(phKeyStore_Sw_DataParams_t *pDataParams, uint16_t wSizeOfDataParams, phKeyStore_Sw_KeyEntry_t *pKeyEntries, uint16_t wNoOfKeyEntries, phKeyStore_Sw_KeyVersionPair_t *pKeyVersionPairs, uint16_t wNoOfVersionPairs, phKeyStore_Sw_KUCEntry_t *pKUCEntries, uint16_t wNoOfKUCEntries)
Initializes the KeyStore component as software component.
phStatus_t phCryptoSym_Sw_Init(phCryptoSym_Sw_DataParams_t *pDataParams, uint16_t wSizeOfDataParams, void *pKeyStoreDataParams)
Initialize the CryptoSym with Software as sub-component.
Software KeyEntry structure.
Definition: phKeyStore.h:66
Software parameter structure.
Definition: phKeyStore.h:82
phStatus_t phKeyStore_SetKeyAtPos(void *pDataParams, uint16_t wKeyNo, uint16_t wPos, uint16_t wKeyType, uint8_t *pNewKey, uint16_t wNewKeyVersion)
Change a symmetric key entry at the specified position.
phStatus_t phhalHw_Rd710_Init(phhalHw_Rd710_DataParams_t *pDataParams, uint16_t wSizeOfDataParams, void *pBalDataParams, uint8_t bSlotNumber, uint8_t *pTxBuffer, uint16_t wTxBufSize, uint8_t *pRxBuffer, uint16_t wRxBufSize)
Initialise the HAL component.
phStatus_t phhalHw_Rd710_Cmd_InitReader(phhalHw_Rd710_DataParams_t *pDataParams)
The function starts the reader in direct PCSC mode and initializes the following stack components: HA...
Software KeyVersionPair structure for Symmetric and ASymmetric keys.
Definition: phKeyStore.h:51
#define PHHAL_HW_SAMAV3_CMD_SAM_AUTHENTICATE_HOST_MODE_PLAIN
Option mask for protection mode as plain.
Definition: phhalHw_SamAV3_Cmd.h:295
uint16_t phStatus_t
phcsBfl_Status_t is a signed short value, using the positive range.
Definition: ph_TypeDefs.h:158
#define PHBAL_REG_PCSCWIN_VALUE_PROTOCOL_UNDEFINED
UNDEFINED protocol.
Definition: phbalReg.h:641
Sam BAL parameter structure.
Definition: phbalReg.h:1031
phStatus_t phhalHw_SamAV3_Init(phhalHw_SamAV3_DataParams_t *pDataParams, uint16_t wSizeOfDataParams, void *pBalDataParams, void *pReaderHalDataParams, void *pKeyStoreDataParams, void *pCryptoENCDataParams, void *pCryptoMACDataParams, void *pCryptoRngDataParams, void *pPLUpload_CryptoENCDataParams, void *pPLUpload_CryptoMACDataParams, uint8_t bOpMode, uint8_t bLogicalChannel, uint8_t *pTxBuffer, uint16_t wTxBufSize, uint8_t *pRxBuffer, uint16_t wRxBufSize, uint8_t *pPLUploadBuf)
Initialise the HAL component.
#define PH_KEYSTORE_KEY_TYPE_AES128
AES 128 Key [16].
Definition: phKeyStore.h:1067
Rd710 HAL parameter structure.
Definition: phhalHw.h:1484
phStatus_t phCryptoRng_Sw_Init(phCryptoRng_Sw_DataParams_t *pDataParams, uint16_t wSizeOfDataParams, void *pCryptoDataParams)
Initialize the CryptoRng with software as sub-component.
phStatus_t phhalHw_SamAV3_DetectMode(phhalHw_SamAV3_DataParams_t *pDataParams)
Detect UID, AV2/AV3 mode and HostAuth settings.
Data structure for Symmetric Crypto Software layer implementation.
Definition: phCryptoSym.h:435
phStatus_t phbalReg_SetPort(void *pDataParams, uint8_t *pPortName)
Select Port to be used.
phStatus_t phKeyStore_SamAV3_Init(phKeyStore_SamAV3_DataParams_t *pDataParams, uint16_t wSizeOfDataParams, phhalHw_SamAV3_DataParams_t *pHalDataParams)
Initializes the KeyStore component as SAM AV3 component.
Software KeyUsageCounter structure.
Definition: phKeyStore.h:75
#define PHBAL_REG_PCSCWIN_VALUE_SHARE_DIRECT
DIRECT access.
Definition: phbalReg.h:644
phStatus_t phbalReg_Sam_Init(phbalReg_Sam_DataParams_t *pDataParams, uint16_t wSizeOfDataParams, void *pLowerBalDataParams, uint8_t *pAtrBuffer, uint16_t wAtrBufSize, uint8_t *pTxBuffer, uint16_t wTxBufSize, uint8_t *pRxBuffer, uint16_t wRxBufSize)
Initialize the SAM BAL component.
phStatus_t phbalReg_SetConfig(void *pDataParams, uint16_t wConfig, uint16_t wValue)
Set configuration parameter.
#define PHHAL_HW_SAMAV3_OPMODE_NON_X
Non-X operation mode.
Definition: phhalHw.h:418
Data structure for Random Number's Software layer implementation.
Definition: phCryptoRng.h:52
#define PHBAL_REG_PCSCWIN_CONFIG_SHARE
Used Access mode; e.g.
Definition: phbalReg.h:628
phStatus_t phCryptoRng_Seed(void *pDataParams, uint8_t *pSeed, uint8_t bSeedLength)
Seeds the random number generator with the given seed.
phStatus_t phhalHw_SamAV3_Cmd_SAM_AuthenticateHost(phhalHw_SamAV3_DataParams_t *pDataParams, uint8_t bHostMode, uint16_t wRdKeyNo, uint16_t wRdKeyV, uint8_t bSamKeyNo, uint8_t bSamKeyV)
Mutual 3-pass-AV2 or 3-Pass AV3 authentication between Host and SAM.
phStatus_t phbalReg_OpenPort(void *pDataParams)
Open communication port.
phStatus_t phbalReg_PcscWin_Init(phbalReg_PcscWin_DataParams_t *pDataParams, uint16_t wSizeOfDataParams, uint8_t *pAtrBuffer, uint16_t wAtrBufSize)
Initialise the PCSC BAL component.
Sam parameter structure.
Definition: phKeyStore.h:421
#define PHBAL_REG_PCSCWIN_CONFIG_PROTOCOL
Used Protocol; e.g.
Definition: phbalReg.h:627
unsigned char uint8_t
8 bit unsigned integer
Definition: ph_TypeDefs.h:56
phStatus_t phKeyStore_FormatKeyEntry(void *pDataParams, uint16_t wKeyNo, uint16_t wNewKeyType)
Format a key entry to a new KeyType.
SamAV3 HAL parameter structure.
Definition: phhalHw.h:445