RC522 RFID Uygulaması
Merhaba arkadaşlar, bu yazımızda Trudyo Geliştirme Kartı ile RC522 RFID Kiti’nin kullanımından bahsedeceğiz. Ayrıca uygulamamızda 2×16 Karakter LCD – LCD I2C Seri Arayüz Modülü çifti ile birlikte Buzzer Kartı ve RC522 RFID Modülü için 78L33 3.3V Voltaj Regülatörü kullanacağız. Uygulamaya ait gerekli malzeme ve kütüphane dosyalarını sizin için derlediğimiz bu yazımız öncelikle RC522 RFID Modülü hakkında kısa bir bilgi edinerek başlayabiliriz.
RC522 RFID Modülü Hakkında Kısa Bir Bilgi
RC522 RFID Kit, 13.56MHz frekansı değerinde çalışan RFID cihazlardan veri okuma ve yazma işlemi yapabilen, düşük güç tüketimli bir geliştirme kitidir. Bir RFID okuyucu modülü, bir RFID kart ve bir RFID anahtarlık içermektedir. Okuyucu Modül, RC522 işlemcisine dayanmaktadır. Dahili bir antene sahip olup, SPI haberleşme protokolü ile iletişim sağlamaktadır. 13.56MHz frekansında çalışan RFID kart ve anahtarlıkları okuyabilmektedir. Dahili anteni, metalik olmayan kapaklar veya muhafazalar olsa bile 10cm’ye kadar mesafelerde iletişim kurulmasına olanak tanımaktadır.
Çeşitli mikrodenetleyici platformları ile birlikte kullanılabilen RC522 RFID Kit, 10Mbit/s değerine kadar haberleşme hızı sağlayabilmektedir. RFID üzerinde farklı şifreleme türlerini desteklemektedir. Desteklediği kart türleri; mifare1 S50, mifare1 S70 mifare ultralight, mifare pro ve mifare desfire’dir.
Not: Modül, 125kHz frekans değerinde çalışan RFID kartları desteklememektedir. Yalnızca 13.56MHz frekans değerinde çalışan kartları desteklemektedir. NFC modülleri bu frekansta çalıştığı için NFC kartları ile birlikte kullanılabilir.
Pin No | İsim | Açıklama |
1 | SDA | SPI SS (Slave Select) Bağlantı Pini |
2 | SCK | SPI Seri Clock Bağlantı Pini |
3 | MOSI | SPI MOSI Bağlantı Pini |
4 | MISO | SPI MISO Bağlantı Pini |
5 | RQ | Kesme Pini (Modül bir RFID cihaz algıladığında kesme oluşturur.) |
6 | GND | GND Bağlantı Pini |
7 | RST | Sıfırlama Bağlantı Pini |
8 | 3.3V | +3.3V Bağlantı Pini |
Özellik | Değer |
Besleme Gerilimi | 3.3V |
Çalışma Frekansı | 13.56MHz |
Çalışma Akımı | 13-26mA |
Uyku Akımı | <80uA |
Haberleşme Protokolü | SPI |
Veri Aktarım Hızı (Max) | 10Mbit/s |
Mikrodenetleyici | RC522 |
Boyutlar | 39x60x3mm |
RC522, LCD ve Trudyo Geliştirme Kartı Bağlantısı
Yukarıdaki görsellerde açıkladığı üzere RC522 RFID Modülü A portuna bağlanmıştır. Ayrıca Buzzer Kartı D0 pinine ve I2C Seri Arayüz Modüllü 2×16 LCD Ekran, Trudyo Geliştirme Kartı‘nın B0 ve B1 pinlerine bağlanmıştır. Modül üzerinde bulunan 10K Ohm değerinde bir Potansiyometre ile LCD ekranın kontrast ayarı yapılabilmektedir.
Bu Uygulamada Kullanılan Malzemeler
Buzzer Kartı
Başlamadan Önce
2×16 LCD Ekran Kullanımı
2×16 karakter LCD ekran kullanımı hakkında ayrıntılı bilgi ve örnek uygulamayı incelemek için daha önce yayınlanan “2×16 LCD Ekran Kullanımı” yazımızı okuyabilirsiniz.
Trudyo Konfigürasyon Ayarları
Trudyo Geliştirme Kartı ile programlama yapabilmek için kartınızın konfigürasyon ayarlarını yapmanız gerekmektedir. Gerekli konfigürasyon ayarlarını yapmak için “Trudyo Konfigürasyon Ayarları” yazımızı okuyabilirsiniz.
RC522 RFID Uygulama Kodları
// Connections
sbit LED at LATA4_bit; // Dahili LED RA4 Pinine Bagli
sbit BUZZER at LATD0_bit; // Buzzer RD0 Pinine Bagli
// Software SPI module connections*/
sbit MFRC522_CS at RA0_bit; // SDA
sbit SoftSPI_CLK at RA1_bit; // SCK
sbit SoftSPI_SDO at RA2_bit; // MOSI
sbit SoftSPI_SDI at RA3_Bit; // MISO
sbit MFRC522_RST at RA5_bit; // RST
sbit MFRC522_CS_Direction at TRISA0_Bit;
sbit SoftSPI_CLK_Direction at TRISA1_Bit;
sbit SoftSPI_SDO_Direction at TRISA2_Bit;
sbit SoftSPI_SDI_Direction at TRISA3_Bit;
sbit MFRC522_RST_Direction at TRISA5_Bit;
// End Software SPI module connections
#include "RC522.c" // RC522 RFID Kütüphanesi
#include "LCD_I2C.c" // LCD I2C Kütüphanesi
unsigned long RC522_ID;
char txt[3];
void main() {
// Port Giris-Çikis Seçimi (0:Çikis, 1:Giris)
TRISA=0b00000000; // [][][MFRC522_RST][LED][SoftSPI_SDI][SoftSPI_SDO][SoftSPI_CLK][MFRC522_CS]
TRISB=0b00000000; // [][][][][][][SCK][SDA]
TRISC=0b00000000; // [][][][][][][][]
TRISD=0b00000000; // [][][][][][][][BUZZER]
TRISE=0b00000000; // [][][][][][][][]
// Port Analog-Dijital Giris Seçimi (0:Dijital, 1:Analog)
ANSELA=0b00000000; // [][][][][][][][]
ANSELB=0b00000000; // [][][][][][][][]
ANSELC=0b00000000; // [][][][][][][][]
ANSELD=0b00000000; // [][][][][][][][]
ANSELE=0b00000000; // [][][][][][][][]
// Port Temizleme
LATA=0x00;
LATB=0x00;
LATC=0x00;
LATD=0x00;
LATE=0x00;
// I2C Hazirlama
I2C1_Init(100000); // I2C LCD kütüphanesi dahili I2C donanimi ile çalismaktadir.
Soft_SPI_Init(); // SPI hazirlama
MFRC522_CS = 1; // SlaveSelect (SS) RFID aktif
MFRC522_Init(); // RC522 modülü hazirlama
delay_ms(1000); // 1 saniye bekleme
// LCD Ekran Hazirlama
LCD_Init(); // Ekrani hazirla
LCD_Cmd(_LCD_CURSOR_OFF); // Imleci kapat
LCD_Cmd(_LCD_CLEAR); // Ekrani temizle
Lcd_Out(1, 1," RFID-RC522 "); // 1.Satir 1.Sutuna yaz
Lcd_Out(2, 1,"ID: 00:00:00:00"); // 2.Satir 1.Sutuna yaz
// Sonsuz Dongu
while(1){
RC522_ID=MFRC522_GetId(); // RC522 ID oku
if(RC522_ID){ // Bir ID okundu mu?
BUZZER=1; delay_ms(100); BUZZER=0; // 100ms lik BUZZER sinyali
ByteToHex(RC522_ID>>24, txt); Lcd_Out(2, 6,txt); // ID'nin 1.Byte degerini LCD'ye yaz
ByteToHex(RC522_ID>>16, txt); Lcd_Out(2, 9,txt); // ID'nin 2.Byte degerini LCD'ye yaz
ByteToHex(RC522_ID>>8 , txt); Lcd_Out(2, 12,txt); // ID'nin 3.Byte degerini LCD'ye yaz
ByteToHex(RC522_ID , txt); Lcd_Out(2, 15,txt); // ID'nin 4.Byte degerini LCD'ye yaz
delay_ms(1000); // 1 saniye bekleme
}
}
}
RC522 RFID Kütüphane Kodları
//Maximum length of the array
#define MAX_LEN 16
//MF522 Command Words
#define PCD_IDLE 0x00 // No action; Cancel the current command
#define PCD_AUTHENT 0x0E // Authentication Key
#define PCD_RECEIVE 0x08 // Receive Data
#define PCD_TRANSMIT 0x04 // Transmit Data
#define PCD_TRANSCEIVE 0x0C // Transmit and Receive Data
#define PCD_RESETPHASE 0x0F // Reset
#define PCD_CALCCRC 0x03 // CRC Calculate
// Mifare_One Card Command Words
#define PICC_REQIDL 0x26 // Find the antenna area does not enter hibernation
#define PICC_REQALL 0x52 // Find all the cards antenna area
#define PICC_ANTICOLL 0x93 // Anti-collision
#define PICC_SElECTTAG 0x93 // Election card
#define PICC_AUTHENT1A 0x60 // Authentication key A
#define PICC_AUTHENT1B 0x61 // Authentication key B
#define PICC_READ 0x30 // Read block
#define PICC_WRITE 0xA0 // Write block
#define PICC_DECREMENT 0xC0 // Debit
#define PICC_INCREMENT 0xC1 // Recharge
#define PICC_RESTORE 0xC2 // Transfer block data to the buffer
#define PICC_TRANSFER 0xB0 // Save the data in the buffer
#define PICC_HALT 0x50 // Sleep
// And MF522 The error code is returned when communication
#define MI_OK 0
#define MI_NOTAGERR 1
#define MI_ERR 2
//------------------MFRC522 Register---------------
//Page 0: Command and Status
#define Reserved00 0x00
#define CommandReg 0x01
#define CommIEnReg 0x02
#define DivlEnReg 0x03
#define CommIrqReg 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 Reserved01 0x0F
//Page 1: Command
#define Reserved10 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 Reserved11 0x1A
#define Reserved12 0x1B
#define MifareReg 0x1C
#define Reserved13 0x1D
#define Reserved14 0x1E
#define SerialSpeedReg 0x1F
//Page 2: CFG
#define Reserved20 0x20
#define CRCResultRegM 0x21
#define CRCResultRegL 0x22
#define Reserved21 0x23
#define ModWidthReg 0x24
#define Reserved22 0x25
#define RFCfgReg 0x26
#define GsNReg 0x27
#define CWGsPReg 0x28
#define ModGsPReg 0x29
#define TModeReg 0x2A
#define TPrescalerReg 0x2B
#define TReloadRegH 0x2C
#define TReloadRegL 0x2D
#define TCounterValueRegH 0x2E
#define TCounterValueRegL 0x2F
//Page 3: TestRegister
#define Reserved30 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 Reserved31 0x3C
#define Reserved32 0x3D
#define Reserved33 0x3E
#define Reserved34 0x3F
// 4 bytes card serial number, the first 5 bytes for the checksum byte
unsigned char serNum[5];
void Write_MFRC522(unsigned char addr, unsigned char val);
unsigned char Read_MFRC522(unsigned char addr);
void SetBitMask(unsigned char reg, unsigned char mask);
void ClearBitMask(unsigned char reg, unsigned char mask);
void AntennaOn(void);
void AntennaOff(void);
void MFRC522_Reset(void);
void MFRC522_Init(void);
unsigned char MFRC522_Request(unsigned char reqMode, unsigned char *TagType);
unsigned char MFRC522_ToCard(unsigned char command, unsigned char *sendData, unsigned char sendLen, unsigned char *backData, unsigned int *backLen);
unsigned char MFRC522_Anticoll(unsigned char *serNum);
void CalulateCRC(unsigned char *pIndata, unsigned char len, unsigned char *pOutData);
unsigned char MFRC522_SelectTag(unsigned char *serNum);
unsigned char MFRC522_Auth(unsigned char authMode, unsigned char BlockAddr, unsigned char *Sectorkey, unsigned char *serNum);
unsigned char MFRC522_Read(unsigned char blockAddr, unsigned char *recvData);
unsigned char MFRC522_Write(unsigned char blockAddr, unsigned char *writeData);
void MFRC522_Halt(void);
/*
* Function Name: Separate_hexP10
* Function Description: To strip data high from full data
* Input Parameters: val - the value to be strip
* Return value: Part High
*/
unsigned char Separate_hexP10(unsigned char val){
val = val & 0xF0;
val = val >> 4;
if (val < 10)
return val + 48;
else
return val + 55;
}
/*
* Function Name: Separate_hexP1
* Function Description: To strip data low from full data
* Input Parameters: val - the value to be strip
* Return value: Part Low
*/
unsigned char Separate_hexP1(unsigned char val){
val = val & 0x0F;
if (val < 10)
return val + 48;
else
return val + 55;
}
/*
* Function Name: Write_MFRC5200
* Function Description: To a certain MFRC522 register to write a byte of data
* Input Parameters: addr - register address; val - the value to be written
* Return value: None
*/
void Write_MFRC522(unsigned char addr, unsigned char val){
MFRC522_CS = 0;
//Address Format: 0XXXXXX0
Soft_SPI_Write((addr<<1)&0x7E);
Soft_SPI_Write(val);
MFRC522_CS = 1;
}
/*
* Function Name: Read_MFRC522
* Description: From a certain MFRC522 read a byte of data register
* Input Parameters: addr - register address
* Returns: a byte of data read from the
*/
unsigned char Read_MFRC522(unsigned char addr){
unsigned char val;
MFRC522_CS = 0;
//Address Format: 1XXXXXX0
Soft_SPI_Write(((addr<<1)&0x7E) | 0x80);
val = Soft_SPI_Read(0x00);
MFRC522_CS = 1;
return val;
}
/*
* Function Name: SetBitMask
* Description: Set RC522 register bit
* Input parameters: reg - register address; mask - set value
* Return value: None
*/
void SetBitMask(unsigned char reg, unsigned char mask){
unsigned char tmp;
tmp = Read_MFRC522(reg);
Write_MFRC522(reg, tmp | mask); // set bit mask
}
/*
* Function Name: ClearBitMask
* Description: clear RC522 register bit
* Input parameters: reg - register address; mask - clear bit value
* Return value: None
*/
void ClearBitMask(unsigned char reg, unsigned char mask){
unsigned char tmp;
tmp = Read_MFRC522(reg);
Write_MFRC522(reg, tmp & (~mask)); // clear bit mask
}
/*
* Function Name: AntennaOn
* Description: Open antennas, each time you start or shut down the natural barrier between the transmitter should be at least 1ms interval
* Input: None
* Return value: None
*/
void AntennaOn(void){
unsigned char temp;
temp = Read_MFRC522(TxControlReg);
if (!(temp & 0x03))
SetBitMask(TxControlReg, 0x03);
}
/*
* Function Name: AntennaOff
* Description: Close antennas, each time you start or shut down the natural barrier between the transmitter should be at least 1ms interval
* Input: None
* Return value: None
*/
void AntennaOff(void){
ClearBitMask(TxControlReg, 0x03);
}
/*
* Function Name: ResetMFRC522
* Description: Reset RC522
* Input: None
* Return value: None
*/
void MFRC522_Reset(void){
Write_MFRC522(CommandReg, PCD_RESETPHASE);
}
/*
* Function Name: InitMFRC522
* Description: Initialize RC522
* Input: None
* Return value: None
*/
void MFRC522_Init(void){
MFRC522_RST = 1;
MFRC522_Reset();
//Timer: TPrescaler*TreloadVal/6.78MHz = 24ms
Write_MFRC522(TModeReg, 0x8D); //Tauto=1; f(Timer) = 6.78MHz/TPreScaler
Write_MFRC522(TPrescalerReg, 0x3E); //TModeReg[3..0] + TPrescalerReg
Write_MFRC522(TReloadRegL, 30);
Write_MFRC522(TReloadRegH, 0);
Write_MFRC522(TxAutoReg, 0x40); //100%ASK
Write_MFRC522(ModeReg, 0x3D); //CRC Initial value 0x6363
AntennaOn(); //Open the antenna
}
/*
* Function Name: MFRC522_Request
* Description: Find cards, read the card type number
* Input parameters: reqMode - find cards way
* TagType - Return Card Type
* 0x4400 = Mifare_UltraLight
* 0x0400 = Mifare_One(S50)
* 0x0200 = Mifare_One(S70)
* 0x0800 = Mifare_Pro(X)
* 0x4403 = Mifare_DESFire
* Return value: the successful return MI_OK
*/
unsigned char MFRC522_Request(unsigned char reqMode, unsigned char *TagType){
unsigned char status;
unsigned char backBits; //The received data bits
Write_MFRC522(BitFramingReg, 0x07); //TxLastBists = BitFramingReg[2..0] ???
TagType[0] = reqMode;
status = MFRC522_ToCard(PCD_TRANSCEIVE, TagType, 1, TagType, &backBits);
if ((status != MI_OK) || (backBits != 0x10))
status = MI_ERR;
return status;
}
/*
* Function Name: MFRC522_ToCard
* Description: RC522 and ISO14443 card communication
* Input Parameters: command - MF522 command word,
* sendData--RC522 sent to the card by the data
* sendLen--Length of data sent
* backData--Received the card returns data,
* backLen--Return data bit length
* Return value: the successful return MI_OK
*/
unsigned char MFRC522_ToCard(unsigned char command, unsigned char *sendData, unsigned char sendLen, unsigned char *backData, unsigned int *backLen){
unsigned char status = MI_ERR;
unsigned char irqEn = 0x00;
unsigned char waitIRq = 0x00;
unsigned char lastBits;
unsigned char n;
unsigned char i;
switch (command){
case PCD_AUTHENT: // Certification cards close
irqEn = 0x12;
waitIRq = 0x10;
break;
case PCD_TRANSCEIVE: // Transmit FIFO data
irqEn = 0x77;
waitIRq = 0x30;
break;
default:
break;
}
Write_MFRC522(CommIEnReg, irqEn|0x80); //Interrupt request
ClearBitMask(CommIrqReg, 0x80); //Clear all interrupt request bit
SetBitMask(FIFOLevelReg, 0x80); //FlushBuffer=1, FIFO Initialization
Write_MFRC522(CommandReg, PCD_IDLE); //NO action; Cancel the current command???
//Writing data to the FIFO
for (i=0; i MAX_LEN)
n = MAX_LEN;
//Reading the received data in FIFO
for (i=0; i
RC522 RFID Kütüphane Kodları
//Maximum length of the array
#define MAX_LEN 16
//MF522 Command Words
#define PCD_IDLE 0x00 // No action; Cancel the current command
#define PCD_AUTHENT 0x0E // Authentication Key
#define PCD_RECEIVE 0x08 // Receive Data
#define PCD_TRANSMIT 0x04 // Transmit Data
#define PCD_TRANSCEIVE 0x0C // Transmit and Receive Data
#define PCD_RESETPHASE 0x0F // Reset
#define PCD_CALCCRC 0x03 // CRC Calculate
// Mifare_One Card Command Words
#define PICC_REQIDL 0x26 // Find the antenna area does not enter hibernation
#define PICC_REQALL 0x52 // Find all the cards antenna area
#define PICC_ANTICOLL 0x93 // Anti-collision
#define PICC_SElECTTAG 0x93 // Election card
#define PICC_AUTHENT1A 0x60 // Authentication key A
#define PICC_AUTHENT1B 0x61 // Authentication key B
#define PICC_READ 0x30 // Read block
#define PICC_WRITE 0xA0 // Write block
#define PICC_DECREMENT 0xC0 // Debit
#define PICC_INCREMENT 0xC1 // Recharge
#define PICC_RESTORE 0xC2 // Transfer block data to the buffer
#define PICC_TRANSFER 0xB0 // Save the data in the buffer
#define PICC_HALT 0x50 // Sleep
// And MF522 The error code is returned when communication
#define MI_OK 0
#define MI_NOTAGERR 1
#define MI_ERR 2
//------------------MFRC522 Register---------------
//Page 0: Command and Status
#define Reserved00 0x00
#define CommandReg 0x01
#define CommIEnReg 0x02
#define DivlEnReg 0x03
#define CommIrqReg 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 Reserved01 0x0F
//Page 1: Command
#define Reserved10 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 Reserved11 0x1A
#define Reserved12 0x1B
#define MifareReg 0x1C
#define Reserved13 0x1D
#define Reserved14 0x1E
#define SerialSpeedReg 0x1F
//Page 2: CFG
#define Reserved20 0x20
#define CRCResultRegM 0x21
#define CRCResultRegL 0x22
#define Reserved21 0x23
#define ModWidthReg 0x24
#define Reserved22 0x25
#define RFCfgReg 0x26
#define GsNReg 0x27
#define CWGsPReg 0x28
#define ModGsPReg 0x29
#define TModeReg 0x2A
#define TPrescalerReg 0x2B
#define TReloadRegH 0x2C
#define TReloadRegL 0x2D
#define TCounterValueRegH 0x2E
#define TCounterValueRegL 0x2F
//Page 3: TestRegister
#define Reserved30 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 Reserved31 0x3C
#define Reserved32 0x3D
#define Reserved33 0x3E
#define Reserved34 0x3F
// 4 bytes card serial number, the first 5 bytes for the checksum byte
unsigned char serNum[5];
void Write_MFRC522(unsigned char addr, unsigned char val);
unsigned char Read_MFRC522(unsigned char addr);
void SetBitMask(unsigned char reg, unsigned char mask);
void ClearBitMask(unsigned char reg, unsigned char mask);
void AntennaOn(void);
void AntennaOff(void);
void MFRC522_Reset(void);
void MFRC522_Init(void);
unsigned char MFRC522_Request(unsigned char reqMode, unsigned char *TagType);
unsigned char MFRC522_ToCard(unsigned char command, unsigned char *sendData, unsigned char sendLen, unsigned char *backData, unsigned int *backLen);
unsigned char MFRC522_Anticoll(unsigned char *serNum);
void CalulateCRC(unsigned char *pIndata, unsigned char len, unsigned char *pOutData);
unsigned char MFRC522_SelectTag(unsigned char *serNum);
unsigned char MFRC522_Auth(unsigned char authMode, unsigned char BlockAddr, unsigned char *Sectorkey, unsigned char *serNum);
unsigned char MFRC522_Read(unsigned char blockAddr, unsigned char *recvData);
unsigned char MFRC522_Write(unsigned char blockAddr, unsigned char *writeData);
void MFRC522_Halt(void);
/*
* Function Name: Separate_hexP10
* Function Description: To strip data high from full data
* Input Parameters: val - the value to be strip
* Return value: Part High
*/
unsigned char Separate_hexP10(unsigned char val){
val = val & 0xF0;
val = val >> 4;
if (val < 10)
return val + 48;
else
return val + 55;
}
/*
* Function Name: Separate_hexP1
* Function Description: To strip data low from full data
* Input Parameters: val - the value to be strip
* Return value: Part Low
*/
unsigned char Separate_hexP1(unsigned char val){
val = val & 0x0F;
if (val < 10)
return val + 48;
else
return val + 55;
}
/*
* Function Name: Write_MFRC5200
* Function Description: To a certain MFRC522 register to write a byte of data
* Input Parameters: addr - register address; val - the value to be written
* Return value: None
*/
void Write_MFRC522(unsigned char addr, unsigned char val){
MFRC522_CS = 0;
//Address Format: 0XXXXXX0
Soft_SPI_Write((addr<<1)&0x7E);
Soft_SPI_Write(val);
MFRC522_CS = 1;
}
/*
* Function Name: Read_MFRC522
* Description: From a certain MFRC522 read a byte of data register
* Input Parameters: addr - register address
* Returns: a byte of data read from the
*/
unsigned char Read_MFRC522(unsigned char addr){
unsigned char val;
MFRC522_CS = 0;
//Address Format: 1XXXXXX0
Soft_SPI_Write(((addr<<1)&0x7E) | 0x80);
val = Soft_SPI_Read(0x00);
MFRC522_CS = 1;
return val;
}
/*
* Function Name: SetBitMask
* Description: Set RC522 register bit
* Input parameters: reg - register address; mask - set value
* Return value: None
*/
void SetBitMask(unsigned char reg, unsigned char mask){
unsigned char tmp;
tmp = Read_MFRC522(reg);
Write_MFRC522(reg, tmp | mask); // set bit mask
}
/*
* Function Name: ClearBitMask
* Description: clear RC522 register bit
* Input parameters: reg - register address; mask - clear bit value
* Return value: None
*/
void ClearBitMask(unsigned char reg, unsigned char mask){
unsigned char tmp;
tmp = Read_MFRC522(reg);
Write_MFRC522(reg, tmp & (~mask)); // clear bit mask
}
/*
* Function Name: AntennaOn
* Description: Open antennas, each time you start or shut down the natural barrier between the transmitter should be at least 1ms interval
* Input: None
* Return value: None
*/
void AntennaOn(void){
unsigned char temp;
temp = Read_MFRC522(TxControlReg);
if (!(temp & 0x03))
SetBitMask(TxControlReg, 0x03);
}
/*
* Function Name: AntennaOff
* Description: Close antennas, each time you start or shut down the natural barrier between the transmitter should be at least 1ms interval
* Input: None
* Return value: None
*/
void AntennaOff(void){
ClearBitMask(TxControlReg, 0x03);
}
/*
* Function Name: ResetMFRC522
* Description: Reset RC522
* Input: None
* Return value: None
*/
void MFRC522_Reset(void){
Write_MFRC522(CommandReg, PCD_RESETPHASE);
}
/*
* Function Name: InitMFRC522
* Description: Initialize RC522
* Input: None
* Return value: None
*/
void MFRC522_Init(void){
MFRC522_RST = 1;
MFRC522_Reset();
//Timer: TPrescaler*TreloadVal/6.78MHz = 24ms
Write_MFRC522(TModeReg, 0x8D); //Tauto=1; f(Timer) = 6.78MHz/TPreScaler
Write_MFRC522(TPrescalerReg, 0x3E); //TModeReg[3..0] + TPrescalerReg
Write_MFRC522(TReloadRegL, 30);
Write_MFRC522(TReloadRegH, 0);
Write_MFRC522(TxAutoReg, 0x40); //100%ASK
Write_MFRC522(ModeReg, 0x3D); //CRC Initial value 0x6363
AntennaOn(); //Open the antenna
}
/*
* Function Name: MFRC522_Request
* Description: Find cards, read the card type number
* Input parameters: reqMode - find cards way
* TagType - Return Card Type
* 0x4400 = Mifare_UltraLight
* 0x0400 = Mifare_One(S50)
* 0x0200 = Mifare_One(S70)
* 0x0800 = Mifare_Pro(X)
* 0x4403 = Mifare_DESFire
* Return value: the successful return MI_OK
*/
unsigned char MFRC522_Request(unsigned char reqMode, unsigned char *TagType){
unsigned char status;
unsigned char backBits; //The received data bits
Write_MFRC522(BitFramingReg, 0x07); //TxLastBists = BitFramingReg[2..0] ???
TagType[0] = reqMode;
status = MFRC522_ToCard(PCD_TRANSCEIVE, TagType, 1, TagType, &backBits);
if ((status != MI_OK) || (backBits != 0x10))
status = MI_ERR;
return status;
}
/*
* Function Name: MFRC522_ToCard
* Description: RC522 and ISO14443 card communication
* Input Parameters: command - MF522 command word,
* sendData--RC522 sent to the card by the data
* sendLen--Length of data sent
* backData--Received the card returns data,
* backLen--Return data bit length
* Return value: the successful return MI_OK
*/
unsigned char MFRC522_ToCard(unsigned char command, unsigned char *sendData, unsigned char sendLen, unsigned char *backData, unsigned int *backLen){
unsigned char status = MI_ERR;
unsigned char irqEn = 0x00;
unsigned char waitIRq = 0x00;
unsigned char lastBits;
unsigned char n;
unsigned char i;
switch (command){
case PCD_AUTHENT: // Certification cards close
irqEn = 0x12;
waitIRq = 0x10;
break;
case PCD_TRANSCEIVE: // Transmit FIFO data
irqEn = 0x77;
waitIRq = 0x30;
break;
default:
break;
}
Write_MFRC522(CommIEnReg, irqEn|0x80); //Interrupt request
ClearBitMask(CommIrqReg, 0x80); //Clear all interrupt request bit
SetBitMask(FIFOLevelReg, 0x80); //FlushBuffer=1, FIFO Initialization
Write_MFRC522(CommandReg, PCD_IDLE); //NO action; Cancel the current command???
//Writing data to the FIFO
for (i=0; i MAX_LEN)
n = MAX_LEN;
//Reading the received data in FIFO
for (i=0; i
Uygulamaya ait dosyaları buraya tıklayarak indirebilirsiniz. Merak ettiğiniz ve aklınıza takılan soruları aşağıda 👇 yorum olarak bize iletebilirsiniz. İyi çalışmalar. 🙂 #geliştirmeyebaşla
Yorum yapmak için giriş yapmalısınız.