|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
1 d6 g5 ?4 r" `- Q) u- B* F$ v- h! I% g& `" V" U
. n% w6 Z) J1 h% d/ w' M, ?摘要:针对民用航空领域的应用需求,设计了一款基于S3C6410微处理器的RFID读卡器,给出了具体的硬件设计方案,详细介绍了LINUX下应用程序与底层驱动的工作流程,最后印证了系统运作的可靠性。该读卡器支持多种协议,支持LINUX操作系统,支持3.5寸触摸屏,可通过串口或者GPRS与上位机的SQL数据库通信,与其他采用单片机或者低主频ARM 微处理器的读卡器相比具有方便、快捷、用户体验良好等特性。
' A- G2 R6 z0 K8 T% B4 D$ J4 K% {5 j% U- _$ ~- \+ ]$ C
关键词:RFID RFID读卡器 电子标签 天线感应 射频驱动
; d |+ w+ y6 D. W8 q! p9 k# C/ {/ }) ]3 N4 L. r) |$ v! c6 n
0 引 言 随着国民经济的发展,航空日益成为民众所依赖的出行方式。航空货运物流系统中食品与商品种类多,安全要求高,交接手续繁杂,急需引入信息化管理,RFID技术的出现对于改善民航的物流管理有着积极的意义。航空物流RFID系统主要由电子铅封、读卡器和数据库管理系统等组成,现有的读卡器一般采用单片机系统(如STC89C54或MC9S12X128)或者STM32系列,它们的普遍缺点是:主频偏低,不支持操作系统且用户体验不佳,满足不了航空货运物流系统日益增长的应用需求。在航空食品和免税商品物流系统中,地勤与空乘人员急需操作简洁,反应快速,可随时通过无线网络上传数据的手持读卡器,从而加快物流速度,提高机场工作人员的工作效率。基于上述情况,提出了基于S3C6410的高主频的射频识别读卡器,它支持linux操作系统,支持多线程操作,操作人员可在多个读卡界面之间切换并且能随时随地通过GPRS上传数据到SQL数据库,不但大大降低机场工作人员的工作量,而且提高了航空物流的速度与安全性。 S+ ?/ B! o' T3 P2 y1 p( Q# \
! a" r! z5 y3 ~1 硬件设计方案 : K7 a) f+ k) E+ j: n
; o" b# ~' @. E% a) T7 ^8 I
系统结构如图1所示,系统采用了S3C6410微处理器,其稳定主频667MHz,最高主频可达800MHz.S3C6410集成了许多外设接口,如Camera接口、TFT-24bit真彩色LCD控制器、电源系统管理、4通道UART、32通道DMA、4通道定时器、通用I/O 端口、IIS、IIC 总线接口、USBHost、USB OTG(480Mbps)、3通道SD/MMC Host控制器及时钟生成PLL等。此外采用90nm COMS工艺,低功耗、简洁、精美且全静态设计使得S3C6410非常适合对成本、功耗敏感的应用。
' ]/ n+ x. q0 l+ _$ F+ g6 I
- G% f2 U c1 X( m& S& d. J3 O系统的显示屏采用3.5寸24位的真彩触摸TFT-LCD,分辨率最大可支持到1 024×1 024,本读卡器的分辨率为480×272.存储外设为Nand flash、24C64 和SD 卡。
) Y% A+ }+ e/ ^3 U* t
2 J3 v. b* j. e- k/ ]LINUX的Uboot、内核、开机图片和文件系统都烧写到nand flash中,24C64用于保存触摸屏校正参数和从电子标签中读取的数据。系统启动时S3C6410自动从24C64中读取校正参数,避免每次开机需校正屏幕。SD卡用于储存从电子铅封中读取的数据,此外汉字库与图标等文件也存放在SD卡中。 + y" h# k2 x$ ]
. \( s3 W& L- T; t/ G
3 S1 p) q3 i. I4 _
& x, U' C _/ ^图1 系统结构 7 }: v9 Z* w+ ?8 w3 Y
& Q) P, `" T3 Q6 N3 JS3C6410通过串口1驱动GPRS模块(SIM300)与上位机SQL数据库进行无线通信。SIM300是一款3频段GSM/GPRS模块,可在全球范围内的EGSM 900 MHz、DCS 1 800MHz、PCS 1 900MHz 3种频率下工作,能够提供GPRS多信道类型多达10个,并且支持CS-1、CS-2、CS-3和CS-4 4种GPRS编码方案。 $ @0 }" q+ i! [1 t* x
8 K& ^9 s% ~, t8 \0 O% p/ x
射频芯片采用NXP公司的CLRC632,它是一款针对13.56MHz的高集成无线射频IC,其管脚与MF RC500,MF RC530,MF RC531和SL RC 400均可兼容,可读写符合ISO14443协议的Type A 卡和Type B 卡,以及支持ISO15693协议的电子标签。RC632提供了2种通信接口,第一种是8位并口,可直接与各种8位微处理器相连接;第二种是SPI接口,本系统即采用了此通信接口,微处理器通过设置RC632的寄存器,便可实现射频操作(见图2)。 }% v R* {) q& W1 e) M
5 j/ G. {" |- C+ \: ?
/ [4 U* y; l% n- H
- U: E+ ^) m; i5 w. Y6 D9 [
图2 CL RC632原理
; r9 C) K: P5 C! T$ M7 ?6 W9 H
2 M2 `0 |0 @1 r; }3 eSPI总线是一种高速全双工同步的通信总线,它使用4条线:MISO 、MOSI、SCLK 、CS.其主要特点有:同时发出和接收串行数据;可当主机或从机工作;提供频率可编程时钟;发送结束中断标志;写冲突保护;总线竞争保护等。 7 J$ l. Q% T, P) ~ X* u# k
; L" w' b1 b2 F" r! `& d4 X9 f" lRC632总共有32个管脚,其中管脚22、23、24是寄存器的地址线,管脚13到管脚20是8位并口。当采用SPI方式通信时,管脚13即数据位D0为MISO,管脚22即地址线A0为MOSI,管脚24即地址线A2为CLK,D1到D7则不需要连接。此外,必须把A1与NCS置底电平,NRD与NWR置高电平。 5 |4 ~" ^4 b& _% O6 o; r
9 U$ j# O, Q. N4 S: ?5 a& i) J
RC632与天线之间通过3个管脚DTX1、DTX2与DRX进行通信,它会把调制好的13.56MHz的能量载波通过管脚DTX1、DTX2传输到天线,而天线则通过管脚DRX把13.56MHz的能量载波传输回RC632.一般采用2种方法将天线连接到RC632:直接匹配天线和50Ω匹配天线,本系统采用直接匹配的方式将RC632与天线连接,其包括了EMC低通滤波器、天线匹配电路与接收电路。
; ^ P: z+ b; J, h8 b' n
) }3 K: E& B2 C, h c: L/ j系统采用PCB环形天线,它的EMC低通滤波器用于滤除高频电磁波,天线匹配电路与天线进行阻抗匹配,以获得最大的功率传输,增大读卡距离,同时避免阻抗失配可能对电路造成的损害。经实测,天线的可操作距离为5~10cm.
' ]" R+ W7 m( j3 @) q1 V
6 c! r, p' C! J% w l, W2 读卡器的软件设计
4 M3 ]; y( f8 B; q( T9 n9 ~% \6 ~) o0 e1 k N% P4 C
读卡器的操作系统采用较稳定的Linux-2.6.30内核,文件系统为yaffs文件系统。软件分为2大部分:第一部分为QT程序,主要的功能是接受用户指令与显示图形界面;第二部分为射频驱动程序,它负责对RC632的寄存器进行操作,实现具体的射频功能。在编写射频读卡的QT应用程序之后,需把它整合到yaffs文件系统中。此外,还需裁剪linux内核,把驱动配置到内核配置单中。
# f) C2 J9 u$ R) H( M. J, w0 a% `0 O1 |& z5 n5 P
13.56MHz的RFID的典型协议有ISO-14443协议和ISO-15693协议。其中ISO-14443协议是非接触式IC卡标准协议,应用较ISO-15693更为广泛。下面将主要分析ISO-14443协议,ISO-14443由4个部分组成:第一部分,物理特性;第二部分,频谱功率和信号接口;第三部分,初始化和防碰撞算法;第四部分,通讯协议。
5 c8 s, s y. G# D4 t5 a) f6 x$ C' r
+ E( }8 y9 n: J! s' uISO-14443通信协议的报文可分成6个部分,如表1所示: 1 M- x2 i; h& w6 A9 t3 _1 Z
7 [9 _0 ]1 l$ \: J' s
表1 ISO-14443通信协议的报文数据格式 $ j% O2 T) x) K: [# v
3 D" N# f% Y. J! [* q( ^
6 G8 K7 D1 J! R
" t/ `, W8 r; G报头2字节固定为AABB,报文长度代表从节点到校验的字节之和,命令代码指明了报文的功能。常用的命令代码有0201(寻卡)、0202(防冲突)、0203(选卡)、0206(密码认证)、0208(读卡)、0209(写卡)等。 * h! r. o7 K0 h2 ]& s! s' B/ @+ l
9 R' A0 r B9 B- e; x& lQT程序在启动后,会在TFT-LCD上显示一系列的图标,分别为:寻卡、读卡、写卡、选择扇区等,在寻卡中包含了防冲突检测,它是读卡过程中非常重要的一个步骤[10-11].其流程如下,当用户点击TFT-LCD的寻卡图标时,触摸屏上会产生触摸点的位置信号,系统根据触摸点坐标判断其所在的区域,依据触摸的区域,系统做出相应的处理。QT程序把ISO-14443协议中的寻卡(0201),防冲突(0202),选卡(0203),密码认证(0206)都整合到1个子函数中。寻卡过程分为4个过程:
% z! I( c) ^1 e
( f! c [' [! I, a1 w1)搜索标签-即S3C6410通过串口1发送指令给RC632操作其中的相关寄存器进行天线操作。无论是否有卡在天线感应区域范围之内,RC632都会S3C6410回传相关数据,S3C6410收到数据后,进行判断是否有电子标签存在。 # J! t X! g/ h7 @6 L# G; c
9 g# P- ^( Y9 v2 i7 ?+ k) ?2)防冲突-如果在天线感应区域范围之内有一张以上的电子标签,那么读卡器就需要进行选择。RC632在防冲突后,将给微处理器传回4个字节的电子标签卡号。
) I- ]% c y) ?& I+ c$ m. y
$ V) I1 j# Z. c' a- T4 R7 D3)选择标签-如果要对相应卡号的电子标签进行操作,则微处理器就会发送命令给RC632,使其选中这张电子标签,以便进行下一步的读写操作。 9 S; F' p0 W5 O0 f2 R! \
4 ^3 W2 p' W# ^$ s: a4 j% ~4)密码认证-只有拥有正确密码的读卡器才能读写相应的电子标签。
0 P8 ]8 w! m; b
! e; N6 @: E n1 H! H! k选择扇区后,如进行读卡操作,则直接点击读卡图标,如进行写卡操作的话,则还需用输入数据。如图3所示。
, b' R( Y/ o0 j, L) v) N9 V
" g6 u; V K5 z6 c: y$ g$ X
. a2 V+ {6 M5 X1 o
* n$ j, R$ H6 t8 y图3 QT应用程序流程 4 l2 o: T1 ?9 h8 [% p6 l+ J' t Y
射频驱动程序在收到应用程序发来的报文后,除去报头与校验位,通过case语句判断命令代码,然后跳转到相应的子程序,子函数通过驱动程序对RC632的寄存器进行设置,实现射频操作。读取RC632数据时,MOSI线的第一个字节设置模式与地址:具体来说,第0位设置为1,第1位到第6位为地址,第7位设置为0,MOSI线的其他字节均按此设置。MISO线的第一个字节保留,从第二个字节开始为从RC632返回的数据。对RC632写入数据时,MOSI线的第一字节代表地址,从第二个字节开始为写入RC632的数据,此时MISO线没有启用。
6 G5 Q0 m* D4 y* ^5 K7 X
1 e: x7 l9 ?9 Q/ p驱动RC632时,首先设置信道校验寄存器,把第0,2比特置1(启用奇偶校验与CRC校验),然后把控制寄存器第3比特清零(不启用数据加密),接着把0x07写入比特结构控制器,最后一步是设置发射控制寄存器为0x03(在管脚TX2发送未经调制的13.56MHz连续载波)。设置完寄存器状态后,RC632便可与电子铅封进行通信。通信过程中的寄存器操作包含以下几个步骤: ! x' A4 x9 e* ^5 n8 g4 |
; K- s$ }6 Q7 F: n# X. Z' T1)置中断使能与中断请求2个寄存器为0x07,设置命令寄存器,取消当前命令;2)清除FIFO BUF读写指针(即FIFO[6:0]清零),设置中断使能寄存器,提示标志位已经设置;3)依次把数据写入到FIFO BUF,把数据从天线发送出去;4)设置命令寄存器,激活要执行的命令,读取错误标志寄存器,判断是否出错;5)等待规定的时间,然后读FIFO BUF,把天线接收的数据读取到RC632中;6)置中断时能与中断请求2个寄存器为0x07,设置控制寄存器,停止定时器,设置命令寄存器,取消当前命令。 * p. X. k3 k9 N) y/ C
1 c t9 P! J" d" E0 s! n/ r
3 现场实测和上位机SQL数据库通信实例
- b5 V: n! T/ U- D1 `; k- Z, h+ ^. V( ?4 v
在现场测试过程中,分别对电子铅封的扇区4,扇区16,扇区33各进行了20次操作,其中只有对扇区16的一个写过程中出现了数据丢失情况,这显示出了稳定的操作性能。表2是读卡器对货物的电子铅封进行数据写入与读出的实例:先写入内容11220003,然后再把写入的内容读出,其操作的扇区为04号,设置密码为FFFFFFFFFF.
5 j7 |/ \' J2 u# o, a3 V* l
2 s8 k- N; `) F9 g5 F1 n) K+ N" @读出的数据传输到上位机SQL 数据库后的界面如图4所示。
) a( ^2 D( I; D8 {/ \+ v9 P: g& `5 s- M- R) c. P. {4 |
表2 现场实测电子铅封读写数据 1 o3 C: m* i7 F: P) a/ X
" n$ T: V# m3 j$ J
" g3 k* g' O" b5 v" r7 O& G, _
% r. S- b$ N# ?. z
: ]* k- B7 S' c9 Y3 b% _ }% A/ Z' y! Z' p( _2 q7 m- ~0 h ^9 t
* g+ r: U# `/ T- O8 \7 b3 o8 e* e8 Z图4 数据传输到数据库的界面 % G Z# W a* }
! s; u& P( H _ Z: w
4 结 论 9 K- a# J, s1 l+ j* }7 f# K
" b, H' Y$ ]* y0 m1 O6 W( ^+ `提出了基于S3C6410微处理器的高主频射频识别读卡器,实现了读卡、写卡与上传数据到数据库的功能。实验表明该读卡器具有良好的稳定性与实用性,适合于民用航空领域的应用。该读卡器系统对于民航物流的发展提高具有一定的参考价值和应用前景。
9 `% b3 e, X3 w, Z0 V" s; N9 M! t C
( W' v5 e" c2 P& x% \. i
4 A/ {. i2 ~0 \0 q: A |
|