From 09b3cdec439cb1dd6bb8833075bcb712c83cf9aa Mon Sep 17 00:00:00 2001 From: Jesse de Vries Date: Sat, 2 Dec 2023 00:33:16 +0100 Subject: [PATCH 1/4] Fixed for compatibility with new SPI package --- MFRC522.py | 141 +++++++++++++++++++++++++++-------------------------- 1 file changed, 71 insertions(+), 70 deletions(-) diff --git a/MFRC522.py b/MFRC522.py index d1ee8b6..f8479a1 100644 --- a/MFRC522.py +++ b/MFRC522.py @@ -25,12 +25,12 @@ import spi import signal import time - + class MFRC522: NRSTPD = 22 - + MAX_LEN = 16 - + PCD_IDLE = 0x00 PCD_AUTHENT = 0x0E PCD_RECEIVE = 0x08 @@ -38,7 +38,7 @@ class MFRC522: PCD_TRANSCEIVE = 0x0C PCD_RESETPHASE = 0x0F PCD_CALCCRC = 0x03 - + PICC_REQIDL = 0x26 PICC_REQALL = 0x52 PICC_ANTICOLL = 0x93 @@ -52,11 +52,11 @@ class MFRC522: PICC_RESTORE = 0xC2 PICC_TRANSFER = 0xB0 PICC_HALT = 0x50 - + MI_OK = 0 MI_NOTAGERR = 1 MI_ERR = 2 - + Reserved00 = 0x00 CommandReg = 0x01 CommIEnReg = 0x02 @@ -73,7 +73,7 @@ class MFRC522: BitFramingReg = 0x0D CollReg = 0x0E Reserved01 = 0x0F - + Reserved10 = 0x10 ModeReg = 0x11 TxModeReg = 0x12 @@ -90,8 +90,8 @@ class MFRC522: Reserved13 = 0x1D Reserved14 = 0x1E SerialSpeedReg = 0x1F - - Reserved20 = 0x20 + + Reserved20 = 0x20 CRCResultRegM = 0x21 CRCResultRegL = 0x22 Reserved21 = 0x23 @@ -107,7 +107,7 @@ class MFRC522: TReloadRegL = 0x2D TCounterValueRegH = 0x2E TCounterValueRegL = 0x2F - + Reserved30 = 0x30 TestSel1Reg = 0x31 TestSel2Reg = 0x32 @@ -124,42 +124,43 @@ class MFRC522: Reserved32 = 0x3D Reserved33 = 0x3E Reserved34 = 0x3F - + serNum = [] - + device_0 = spi.openSPI(device="/dev/spidev0.0", mode=0, speed=1000000) + def __init__(self, dev='/dev/spidev0.0', spd=1000000): - spi.openSPI(device=dev,speed=spd) + spi.openSPI(device=dev,mode=0,speed=spd) GPIO.setmode(GPIO.BOARD) GPIO.setup(self.NRSTPD, GPIO.OUT) GPIO.output(self.NRSTPD, 1) self.MFRC522_Init() - + def MFRC522_Reset(self): self.Write_MFRC522(self.CommandReg, self.PCD_RESETPHASE) - + def Write_MFRC522(self, addr, val): - spi.transfer(((addr<<1)&0x7E,val)) - + spi.transfer(self.device_0, ((addr<<1)&0x7E,val)) + def Read_MFRC522(self, addr): - val = spi.transfer((((addr<<1)&0x7E) | 0x80,0)) + val = spi.transfer(self.device_0, (((addr<<1)&0x7E) | 0x80,0)) return val[1] - + def SetBitMask(self, reg, mask): tmp = self.Read_MFRC522(reg) self.Write_MFRC522(reg, tmp | mask) - + def ClearBitMask(self, reg, mask): tmp = self.Read_MFRC522(reg); self.Write_MFRC522(reg, tmp & (~mask)) - + def AntennaOn(self): temp = self.Read_MFRC522(self.TxControlReg) if(~(temp & 0x03)): self.SetBitMask(self.TxControlReg, 0x03) - + def AntennaOff(self): self.ClearBitMask(self.TxControlReg, 0x03) - + def MFRC522_ToCard(self,command,sendData): backData = [] backLen = 0 @@ -169,45 +170,45 @@ def MFRC522_ToCard(self,command,sendData): lastBits = None n = 0 i = 0 - + if command == self.PCD_AUTHENT: irqEn = 0x12 waitIRq = 0x10 if command == self.PCD_TRANSCEIVE: irqEn = 0x77 waitIRq = 0x30 - + self.Write_MFRC522(self.CommIEnReg, irqEn|0x80) self.ClearBitMask(self.CommIrqReg, 0x80) self.SetBitMask(self.FIFOLevelReg, 0x80) - - self.Write_MFRC522(self.CommandReg, self.PCD_IDLE); - + + self.Write_MFRC522(self.CommandReg, self.PCD_IDLE); + while(i self.MAX_LEN: n = self.MAX_LEN - + i = 0 while i Date: Sat, 2 Dec 2023 00:34:13 +0100 Subject: [PATCH 2/4] Updated to work with new SPI package --- Read.py | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/Read.py b/Read.py index cc395c5..7f726c6 100644 --- a/Read.py +++ b/Read.py @@ -30,7 +30,7 @@ # Capture SIGINT for cleanup when the script is aborted def end_read(signal,frame): global continue_reading - print "Ctrl+C captured, ending read." + print("Ctrl+C captured, ending read.") continue_reading = False GPIO.cleanup() @@ -41,8 +41,8 @@ def end_read(signal,frame): MIFAREReader = MFRC522.MFRC522() # Welcome message -print "Welcome to the MFRC522 data read example" -print "Press Ctrl-C to stop." +print("Welcome to the MFRC522 data read example") +print("Press Ctrl-C to stop.") # This loop keeps checking for chips. If one is near it will get the UID and authenticate while continue_reading: @@ -52,7 +52,7 @@ def end_read(signal,frame): # If a card is found if status == MIFAREReader.MI_OK: - print "Card detected" + print("Card detected") # Get the UID of the card (status,uid) = MIFAREReader.MFRC522_Anticoll() @@ -61,7 +61,7 @@ def end_read(signal,frame): if status == MIFAREReader.MI_OK: # Print UID - print "Card read UID: %s,%s,%s,%s" % (uid[0], uid[1], uid[2], uid[3]) + print("Card read UID: %s,%s,%s,%s" % (uid[0], uid[1], uid[2], uid[3])) # This is the default key for authentication key = [0xFF,0xFF,0xFF,0xFF,0xFF,0xFF] @@ -77,5 +77,5 @@ def end_read(signal,frame): MIFAREReader.MFRC522_Read(8) MIFAREReader.MFRC522_StopCrypto1() else: - print "Authentication error" + print("Authentication error") From 7e92b3fd6bd55502d77b42d236de00a85175c56a Mon Sep 17 00:00:00 2001 From: Jesse de Vries Date: Sat, 2 Dec 2023 00:35:56 +0100 Subject: [PATCH 3/4] Updated to work with new SPI package --- Write.py | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/Write.py b/Write.py index 237e268..6e7bc67 100644 --- a/Write.py +++ b/Write.py @@ -30,7 +30,7 @@ # Capture SIGINT for cleanup when the script is aborted def end_read(signal,frame): global continue_reading - print "Ctrl+C captured, ending read." + print("Ctrl+C captured, ending read.") continue_reading = False GPIO.cleanup() @@ -48,7 +48,7 @@ def end_read(signal,frame): # If a card is found if status == MIFAREReader.MI_OK: - print "Card detected" + print("Card detected") # Get the UID of the card (status,uid) = MIFAREReader.MFRC522_Anticoll() @@ -57,7 +57,7 @@ def end_read(signal,frame): if status == MIFAREReader.MI_OK: # Print UID - print "Card read UID: %s,%s,%s,%s" % (uid[0], uid[1], uid[2], uid[3]) + print("Card read UID: %s,%s,%s,%s" % (uid[0], uid[1], uid[2], uid[3])) # This is the default key for authentication key = [0xFF,0xFF,0xFF,0xFF,0xFF,0xFF] @@ -67,7 +67,7 @@ def end_read(signal,frame): # Authenticate status = MIFAREReader.MFRC522_Auth(MIFAREReader.PICC_AUTHENT1A, 8, key, uid) - print "\n" + print("\n") # Check if authenticated if status == MIFAREReader.MI_OK: @@ -79,34 +79,34 @@ def end_read(signal,frame): for x in range(0,16): data.append(0xFF) - print "Sector 8 looked like this:" + print("Sector 8 looked like this:") # Read block 8 MIFAREReader.MFRC522_Read(8) - print "\n" + print("\n") - print "Sector 8 will now be filled with 0xFF:" + print("Sector 8 will now be filled with 0xFF:") # Write the data MIFAREReader.MFRC522_Write(8, data) - print "\n" + print("\n") - print "It now looks like this:" + print("It now looks like this:") # Check to see if it was written MIFAREReader.MFRC522_Read(8) - print "\n" + print("\n") data = [] # Fill the data with 0x00 for x in range(0,16): data.append(0x00) - print "Now we fill it with 0x00:" + print("Now we fill it with 0x00:") MIFAREReader.MFRC522_Write(8, data) - print "\n" + print("\n") - print "It is now empty:" + print("It is now empty:") # Check to see if it was written MIFAREReader.MFRC522_Read(8) - print "\n" + print("\n") # Stop MIFAREReader.MFRC522_StopCrypto1() @@ -114,4 +114,4 @@ def end_read(signal,frame): # Make sure to stop reading for cards continue_reading = False else: - print "Authentication error" + print("Authentication error") From 0446be03ddfc3793b2808860fb7d6782582eecc0 Mon Sep 17 00:00:00 2001 From: Jesse de Vries Date: Sat, 2 Dec 2023 00:36:34 +0100 Subject: [PATCH 4/4] Updated to work with new SPI package --- Dump.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Dump.py b/Dump.py index 3b528e4..73fc548 100644 --- a/Dump.py +++ b/Dump.py @@ -30,7 +30,7 @@ # Capture SIGINT for cleanup when the script is aborted def end_read(signal,frame): global continue_reading - print "Ctrl+C captured, ending read." + print("Ctrl+C captured, ending read.") continue_reading = False GPIO.cleanup() @@ -48,7 +48,7 @@ def end_read(signal,frame): # If a card is found if status == MIFAREReader.MI_OK: - print "Card detected" + print("Card detected") # Get the UID of the card (status,uid) = MIFAREReader.MFRC522_Anticoll() @@ -57,7 +57,7 @@ def end_read(signal,frame): if status == MIFAREReader.MI_OK: # Print UID - print "Card read UID: %s,%s,%s,%s" % (uid[0], uid[1], uid[2], uid[3]) + print("Card read UID: %s,%s,%s,%s" % (uid[0], uid[1], uid[2], uid[3])) # This is the default key for authentication key = [0xFF,0xFF,0xFF,0xFF,0xFF,0xFF]