基于ARM的RFID阅读器设计
时间:07-23
来源:互联网
点击:
RFID是Radio Frequency Identification的缩写,即射频识别。一种非接触式的自动识别技术,它通过射频信号自动识别目标对象并获取相关数据,识别的距离可达几十厘米至几米,且根据读写的方式,可以输入数千字节的信息,同时,还具有极高的保密性,识别工作无须人工干预,可工作于各种恶劣环境。RFID技术可识别高速运动物体并可同时识别多个标签,操作快捷方便。其应用范围十分广泛,主要有商品零售、商品防伪、交通运输、物流仓储、安全管理、医疗卫生、图书档案和国防军事等。
RFID系统由三部分组成:
1.标签(Tag,即射频卡),由耦合元件及芯片组成,标签含有内置天线,用于和射频天线间进行通信;
2.阅读器,读取(在读写卡中还可以写入)标签信息的设备;
3.天线,在标签和读取器间传递射频信号。本文主要介绍基于ARM,工作频率在13.56MHz的RFID阅读器设计方案。
1系统硬件设计
1.1 系统主要芯片介绍
本设计方案的两个主要芯片是LPC2212和MF RC500。LPC2212功耗低,性能高,接口资源丰富,可以在RFID阅读器的基础上进行其它功能的扩展,实现一个多功能应用系统。MF RC500是PHILIPS公司生产的应用于13.56MHz非接触式通信中高集成读卡IC系列中的一员。MF RC500支持ISO14443A所有的层,内部的发送器部分不需要增加有源电路就能够直接驱动近操作距离的天线(可达100mm);接收器部分提供一个坚固而有效的解调和解码电路用于ISO14443A兼容的应答器信号;数字部分处理ISO14443A帧和错误检测奇偶CRC,此外它还支持快速CRYPTO1加密算法用于验证MIFARE系列产品。
1.2 系统总体设计
系统从功能上主要分为4大模块:控制模块、发送接收数据模块、串行通信模块和显示模块。各模块组成的系统总框图如图1所示。
控制模块主要由微控制器LPC2212和晶振组成,负责整个系统的控制工作。
发送接收数据模块主要由MF RC500、晶振和天线组成。MF RC500分为模拟部分和数字部分。模拟部分负责对射频卡的发送接收操作,发送主要完成驱动天线,提供13.56MHz的能量载波并根据寄存器的设置对发送数据进行调制;接收主要完成对射频卡发送的信号进行检测和解调并根据寄存器的设定进行处理。数字部分则通过并口和中断与微控制器LPC2212通信。MF RC500的能量载波由13.56MHz晶振提供,天线则主要由LC低通滤波器和LC谐振电路组成。
串行通信模块主要由RS-232-C标准采用的9芯接口和电平转换电路MAX232A组成。本模块负责阅读器与PC机通讯,可进行程序下载,射频卡信息修改等。
显示模块主要由低复用率的通用液晶(LCD)驱动器PCF8562和LCD屏组成。
PCF8562与微控制器LPC2212可以通过两线双向的I2C总线通信,当这两条线连接到器件的输出级时必须通过上拉电阻连接到正电源。显示模块负责卡片信息显示。
2 系统软件设计
软件设计包括三个模块:系统初始化模块、射频卡与读写器通信模块和LCD显示模块。下面详细介绍以上模块。
2.1 系统初始化模块
为了使系统能够正常运行,必须在系统复位时对系统进行初始化工作。其中包括中断向量表的建立和REMAP(重映射)操作、各种模式堆栈初始化操作、时钟初始化操作、串口初始化操作和中断选择初始化操作。
ARM7处理器有7种异常模式,其中断向量位置是固定的(地址0x00000000-0x0000001C),LPC2212采用64字节存储中断向量表。为了实现LPC2212在不同操作模式下对中断的使用,必须对LPC2212中Flash的Boot Block块和SRAM空间的一小部分REMAP。另外,需要对各种模式的堆栈进行初始化。
LPC2212振荡器工作在振荡模式,外部晶体振荡频率为20-25MHz,通过内部PLL电路调整时钟,使系统运行速度更快。程序首先使能PLL但不连接PLL,然后设置外设时钟与系统时钟的分频比,接着设置PLL的乘因子和除因子。设置完成后,把数据正确写入硬件,并等待PLL跟踪完成。最后,使能PLL并使PLL连上系统。
串口是读卡器与PC机通信端口,在使用前须设置串口波特率、接收和发送数据字符格式和初始化FIFO(先进先出队列)。
串口和RC500都是基于IRQ中断,使用前,须对LPC2212中断选择寄存器进行配置,把串口和RC500的中断请求分配为IRQ模式。
2.2 射频卡与读写器通信模块
本系统采用M1(MIFARE 1)智能卡,本卡自带天线,内含加密控制逻辑和通讯逻辑电路,M1分为16个扇区,每个扇区为4块,每块16个字节,以块为存取单位,每个扇区有独立的一组密码及访问控制,可一卡多用。M1射频卡与读写器的通信流程图如图2所示。
复位应答(Answer to request):M1射频卡的通讯协议和通讯波特率是定义好的,当有卡片进入读写器的操作范围时,读写器以特定的协议与它通讯,从而确定该卡是否为M1射频卡,即验证卡片的卡型。
防冲突机制 (Anti-collision Loop):当有多张卡进入读写器操作范围时,防冲突机制会从其中选择一张进行操作,未选中的则处于空闲模式等待下一次选卡,该过程会返回被选卡的序列号。
选择卡片(Select Tag):选择被选中的卡的序列号,并同时返回卡的容量代码。
三次互相验证(Three Authentication):选定要处理的卡片之后,读写器就确定要访问的扇区号,并对该扇区密码进行密码校验,在三次相互认证之后就可以通过加密流进行通讯。(在选择另一扇区时,则必须进行另一扇区密码校验。)
RFID系统由三部分组成:
1.标签(Tag,即射频卡),由耦合元件及芯片组成,标签含有内置天线,用于和射频天线间进行通信;
2.阅读器,读取(在读写卡中还可以写入)标签信息的设备;
3.天线,在标签和读取器间传递射频信号。本文主要介绍基于ARM,工作频率在13.56MHz的RFID阅读器设计方案。
1系统硬件设计
1.1 系统主要芯片介绍
本设计方案的两个主要芯片是LPC2212和MF RC500。LPC2212功耗低,性能高,接口资源丰富,可以在RFID阅读器的基础上进行其它功能的扩展,实现一个多功能应用系统。MF RC500是PHILIPS公司生产的应用于13.56MHz非接触式通信中高集成读卡IC系列中的一员。MF RC500支持ISO14443A所有的层,内部的发送器部分不需要增加有源电路就能够直接驱动近操作距离的天线(可达100mm);接收器部分提供一个坚固而有效的解调和解码电路用于ISO14443A兼容的应答器信号;数字部分处理ISO14443A帧和错误检测奇偶CRC,此外它还支持快速CRYPTO1加密算法用于验证MIFARE系列产品。
1.2 系统总体设计
系统从功能上主要分为4大模块:控制模块、发送接收数据模块、串行通信模块和显示模块。各模块组成的系统总框图如图1所示。
控制模块主要由微控制器LPC2212和晶振组成,负责整个系统的控制工作。
发送接收数据模块主要由MF RC500、晶振和天线组成。MF RC500分为模拟部分和数字部分。模拟部分负责对射频卡的发送接收操作,发送主要完成驱动天线,提供13.56MHz的能量载波并根据寄存器的设置对发送数据进行调制;接收主要完成对射频卡发送的信号进行检测和解调并根据寄存器的设定进行处理。数字部分则通过并口和中断与微控制器LPC2212通信。MF RC500的能量载波由13.56MHz晶振提供,天线则主要由LC低通滤波器和LC谐振电路组成。
串行通信模块主要由RS-232-C标准采用的9芯接口和电平转换电路MAX232A组成。本模块负责阅读器与PC机通讯,可进行程序下载,射频卡信息修改等。
显示模块主要由低复用率的通用液晶(LCD)驱动器PCF8562和LCD屏组成。
PCF8562与微控制器LPC2212可以通过两线双向的I2C总线通信,当这两条线连接到器件的输出级时必须通过上拉电阻连接到正电源。显示模块负责卡片信息显示。
2 系统软件设计
软件设计包括三个模块:系统初始化模块、射频卡与读写器通信模块和LCD显示模块。下面详细介绍以上模块。
2.1 系统初始化模块
为了使系统能够正常运行,必须在系统复位时对系统进行初始化工作。其中包括中断向量表的建立和REMAP(重映射)操作、各种模式堆栈初始化操作、时钟初始化操作、串口初始化操作和中断选择初始化操作。
ARM7处理器有7种异常模式,其中断向量位置是固定的(地址0x00000000-0x0000001C),LPC2212采用64字节存储中断向量表。为了实现LPC2212在不同操作模式下对中断的使用,必须对LPC2212中Flash的Boot Block块和SRAM空间的一小部分REMAP。另外,需要对各种模式的堆栈进行初始化。
LPC2212振荡器工作在振荡模式,外部晶体振荡频率为20-25MHz,通过内部PLL电路调整时钟,使系统运行速度更快。程序首先使能PLL但不连接PLL,然后设置外设时钟与系统时钟的分频比,接着设置PLL的乘因子和除因子。设置完成后,把数据正确写入硬件,并等待PLL跟踪完成。最后,使能PLL并使PLL连上系统。
串口是读卡器与PC机通信端口,在使用前须设置串口波特率、接收和发送数据字符格式和初始化FIFO(先进先出队列)。
串口和RC500都是基于IRQ中断,使用前,须对LPC2212中断选择寄存器进行配置,把串口和RC500的中断请求分配为IRQ模式。
2.2 射频卡与读写器通信模块
本系统采用M1(MIFARE 1)智能卡,本卡自带天线,内含加密控制逻辑和通讯逻辑电路,M1分为16个扇区,每个扇区为4块,每块16个字节,以块为存取单位,每个扇区有独立的一组密码及访问控制,可一卡多用。M1射频卡与读写器的通信流程图如图2所示。
复位应答(Answer to request):M1射频卡的通讯协议和通讯波特率是定义好的,当有卡片进入读写器的操作范围时,读写器以特定的协议与它通讯,从而确定该卡是否为M1射频卡,即验证卡片的卡型。
防冲突机制 (Anti-collision Loop):当有多张卡进入读写器操作范围时,防冲突机制会从其中选择一张进行操作,未选中的则处于空闲模式等待下一次选卡,该过程会返回被选卡的序列号。
选择卡片(Select Tag):选择被选中的卡的序列号,并同时返回卡的容量代码。
三次互相验证(Three Authentication):选定要处理的卡片之后,读写器就确定要访问的扇区号,并对该扇区密码进行密码校验,在三次相互认证之后就可以通过加密流进行通讯。(在选择另一扇区时,则必须进行另一扇区密码校验。)
RFID 射频 ARM 电路 滤波器 LCD 总线 电阻 振荡器 PIC 相关文章:
- 喷墨晶体管预示着柔性显示器件的诞生(01-14)
- 超市自助购物系统设计原理与实现,软硬件协同(11-30)
- 有关室内定位及导航设计方案纵览,包括RFID、DSP等(04-20)
- 低功耗非接触式射频读写器的设计与实现(12-24)
- 基于ARM的嵌入式RIFD读写器设计(08-10)
- 基于单片机的射频读卡器设计(08-17)