KS0205 Keyestudio RC522 RFID Modülü
Keyestudio RC522 RFID Modülü
MF522-AN modülü, Philips MFRC522 orijinal okuyucu devre çip tasarımını, kullanımı kolay, düşük maliyetli, ekipman geliştirmeye uygun, okuyucu kullanıcıları gibi gelişmiş uygulamaların geliştirilmesi, kullanıcının RF kart terminal tasarımı / üretimi ihtiyacını benimser.
Bu modül, doğrudan çeşitli okuyucu kalıplarına yüklenebilir. Modül 3,3V voltaj kullanır ve kullanıcıya, sabit ve güvenilir okuyucu mesafesini garanti edebilen basit birkaç hat kullanılarak SPI arayüzü üzerinden herhangi bir CPU kartı iletişim modülüne doğrudan bağlanabilir.
Parametreler
- Akım: 13-26mA / DC 3.3V
- Boşta Akım: 10-13mA / DC 3.3V
- Uyku akımı: <80uA
- Tepe akımı: <30mA
- Çalışma Frekansı: 13.56MHz
- Desteklenen kart türleri: mifare1 S50, mifare1 S70, mifare UltraLight, mifare Pro, mifare Desfire
- Çevresel Çalışma sıcaklığı: -20 ila 80 santigrat derece
- Çevre Depolama sıcaklığı: -40 ila 85 santigrat derece
- Bağıl Nem:% 5 -% 95
PIN ÇIKIŞLARI
Bağlantı şeması
Örnek Kod
- SPI kitaplıklarını indirme
- Kod İndir Veya aşağıdaki kodu doğrudan kopyalayabilirsiniz.
#include#define uchar unsigned char #define uint unsigned int #define MAX_LEN 16 const int chipSelectPin = 10;//if the controller is UNO,328,168 const int NRSTPD = 5; //MF522command word #define PCD_IDLE 0x00 //NO action; cancel current command #define PCD_AUTHENT 0x0E //verify key #define PCD_RECEIVE 0x08 //receive data #define PCD_TRANSMIT 0x04 //send data #define PCD_TRANSCEIVE 0x0C //receive and send data #define PCD_RESETPHASE 0x0F //reset #define PCD_CALCCRC 0x03 //CRC calculation //Mifare_One Card command word #define PICC_REQIDL 0x26 // line-tracking area is dormant #define PICC_REQALL 0x52 //line-tracking area is interfered #define PICC_ANTICOLL 0x93 //Anti collision #define PICC_SElECTTAG 0x93 //choose cards #define PICC_AUTHENT1A 0x60 //Verify A key #define PICC_AUTHENT1B 0x61 //Verify B key #define PICC_READ 0x30 // Reader Module #define PICC_WRITE 0xA0 // letter block #define PICC_DECREMENT 0xC0 #define PICC_INCREMENT 0xC1 #define PICC_RESTORE 0xC2 //Transfer data to buffer #define PICC_TRANSFER 0xB0 //Save buffer data #define PICC_HALT 0x50 //Dormancy //MF522 Error code 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 uchar serNum[5]; uchar writeDate[16] ={'T', 'e', 'n', 'g', ' ', 'B', 'o', 0, 0, 0, 0, 0, 0, 0, 0,0}; uchar sectorKeyA[16][16] = {{0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}, {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}, {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}, }; uchar sectorNewKeyA[16][16] = {{0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}, {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xff,0x07,0x80,0x69, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}, {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xff,0x07,0x80,0x69, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}, }; void setup() { Serial.begin(9600); // RFID reader SOUT pin connected to Serial RX pin at 2400bps // start the SPI library: SPI.begin(); pinMode(chipSelectPin,OUTPUT); // Set digital pin 10 as OUTPUT to connect it to the RFID /ENABLE pin digitalWrite(chipSelectPin, LOW); // Activate the RFID reader pinMode(NRSTPD,OUTPUT); // Set digital pin 10 , Not Reset and Power-down digitalWrite(NRSTPD, HIGH); MFRC522_Init(); } void loop() { uchar i,tmp; uchar status; uchar str[MAX_LEN]; uchar RC_size; uchar blockAddr; //Select the address of the operation 0~63 // searching card, return card type status = MFRC522_Request(PICC_REQIDL, str); if (status == MI_OK) { } status = MFRC522_Anticoll(str); memcpy(serNum, str, 5); if (status == MI_OK) { Serial.println("The card's number is : "); Serial.print(serNum[0],BIN); Serial.print(serNum[1],BIN); Serial.print(serNum[2],BIN); Serial.print(serNum[3],BIN); Serial.print(serNum[4],BIN); Serial.println(" "); } // select card, return card capacity RC_size = MFRC522_SelectTag(serNum); if (RC_size != 0) {} // write data card blockAddr = 7; // data block 7 status = MFRC522_Auth(PICC_AUTHENT1A, blockAddr, sectorKeyA[blockAddr/4], serNum); // authentication if (status == MI_OK) { // write data status = MFRC522_Write(blockAddr, sectorNewKeyA[blockAddr/4]); Serial.print("set the new card password, and can modify the data of the Sector: "); Serial.print(blockAddr/4,DEC); // write data blockAddr = blockAddr - 3 ; status = MFRC522_Write(blockAddr, writeDate); if(status == MI_OK) { Serial.println("OK!"); } } // read card blockAddr = 7; // data block 7 status = MFRC522_Auth(PICC_AUTHENT1A, blockAddr, sectorNewKeyA[blockAddr/4], serNum); // authentication if (status == MI_OK) { // read data blockAddr = blockAddr - 3 ; status = MFRC522_Read(blockAddr, str); if (status == MI_OK) { Serial.println("Read from the card ,the data is : "); for (i=0; i<16; i++) { Serial.print(str[i]); } Serial.println(" "); } } Serial.println(" "); MFRC522_Halt(); // command card into sleeping mode } void Write_MFRC522(uchar addr, uchar val) { digitalWrite(chipSelectPin, LOW); SPI.transfer((addr<<1)&0x7E); SPI.transfer(val); digitalWrite(chipSelectPin, HIGH); } uchar Read_MFRC522(uchar addr) { uchar val; digitalWrite(chipSelectPin, LOW); //address format: 1XXXXXX0 SPI.transfer(((addr<<1)&0x7E) | 0x80); val =SPI.transfer(0x00); digitalWrite(chipSelectPin, HIGH); return val; } void SetBitMask(uchar reg, uchar mask) { uchar tmp; tmp = Read_MFRC522(reg); Write_MFRC522(reg, tmp | mask); // set bit mask } void ClearBitMask(uchar reg, uchar mask) { uchar tmp; tmp = Read_MFRC522(reg); Write_MFRC522(reg, tmp & (~mask)); // clear bit mask } void AntennaOn(void) { uchar temp; temp = Read_MFRC522(TxControlReg); if (!(temp & 0x03)) { SetBitMask(TxControlReg, 0x03); } } void AntennaOff(void) { ClearBitMask(TxControlReg, 0x03); } void MFRC522_Reset(void) { Write_MFRC522(CommandReg, PCD_RESETPHASE); } void MFRC522_Init(void) { digitalWrite(NRSTPD,HIGH); 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 original value 0x6363 ??? AntennaOn(); // open antenna } uchar MFRC522_Request(uchar reqMode, uchar *TagType) { uchar status; uint backBits; // bits of data received 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; } uchar MFRC522_ToCard(uchar command, uchar *sendData, uchar sendLen, uchar *backData, uint *backLen) { uchar status = MI_ERR; uchar irqEn = 0x00; uchar waitIRq = 0x00; uchar lastBits; uchar n; uint i; switch (command) { case PCD_AUTHENT: // card key authentication { irqEn = 0x12; waitIRq = 0x10; break; } case PCD_TRANSCEIVE: // send data in FIFO { irqEn = 0x77; waitIRq = 0x30; break; } default: break; } Write_MFRC522(CommIEnReg, irqEn|0x80); // permission for interrupt request ClearBitMask(CommIrqReg, 0x80); // clear all bits of the interrupt request SetBitMask(FIFOLevelReg, 0x80); //FlushBuffer=1, FIFO initialize Write_MFRC522(CommandReg, PCD_IDLE); //NO action; clear current command ??? // write data into FIFO for (i=0; i MAX_LEN) { n = MAX_LEN; } // read the data received in FIFO for (i=0; i
Sonuç
Bu deneyde, IC kartı yaklaştığında, RFID modülü verileri IC kartına yazar ve ardından monitör penceresinde görüntüleyerek verileri okur. Aşağıdaki resimde gösterildiği gibi:
Kaynaklar
- Kod ve Kitaplıklar: