[update] 增加STM32智慧宿舍基础代码

This commit is contained in:
solitary
2021-07-27 21:28:13 +08:00
parent 00dbbe55e3
commit 8b2c22efe2
952 changed files with 583792 additions and 0 deletions

View File

@@ -0,0 +1,616 @@
#include "rc522.h"
#include "spi.h"
/**
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: <20>Ӵ<EFBFBD><D3B4><EFBFBD>Flash<73><68>ȡһ<C8A1><D2BB><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: <20><>
* <20><> <20><> ֵ: uint8_t<5F><74><EFBFBD><EFBFBD>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* ˵ <20><><EFBFBD><EFBFBD>This function must be used only if the Start_Read_Sequence
* function has been previously called.
*/
uint8_t SPI_FLASH_ReadByte(void)
{
uint8_t d_read,d_send=Dummy_Byte;
if(HAL_SPI_TransmitReceive(&hspi2,&d_send,&d_read,1,0xFFFFFF)!=HAL_OK)
d_read=Dummy_Byte;
return d_read;
}
/**
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Flash<73><68>ȡд<C8A1><D0B4>һ<EFBFBD><D2BB><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD><EFBFBD>ݲ<EFBFBD><DDB2><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: byte<74><65><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* <20><> <20><> ֵ: uint8_t<5F><74><EFBFBD><EFBFBD><EFBFBD>յ<EFBFBD><D5B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* ˵ <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*/
uint8_t SPI_FLASH_SendByte(uint8_t byte)
{
uint8_t d_read,d_send=byte;
if(HAL_SPI_TransmitReceive(&hspi2,&d_send,&d_read,1,0xFFFFFF)!=HAL_OK)
d_read=Dummy_Byte;
return d_read;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ReadRawRC
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>RC522<32>Ĵ<EFBFBD><C4B4><EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><>ucAddress<73><73><EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD>ַ
* <20><><EFBFBD><EFBFBD> : <20>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD>ĵ<EFBFBD>ǰֵ
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>
*/
uint8_t ReadRawRC ( uint8_t ucAddress )
{
uint8_t ucAddr, ucReturn;
ucAddr = ( ( ucAddress << 1 ) & 0x7E ) | 0x80;
macRC522_CS_Enable() ;
SPI_FLASH_SendByte ( ucAddr );
ucReturn = SPI_FLASH_ReadByte ();
macRC522_CS_Disable();
return ucReturn;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>WriteRawRC
* <20><><EFBFBD><EFBFBD> <20><>дRC522<32>Ĵ<EFBFBD><C4B4><EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><>ucAddress<73><73><EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD>ַ
* ucValue<75><65>д<EFBFBD><D0B4><EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD>ֵ
* <20><><EFBFBD><EFBFBD> : <20><>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>
*/
void WriteRawRC ( uint8_t ucAddress, uint8_t ucValue )
{
uint8_t ucAddr;
ucAddr = ( ucAddress << 1 ) & 0x7E;
macRC522_CS_Enable() ;
SPI_FLASH_SendByte ( ucAddr );
SPI_FLASH_SendByte ( ucValue );
macRC522_CS_Disable();
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>SetBitMask
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>RC522<32>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD>λ
* <20><><EFBFBD><EFBFBD> <20><>ucReg<65><67><EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD>ַ
* ucMask<73><6B><EFBFBD><EFBFBD>λֵ
* <20><><EFBFBD><EFBFBD> : <20><>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>
*/
void SetBitMask ( uint8_t ucReg, uint8_t ucMask )
{
uint8_t ucTemp;
ucTemp = ReadRawRC ( ucReg );
WriteRawRC ( ucReg, ucTemp | ucMask ); // set bit mask
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ClearBitMask
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>RC522<32>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD>λ
* <20><><EFBFBD><EFBFBD> <20><>ucReg<65><67><EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD>ַ
* ucMask<73><6B><EFBFBD><EFBFBD>λֵ
* <20><><EFBFBD><EFBFBD> : <20><>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>
*/
void ClearBitMask ( uint8_t ucReg, uint8_t ucMask )
{
uint8_t ucTemp;
ucTemp = ReadRawRC ( ucReg );
WriteRawRC ( ucReg, ucTemp & ( ~ ucMask) ); // clear bit mask
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdAntennaOn
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> : <20><>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>
*/
void PcdAntennaOn ( void )
{
uint8_t uc;
uc = ReadRawRC ( TxControlReg );
if ( ! ( uc & 0x03 ) )
SetBitMask(TxControlReg, 0x03);
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdAntennaOff
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> : <20><>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>
*/
void PcdAntennaOff ( void )
{
ClearBitMask ( TxControlReg, 0x03 );
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdRese
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>λRC522
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> : <20><>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
void PcdReset ( void )
{
macRC522_Reset_Disable();
HAL_Delay ( 1 );
macRC522_Reset_Enable();
HAL_Delay ( 1 );
macRC522_Reset_Disable();
HAL_Delay ( 1 );
WriteRawRC ( CommandReg, 0x0f );
while ( ReadRawRC ( CommandReg ) & 0x10 );
HAL_Delay ( 1 );
WriteRawRC ( ModeReg, 0x3D ); //<2F><><EFBFBD><EFBFBD>ͺͽ<CDBA><CDBD>ճ<EFBFBD><D5B3><EFBFBD>ģʽ <20><>Mifare<72><65>ͨѶ<CDA8><D1B6>CRC<52><43>ʼֵ0x6363
WriteRawRC ( TReloadRegL, 30 ); //16λ<36><CEBB>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD>λ
WriteRawRC ( TReloadRegH, 0 ); //16λ<36><CEBB>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD>λ
WriteRawRC ( TModeReg, 0x8D ); //<2F><><EFBFBD><EFBFBD><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
WriteRawRC ( TPrescalerReg, 0x3E ); //<2F><><EFBFBD>ö<EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD>Ƶϵ<C6B5><CFB5>
WriteRawRC ( TxAutoReg, 0x40 ); //<2F><><EFBFBD>Ʒ<EFBFBD><C6B7><EFBFBD><EFBFBD>ź<EFBFBD>Ϊ100%ASK
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>M500PcdConfigISOType
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>RC522<32>Ĺ<EFBFBD><C4B9><EFBFBD><EFBFBD><EFBFBD>ʽ
* <20><><EFBFBD><EFBFBD> <20><>ucType<70><65><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
* <20><><EFBFBD><EFBFBD> : <20><>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
void M500PcdConfigISOType ( uint8_t ucType )
{
if ( ucType == 'A') //ISO14443_A
{
ClearBitMask ( Status2Reg, 0x08 );
WriteRawRC ( ModeReg, 0x3D );//3F
WriteRawRC ( RxSelReg, 0x86 );//84
WriteRawRC( RFCfgReg, 0x7F ); //4F
WriteRawRC( TReloadRegL, 30 );//tmoLength);// TReloadVal = 'h6a =tmoLength(dec)
WriteRawRC ( TReloadRegH, 0 );
WriteRawRC ( TModeReg, 0x8D );
WriteRawRC ( TPrescalerReg, 0x3E );
HAL_Delay ( 2 );
PcdAntennaOn ();//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
}
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdComMF522
* <20><><EFBFBD><EFBFBD> <20><>ͨ<EFBFBD><CDA8>RC522<32><32>ISO14443<34><33>ͨѶ
* <20><><EFBFBD><EFBFBD> <20><>ucCommand<6E><64>RC522<32><32><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* pInData<74><61>ͨ<EFBFBD><CDA8>RC522<32><32><EFBFBD>͵<EFBFBD><CDB5><EFBFBD>Ƭ<EFBFBD><C6AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* ucInLenByte<74><65><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݵ<EFBFBD><DDB5>ֽڳ<D6BD><DAB3><EFBFBD>
* pOutData<74><61><EFBFBD><EFBFBD><EFBFBD>յ<EFBFBD><D5B5>Ŀ<EFBFBD>Ƭ<EFBFBD><C6AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* pOutLenBit<69><74><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݵ<EFBFBD>λ<EFBFBD><CEBB><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> : ״ֵ̬
* = MI_OK<4F><4B><EFBFBD>ɹ<EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>
*/
char PcdComMF522 ( uint8_t ucCommand, uint8_t * pInData, uint8_t ucInLenByte, uint8_t * pOutData, uint32_t * pOutLenBit )
{
char cStatus = MI_ERR;
uint8_t ucIrqEn = 0x00;
uint8_t ucWaitFor = 0x00;
uint8_t ucLastBits;
uint8_t ucN;
uint32_t ul;
switch ( ucCommand )
{
case PCD_AUTHENT: //Mifare<72><65>֤
ucIrqEn = 0x12; //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ж<EFBFBD><D0B6><EFBFBD><EFBFBD><EFBFBD>ErrIEn <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ж<EFBFBD>IdleIEn
ucWaitFor = 0x10; //<2F><>֤Ѱ<D6A4><D1B0><EFBFBD>ȴ<EFBFBD>ʱ<EFBFBD><CAB1> <20><>ѯ<EFBFBD><D1AF><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6>־λ
break;
case PCD_TRANSCEIVE: //<2F><><EFBFBD>շ<EFBFBD><D5B7><EFBFBD> <20><><EFBFBD>ͽ<EFBFBD><CDBD><EFBFBD>
ucIrqEn = 0x77; //<2F><><EFBFBD><EFBFBD>TxIEn RxIEn IdleIEn LoAlertIEn ErrIEn TimerIEn
ucWaitFor = 0x30; //Ѱ<><D1B0><EFBFBD>ȴ<EFBFBD>ʱ<EFBFBD><CAB1> <20><>ѯ<EFBFBD><D1AF><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6>־λ<D6BE><CEBB> <20><><EFBFBD><EFBFBD><EFBFBD>жϱ<D0B6>־λ
break;
default:
break;
}
WriteRawRC ( ComIEnReg, ucIrqEn | 0x80 ); //IRqInv<6E><76>λ<EFBFBD>ܽ<EFBFBD>IRQ<52><51>Status1Reg<65><67>IRqλ<71><CEBB>ֵ<EFBFBD>
ClearBitMask ( ComIrqReg, 0x80 ); //Set1<74><31>λ<EFBFBD><CEBB><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1>CommIRqReg<65><67><EFBFBD><EFBFBD><EFBFBD><EFBFBD>λ<EFBFBD><CEBB><EFBFBD><EFBFBD>
WriteRawRC ( CommandReg, PCD_IDLE ); //д<><D0B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
SetBitMask ( FIFOLevelReg, 0x80 ); //<2F><>λFlushBuffer<65><72><EFBFBD><EFBFBD><EFBFBD>ڲ<EFBFBD>FIFO<46>Ķ<EFBFBD><C4B6><EFBFBD>дָ<D0B4><D6B8><EFBFBD>Լ<EFBFBD>ErrReg<65><67>BufferOvfl<66><6C>־λ<D6BE><CEBB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
for ( ul = 0; ul < ucInLenByte; ul ++ )
WriteRawRC ( FIFODataReg, pInData [ ul ] ); //д<><D0B4><EFBFBD>ݽ<EFBFBD>FIFOdata
WriteRawRC ( CommandReg, ucCommand ); //д<><D0B4><EFBFBD><EFBFBD>
if ( ucCommand == PCD_TRANSCEIVE )
SetBitMask(BitFramingReg,0x80); //StartSend<6E><64>λ<EFBFBD><CEBB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݷ<EFBFBD><DDB7><EFBFBD> <20><>λ<EFBFBD><CEBB><EFBFBD>շ<EFBFBD><D5B7><EFBFBD><EFBFBD><EFBFBD>ʹ<EFBFBD><CAB9>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD>Ч
ul = 1000;//<2F><><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1>Ƶ<EFBFBD>ʵ<EFBFBD><CAB5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>M1<4D><31><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȴ<EFBFBD>ʱ<EFBFBD><CAB1>25ms
do //<2F><>֤ <20><>Ѱ<EFBFBD><D1B0><EFBFBD>ȴ<EFBFBD>ʱ<EFBFBD><CAB1>
{
ucN = ReadRawRC ( ComIrqReg ); //<2F><>ѯ<EFBFBD>¼<EFBFBD><C2BC>ж<EFBFBD>
ul --;
} while ( ( ul != 0 ) && ( ! ( ucN & 0x01 ) ) && ( ! ( ucN & ucWaitFor ) ) ); //<2F>˳<EFBFBD><CBB3><EFBFBD><EFBFBD><EFBFBD>i=0,<2C><>ʱ<EFBFBD><CAB1><EFBFBD>жϣ<D0B6><CFA3><EFBFBD>д<EFBFBD><D0B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
ClearBitMask ( BitFramingReg, 0x80 ); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>StartSendλ
if ( ul != 0 )
{
if ( ! ( ReadRawRC ( ErrorReg ) & 0x1B ) ) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>־<EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD>BufferOfI CollErr ParityErr ProtocolErr
{
cStatus = MI_OK;
if ( ucN & ucIrqEn & 0x01 ) //<2F>Ƿ<EFBFBD><C7B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD>ж<EFBFBD>
cStatus = MI_NOTAGERR;
if ( ucCommand == PCD_TRANSCEIVE )
{
ucN = ReadRawRC ( FIFOLevelReg ); //<2F><>FIFO<46>б<EFBFBD><D0B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD>
ucLastBits = ReadRawRC ( ControlReg ) & 0x07; //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>յ<EFBFBD><D5B5><EFBFBD><EFBFBD>ֽڵ<D6BD><DAB5><EFBFBD>Чλ<D0A7><CEBB>
if ( ucLastBits )
* pOutLenBit = ( ucN - 1 ) * 8 + ucLastBits; //N<><4E><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD><EFBFBD><EFBFBD>ȥ1<C8A5><31><EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD>ֽڣ<D6BD>+<2B><><EFBFBD><EFBFBD>һλ<D2BB><CEBB>λ<EFBFBD><CEBB> <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>λ<EFBFBD><CEBB>
else
* pOutLenBit = ucN * 8; //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>յ<EFBFBD><D5B5><EFBFBD><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֽ<EFBFBD><D6BD><EFBFBD>Ч
if ( ucN == 0 )
ucN = 1;
if ( ucN > MAXRLEN )
ucN = MAXRLEN;
for ( ul = 0; ul < ucN; ul ++ )
pOutData [ ul ] = ReadRawRC ( FIFODataReg );
}
}else
{
cStatus = MI_ERR;
}
}
SetBitMask ( ControlReg, 0x80 ); // stop timer now
WriteRawRC ( CommandReg, PCD_IDLE );
return cStatus;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdRequest
* <20><><EFBFBD><EFBFBD> <20><>Ѱ<EFBFBD><D1B0>
* <20><><EFBFBD><EFBFBD> <20><>ucReq_code<64><65>Ѱ<EFBFBD><D1B0><EFBFBD><EFBFBD>ʽ
* = 0x52<35><32>Ѱ<EFBFBD><D1B0>Ӧ<EFBFBD><D3A6><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>з<EFBFBD><D0B7><EFBFBD>14443A<33><41>׼<EFBFBD>Ŀ<EFBFBD>
* = 0x26<32><36>Ѱδ<D1B0><CEB4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>״̬<D7B4>Ŀ<EFBFBD>
* pTagType<70><65><EFBFBD><EFBFBD>Ƭ<EFBFBD><C6AC><EFBFBD>ʹ<EFBFBD><CDB4><EFBFBD>
* = 0x4400<30><30>Mifare_UltraLight
* = 0x0400<30><30>Mifare_One(S50)
* = 0x0200<30><30>Mifare_One(S70)
* = 0x0800<30><30>Mifare_Pro(X))
* = 0x4403<30><33>Mifare_DESFire
* <20><><EFBFBD><EFBFBD> : ״ֵ̬
* = MI_OK<4F><4B><EFBFBD>ɹ<EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
char PcdRequest ( uint8_t ucReq_code, uint8_t * pTagType )
{
char cStatus;
uint8_t ucComMF522Buf [ MAXRLEN ];
uint32_t ulLen;
ClearBitMask ( Status2Reg, 0x08 ); //<2F><><EFBFBD><EFBFBD>ָʾMIFARECyptol<6F><6C>Ԫ<EFBFBD><D4AA>ͨ<EFBFBD>Լ<EFBFBD><D4BC><EFBFBD><EFBFBD>п<EFBFBD><D0BF><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD>ű<EFBFBD><C5B1><EFBFBD><EFBFBD>ܵ<EFBFBD><DCB5><EFBFBD><EFBFBD><EFBFBD>
WriteRawRC ( BitFramingReg, 0x07 ); // <09><><EFBFBD>͵<EFBFBD><CDB5><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD>ֽڵ<D6BD> <20><>λ
SetBitMask ( TxControlReg, 0x03 ); //TX1,TX2<58>ܽŵ<DCBD><C5B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>źŴ<C5BA><C5B4>ݾ<EFBFBD><DDBE><EFBFBD><EFBFBD>͵<EFBFBD><CDB5>Ƶ<EFBFBD>13.56<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ز<EFBFBD><EFBFBD>ź<EFBFBD>
ucComMF522Buf [ 0 ] = ucReq_code; //<2F><><EFBFBD><EFBFBD> <20><>Ƭ<EFBFBD><C6AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
cStatus = PcdComMF522 ( PCD_TRANSCEIVE, ucComMF522Buf, 1, ucComMF522Buf, & ulLen ); //Ѱ<><D1B0>
if ( ( cStatus == MI_OK ) && ( ulLen == 0x10 ) ) //Ѱ<><D1B0><EFBFBD>ɹ<EFBFBD><C9B9><EFBFBD><EFBFBD>ؿ<EFBFBD><D8BF><EFBFBD><EFBFBD><EFBFBD>
{
* pTagType = ucComMF522Buf [ 0 ];
* ( pTagType + 1 ) = ucComMF522Buf [ 1 ];
}
else
cStatus = MI_ERR;
return cStatus;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdAnticoll
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ײ
* <20><><EFBFBD><EFBFBD> <20><>pSnr<6E><72><EFBFBD><EFBFBD>Ƭ<EFBFBD><C6AC><EFBFBD>кţ<D0BA>4<EFBFBD>ֽ<EFBFBD>
* <20><><EFBFBD><EFBFBD> : ״ֵ̬
* = MI_OK<4F><4B><EFBFBD>ɹ<EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
char PcdAnticoll ( uint8_t * pSnr )
{
char cStatus;
uint8_t uc, ucSnr_check = 0;
uint8_t ucComMF522Buf [ MAXRLEN ];
uint32_t ulLen;
ClearBitMask ( Status2Reg, 0x08 ); //<2F><>MFCryptol Onλ ֻ<>гɹ<D0B3>ִ<EFBFBD><D6B4>MFAuthent<6E><74><EFBFBD><EFBFBD><EFBFBD>󣬸<EFBFBD>λ<EFBFBD><CEBB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>λ
WriteRawRC ( BitFramingReg, 0x00); //<2F><><EFBFBD><EFBFBD><EFBFBD>Ĵ<EFBFBD><C4B4><EFBFBD> ֹͣ<CDA3>շ<EFBFBD>
ClearBitMask ( CollReg, 0x80 ); //<2F><>ValuesAfterColl<6C><6C><EFBFBD>н<EFBFBD><D0BD>յ<EFBFBD>λ<EFBFBD>ڳ<EFBFBD>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
ucComMF522Buf [ 0 ] = 0x93; //<2F><>Ƭ<EFBFBD><C6AC><EFBFBD><EFBFBD>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD>
ucComMF522Buf [ 1 ] = 0x20;
cStatus = PcdComMF522 ( PCD_TRANSCEIVE, ucComMF522Buf, 2, ucComMF522Buf, & ulLen);//<2F>뿨Ƭͨ<C6AC><CDA8>
if ( cStatus == MI_OK) //ͨ<>ųɹ<C5B3>
{
for ( uc = 0; uc < 4; uc ++ )
{
* ( pSnr + uc ) = ucComMF522Buf [ uc ]; //<2F><><EFBFBD><EFBFBD>UID
ucSnr_check ^= ucComMF522Buf [ uc ];
}
if ( ucSnr_check != ucComMF522Buf [ uc ] )
{
cStatus = MI_ERR;
}
}
SetBitMask ( CollReg, 0x80 );
return cStatus;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>CalulateCRC
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>RC522<32><32><EFBFBD><EFBFBD>CRC16
* <20><><EFBFBD><EFBFBD> <20><>pIndata<74><61><EFBFBD><EFBFBD><EFBFBD><EFBFBD>CRC16<31><36><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* ucLen<65><6E><EFBFBD><EFBFBD><EFBFBD><EFBFBD>CRC16<31><36><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֽڳ<D6BD><DAB3><EFBFBD>
* pOutData<74><61><EFBFBD><EFBFBD><EFBFBD>ż<EFBFBD><C5BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ŵ<EFBFBD><C5B5>׵<EFBFBD>ַ
* <20><><EFBFBD><EFBFBD> : <20><>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>
*/
void CalulateCRC ( uint8_t * pIndata, uint8_t ucLen, uint8_t * pOutData )
{
uint8_t uc, ucN;
ClearBitMask(DivIrqReg,0x04);
WriteRawRC(CommandReg,PCD_IDLE);
SetBitMask(FIFOLevelReg,0x80);
for ( uc = 0; uc < ucLen; uc ++)
WriteRawRC ( FIFODataReg, * ( pIndata + uc ) );
WriteRawRC ( CommandReg, PCD_CALCCRC );
uc = 0xFF;
do
{
ucN = ReadRawRC ( DivIrqReg );
uc --;
} while ( ( uc != 0 ) && ! ( ucN & 0x04 ) );
pOutData [ 0 ] = ReadRawRC ( CRCResultRegL );
pOutData [ 1 ] = ReadRawRC ( CRCResultRegM );
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdSelect
* <20><><EFBFBD><EFBFBD> <20><>ѡ<EFBFBD><D1A1><EFBFBD><EFBFBD>Ƭ
* <20><><EFBFBD><EFBFBD> <20><>pSnr<6E><72><EFBFBD><EFBFBD>Ƭ<EFBFBD><C6AC><EFBFBD>кţ<D0BA>4<EFBFBD>ֽ<EFBFBD>
* <20><><EFBFBD><EFBFBD> : ״ֵ̬
* = MI_OK<4F><4B><EFBFBD>ɹ<EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
char PcdSelect ( uint8_t * pSnr )
{
char ucN;
uint8_t uc;
uint8_t ucComMF522Buf [ MAXRLEN ];
uint32_t ulLen;
ucComMF522Buf [ 0 ] = PICC_ANTICOLL1;
ucComMF522Buf [ 1 ] = 0x70;
ucComMF522Buf [ 6 ] = 0;
for ( uc = 0; uc < 4; uc ++ )
{
ucComMF522Buf [ uc + 2 ] = * ( pSnr + uc );
ucComMF522Buf [ 6 ] ^= * ( pSnr + uc );
}
CalulateCRC ( ucComMF522Buf, 7, & ucComMF522Buf [ 7 ] );
ClearBitMask ( Status2Reg, 0x08 );
ucN = PcdComMF522 ( PCD_TRANSCEIVE, ucComMF522Buf, 9, ucComMF522Buf, & ulLen );
if ( ( ucN == MI_OK ) && ( ulLen == 0x18 ) )
ucN = MI_OK;
else
ucN = MI_ERR;
return ucN;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdAuthState
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>֤<EFBFBD><D6A4>Ƭ<EFBFBD><C6AC><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><>ucAuth_mode<64><65><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>֤ģʽ
* = 0x60<36><30><EFBFBD><EFBFBD>֤A<D6A4><41>Կ
* = 0x61<36><31><EFBFBD><EFBFBD>֤B<D6A4><42>Կ
* uint8_t ucAddr<64><72><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ַ
* pKey<65><79><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* pSnr<6E><72><EFBFBD><EFBFBD>Ƭ<EFBFBD><C6AC><EFBFBD>кţ<D0BA>4<EFBFBD>ֽ<EFBFBD>
* <20><><EFBFBD><EFBFBD> : ״ֵ̬
* = MI_OK<4F><4B><EFBFBD>ɹ<EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
char PcdAuthState ( uint8_t ucAuth_mode, uint8_t ucAddr, uint8_t * pKey, uint8_t * pSnr )
{
char cStatus;
uint8_t uc, ucComMF522Buf [ MAXRLEN ];
uint32_t ulLen;
ucComMF522Buf [ 0 ] = ucAuth_mode;
ucComMF522Buf [ 1 ] = ucAddr;
for ( uc = 0; uc < 6; uc ++ )
ucComMF522Buf [ uc + 2 ] = * ( pKey + uc );
for ( uc = 0; uc < 6; uc ++ )
ucComMF522Buf [ uc + 8 ] = * ( pSnr + uc );
cStatus = PcdComMF522 ( PCD_AUTHENT, ucComMF522Buf, 12, ucComMF522Buf, & ulLen );
if ( ( cStatus != MI_OK ) || ( ! ( ReadRawRC ( Status2Reg ) & 0x08 ) ) )
cStatus = MI_ERR;
return cStatus;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdWrite
* <20><><EFBFBD><EFBFBD> <20><>д<EFBFBD><D0B4><EFBFBD>ݵ<EFBFBD>M1<4D><31>һ<EFBFBD><D2BB>
* <20><><EFBFBD><EFBFBD> <20><>uint8_t ucAddr<64><72><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ַ
* pData<74><61>д<EFBFBD><D0B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݣ<EFBFBD>16<31>ֽ<EFBFBD>
* <20><><EFBFBD><EFBFBD> : ״ֵ̬
* = MI_OK<4F><4B><EFBFBD>ɹ<EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
char PcdWrite ( uint8_t ucAddr, uint8_t * pData )
{
char cStatus;
uint8_t uc, ucComMF522Buf [ MAXRLEN ];
uint32_t ulLen;
ucComMF522Buf [ 0 ] = PICC_WRITE;
ucComMF522Buf [ 1 ] = ucAddr;
CalulateCRC ( ucComMF522Buf, 2, & ucComMF522Buf [ 2 ] );
cStatus = PcdComMF522 ( PCD_TRANSCEIVE, ucComMF522Buf, 4, ucComMF522Buf, & ulLen );
if ( ( cStatus != MI_OK ) || ( ulLen != 4 ) || ( ( ucComMF522Buf [ 0 ] & 0x0F ) != 0x0A ) )
cStatus = MI_ERR;
if ( cStatus == MI_OK )
{
//memcpy(ucComMF522Buf, pData, 16);
for ( uc = 0; uc < 16; uc ++ )
ucComMF522Buf [ uc ] = * ( pData + uc );
CalulateCRC ( ucComMF522Buf, 16, & ucComMF522Buf [ 16 ] );
cStatus = PcdComMF522 ( PCD_TRANSCEIVE, ucComMF522Buf, 18, ucComMF522Buf, & ulLen );
if ( ( cStatus != MI_OK ) || ( ulLen != 4 ) || ( ( ucComMF522Buf [ 0 ] & 0x0F ) != 0x0A ) )
cStatus = MI_ERR;
}
return cStatus;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdRead
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>ȡM1<4D><31>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><>uint8_t ucAddr<64><72><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ַ
* pData<74><61><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݣ<EFBFBD>16<31>ֽ<EFBFBD>
* <20><><EFBFBD><EFBFBD> : ״ֵ̬
* = MI_OK<4F><4B><EFBFBD>ɹ<EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
char PcdRead ( uint8_t ucAddr, uint8_t * pData )
{
char cStatus;
uint8_t uc, ucComMF522Buf [ MAXRLEN ];
uint32_t ulLen;
ucComMF522Buf [ 0 ] = PICC_READ;
ucComMF522Buf [ 1 ] = ucAddr;
CalulateCRC ( ucComMF522Buf, 2, & ucComMF522Buf [ 2 ] );
cStatus = PcdComMF522 ( PCD_TRANSCEIVE, ucComMF522Buf, 4, ucComMF522Buf, & ulLen );
if ( ( cStatus == MI_OK ) && ( ulLen == 0x90 ) )
{
for ( uc = 0; uc < 16; uc ++ )
* ( pData + uc ) = ucComMF522Buf [ uc ];
}else
cStatus = MI_ERR;
return cStatus;
}
/*
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PcdHalt
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ƭ<EEBFA8><C6AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>״̬
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
* <20><><EFBFBD><EFBFBD> : ״ֵ̬
* = MI_OK<4F><4B><EFBFBD>ɹ<EFBFBD>
* <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ⲿ<EFBFBD><E2B2BF><EFBFBD><EFBFBD>
*/
char PcdHalt( void )
{
uint8_t ucComMF522Buf [ MAXRLEN ];
uint32_t ulLen;
ucComMF522Buf [ 0 ] = PICC_HALT;
ucComMF522Buf [ 1 ] = 0;
CalulateCRC ( ucComMF522Buf, 2, & ucComMF522Buf [ 2 ] );
PcdComMF522 ( PCD_TRANSCEIVE, ucComMF522Buf, 4, ucComMF522Buf, & ulLen );
return MI_OK;
}
void IC_CMT ( uint8_t * UID, uint8_t * KEY, uint8_t RW, uint8_t * Dat )
{
uint8_t ucArray_ID [ 4 ] = { 0 };//<2F>Ⱥ<EFBFBD><C8BA><EFBFBD><EFBFBD><EFBFBD>IC<49><43><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͺ<EFBFBD>UID(IC<49><43><EFBFBD><EFBFBD><EFBFBD>к<EFBFBD>)
PcdRequest ( 0x52, ucArray_ID );//Ѱ<><D1B0>
PcdAnticoll ( ucArray_ID );//<2F><><EFBFBD><EFBFBD>ײ
PcdSelect ( UID );//ѡ<><D1A1><EFBFBD><EFBFBD>
PcdAuthState ( 0x60, 0x10, KEY, UID );//У<><D0A3>
if ( RW )//<2F><>дѡ<D0B4><D1A1><EFBFBD><EFBFBD>1<EFBFBD>Ƕ<EFBFBD><C7B6><EFBFBD>0<EFBFBD><30>д
PcdRead ( 0x10, Dat );
else
PcdWrite ( 0x10, Dat );
PcdHalt ();
}

View File

@@ -0,0 +1,175 @@
/****************************************Copyright (c)****************************************************
**
** File name: light.h
** Created by: XiaoYi
** Created date: 2020-10-16
** Version: v1.0
** Descriptions: The original
** Link address: https://blog.csdn.net/weixin_45006076
**
*********************************************************************************************************/
#ifndef __RC522_H__
#define __RC522_H__
#include "main.h"
//MF522<32><32><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/////////////////////////////////////////////////////////////////////
#define PCD_IDLE 0x00 //ȡ<><C8A1><EFBFBD><EFBFBD>ǰ<EFBFBD><C7B0><EFBFBD><EFBFBD>
#define PCD_AUTHENT 0x0E //<2F><>֤<EFBFBD><D6A4>Կ
#define PCD_RECEIVE 0x08 //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
#define PCD_TRANSMIT 0x04 //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
#define PCD_TRANSCEIVE 0x0C //<2F><><EFBFBD>Ͳ<EFBFBD><CDB2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
#define PCD_RESETPHASE 0x0F //<2F><>λ
#define PCD_CALCCRC 0x03 //CRC<52><43><EFBFBD><EFBFBD>
/////////////////////////////////////////////////////////////////////
//Mifare_One<6E><65>Ƭ<EFBFBD><C6AC><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/////////////////////////////////////////////////////////////////////
#define PICC_REQIDL 0x26 //Ѱ<><D1B0><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>δ<EFBFBD><CEB4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>״̬
#define PICC_REQALL 0x52 //Ѱ<><D1B0><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȫ<EFBFBD><C8AB><EFBFBD><EFBFBD>
#define PICC_ANTICOLL1 0x93 //<2F><><EFBFBD><EFBFBD>ײ
#define PICC_ANTICOLL2 0x95 //<2F><><EFBFBD><EFBFBD>ײ
#define PICC_AUTHENT1A 0x60 //<2F><>֤A<D6A4><41>Կ
#define PICC_AUTHENT1B 0x61 //<2F><>֤B<D6A4><42>Կ
#define PICC_READ 0x30 //<2F><><EFBFBD><EFBFBD>
#define PICC_WRITE 0xA0 //д<><D0B4>
#define PICC_DECREMENT 0xC0 //<2F>ۿ<EFBFBD>
#define PICC_INCREMENT 0xC1 //<2F><>ֵ
#define PICC_RESTORE 0xC2 //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݵ<EFBFBD><DDB5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
#define PICC_TRANSFER 0xB0 //<2F><><EFBFBD><EFBFBD><E6BBBA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
#define PICC_HALT 0x50 //<2F><><EFBFBD><EFBFBD>
/////////////////////////////////////////////////////////////////////
//MF522 FIFO<46><4F><EFBFBD>ȶ<EFBFBD><C8B6><EFBFBD>
/////////////////////////////////////////////////////////////////////
#define DEF_FIFO_LENGTH 64 //FIFO size=64byte
#define MAXRLEN 18
/////////////////////////////////////////////////////////////////////
//MF522<32>Ĵ<EFBFBD><C4B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/////////////////////////////////////////////////////////////////////
// PAGE 0
#define RFU00 0x00
#define CommandReg 0x01
#define ComIEnReg 0x02
#define DivlEnReg 0x03
#define ComIrqReg 0x04
#define DivIrqReg 0x05
#define ErrorReg 0x06
#define Status1Reg 0x07
#define Status2Reg 0x08
#define FIFODataReg 0x09
#define FIFOLevelReg 0x0A
#define WaterLevelReg 0x0B
#define ControlReg 0x0C
#define BitFramingReg 0x0D
#define CollReg 0x0E
#define RFU0F 0x0F
// PAGE 1
#define RFU10 0x10
#define ModeReg 0x11
#define TxModeReg 0x12
#define RxModeReg 0x13
#define TxControlReg 0x14
#define TxAutoReg 0x15
#define TxSelReg 0x16
#define RxSelReg 0x17
#define RxThresholdReg 0x18
#define DemodReg 0x19
#define RFU1A 0x1A
#define RFU1B 0x1B
#define MifareReg 0x1C
#define RFU1D 0x1D
#define RFU1E 0x1E
#define SerialSpeedReg 0x1F
// PAGE 2
#define RFU20 0x20
#define CRCResultRegM 0x21
#define CRCResultRegL 0x22
#define RFU23 0x23
#define ModWidthReg 0x24
#define RFU25 0x25
#define RFCfgReg 0x26
#define GsNReg 0x27
#define CWGsCfgReg 0x28
#define ModGsCfgReg 0x29
#define TModeReg 0x2A
#define TPrescalerReg 0x2B
#define TReloadRegH 0x2C
#define TReloadRegL 0x2D
#define TCounterValueRegH 0x2E
#define TCounterValueRegL 0x2F
// PAGE 3
#define RFU30 0x30
#define TestSel1Reg 0x31
#define TestSel2Reg 0x32
#define TestPinEnReg 0x33
#define TestPinValueReg 0x34
#define TestBusReg 0x35
#define AutoTestReg 0x36
#define VersionReg 0x37
#define AnalogTestReg 0x38
#define TestDAC1Reg 0x39
#define TestDAC2Reg 0x3A
#define TestADCReg 0x3B
#define RFU3C 0x3C
#define RFU3D 0x3D
#define RFU3E 0x3E
#define RFU3F 0x3F
/////////////////////////////////////////////////////////////////////
//<2F><>MF522ͨѶʱ<D1B6><CAB1><EFBFBD>صĴ<D8B5><C4B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/////////////////////////////////////////////////////////////////////
#define MI_OK 0x26
#define MI_NOTAGERR 0xcc
#define MI_ERR 0xbb
/************************<2A>˿ں궨<DABA><EAB6A8>**********************************/
#define macRC522_GPIO_CS_PORT GPIOB
#define macRC522_GPIO_CS_PIN GPIO_PIN_12
#define macRC522_GPIO_RST_PORT GPIOB
#define macRC522_GPIO_RST_PIN GPIO_PIN_7
#define macRC522_GPIO_SCK_PORT GPIOB
#define macRC522_GPIO_SCK_PIN GPIO_PIN_13
#define macRC522_GPIO_MOSI_PORT GPIOB
#define macRC522_GPIO_MOSI_PIN GPIO_PIN_15
#define macRC522_GPIO_MISO_PORT GPIOB
#define macRC522_GPIO_MISO_PIN GPIO_PIN_14
/*********************************** RC522 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EAB6A8>*********************************************/
#define macRC522_CS_Enable() HAL_GPIO_WritePin ( macRC522_GPIO_CS_PORT, macRC522_GPIO_CS_PIN ,GPIO_PIN_RESET)
#define macRC522_CS_Disable() HAL_GPIO_WritePin ( macRC522_GPIO_CS_PORT, macRC522_GPIO_CS_PIN ,GPIO_PIN_SET)
#define macRC522_Reset_Enable() HAL_GPIO_WritePin( macRC522_GPIO_RST_PORT, macRC522_GPIO_RST_PIN,GPIO_PIN_RESET )
#define macRC522_Reset_Disable() HAL_GPIO_WritePin ( macRC522_GPIO_RST_PORT, macRC522_GPIO_RST_PIN,GPIO_PIN_SET)
#define macRC522_SCK_0() HAL_GPIO_WritePin( macRC522_GPIO_SCK_PORT, macRC522_GPIO_SCK_PIN,GPIO_PIN_RESET )
#define macRC522_SCK_1() HAL_GPIO_WritePin ( macRC522_GPIO_SCK_PORT, macRC522_GPIO_SCK_PIN,GPIO_PIN_SET )
#define macRC522_MOSI_0() HAL_GPIO_WritePin( macRC522_GPIO_MOSI_PORT, macRC522_GPIO_MOSI_PIN,GPIO_PIN_RESET )
#define macRC522_MOSI_1() HAL_GPIO_WritePin ( macRC522_GPIO_MOSI_PORT, macRC522_GPIO_MOSI_PIN,GPIO_PIN_SET )
#define macRC522_MISO_GET() HAL_GPIO_ReadPin ( macRC522_GPIO_MISO_PORT, macRC522_GPIO_MISO_PIN )
#define macRC522_DELAY() HAL_Delay(20)
#define Dummy_Byte 0xFF
void PcdReset ( void ); //<2F><>λ
void M500PcdConfigISOType ( uint8_t type ); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽ
char PcdRequest ( uint8_t req_code, uint8_t * pTagType ); //Ѱ<><D1B0>
char PcdAnticoll ( uint8_t * pSnr); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
char PcdAuthState ( uint8_t ucAuth_mode, uint8_t ucAddr, uint8_t * pKey, uint8_t * pSnr );//<2F><>֤<EFBFBD><D6A4>Ƭ<EFBFBD><C6AC><EFBFBD><EFBFBD>
char PcdRead ( uint8_t ucAddr, uint8_t * pData ); //<2F><><EFBFBD><EFBFBD>
char PcdSelect ( uint8_t * pSnr ); //ѡ<><D1A1>
#endif