射頻識別系統(tǒng)中高頻讀寫器的研究與開發(fā)
文章出處:http://coolbang.cn 作者:吳戰(zhàn)克,孫多春,劉賀平 人氣: 發(fā)表時間:2011年10月16日
射頻識別RFID(Radio Frequency Identification)技術于20世紀80年代興起,最近幾年得到迅速發(fā)展。它是一種利用射頻通信方法實現非接觸式、快速、實時、準確地采集與處理信息的自動識別技術。RFID技術同互聯網技術相結合可以實現全球范圍內物品的跟蹤與信息的共享,被世界公認為21世紀十大最熱門的重要技術之一,具有廣泛的應用前景。近年來RFID產業(yè)在我國迅速增長,已滲透到人們生活、工作等各個方面。RFID市場分析預測顯示,我國RFID需求增長迅速。2006年10月份國家將射頻識別(RFID)技術列入863重大應用項目,科技部撥巨額資金重點支持我國RFID領域技術的突破與自主創(chuàng)新。
讀寫器在整個射頻識別系統(tǒng)中起著舉足輕重的作用。讀寫器的頻率決定了射頻識別系統(tǒng)的工作頻段,其功率直接影響射頻識別的距離。人們通過計算機應用軟件來處理對射頻標簽寫入或讀取其攜帶的數據信息,由于標簽的非接觸性,人們必須借助處于應用系統(tǒng)與標簽之間的讀寫器來實現數據的讀寫功能。這使得讀寫器在整個通信過程中起著關鍵性的橋梁作用。
1 讀寫器的組成結構
讀寫器可以簡化為兩個基本的功能模塊:控制部分和射頻部分。控制部分即MCU控制電路,其功能是由智能單元發(fā)出命令,對射頻部分回收來的信號進行必要的處理,將結果放入存儲單元。 而射頻部分由讀寫器芯片及外圍電路組成,包括發(fā)射器和接收器,其功能包括對發(fā)射信號進行調制、將數據傳送給電子標簽、接收并解調來自電子標簽的高頻信號。
2 硬件設計
2.1讀寫器芯片S6700
S6700是TI公司推出的一款具有代表性的多協(xié)議收發(fā)器芯片(RI-R6C-001A),工作頻率為13.56MHz;支持三種協(xié)議,分別是Tag-it協(xié)議、ISO/IEC 15693-2、ISO/IEC 14443-2(TYPE A);其典型電源為+5V,典型發(fā)射功率為200mW,確保電壓在3~5.5V之間;采用SSOP20封裝,內部集成有發(fā)射調節(jié)器和接收解調器,采用曼徹斯特編碼方式,有空閑模式(IDLE)、掉電模式(POWER DOWN)、工作模式(FULL POWER)三種電源管理功能;支持的調制方式有100%和10%~30%的ASK(Amplitude Shift Keying),這兩種調制方式可以通過應用軟件切換,調制深度通過改變與R_MOD端相連的電阻值來實現。
發(fā)射通道首先對DIN、SCLOCK的數據解碼,經過深度調制,再經過功率放大器和低通濾波器后輸出。接收通道對接收數據進行檢波,得到423/484/848kHz的信號,經解碼后輸出DOUT和M_ERR信號。
在讀寫過程中,ISO/IEO15693-2所規(guī)定的讀寫器與應答器通信物理層協(xié)議的接口全部由S6700實現,CPU通過同步串行接口(SPI)與S6700相連,CPU和S6700的通信接口有四根線:時鐘線(SCLOCK)、數據輸入線(DIN)、數據輸出線(DOUT)、出錯檢測線(M_ERR)。其中時鐘線是雙向的,在時鐘的上升沿鎖存數據。DOUT 除了有在接收數據期間的數據輸出功能外,還用來表征芯片內部FIFO 的情況。
2.2 模塊總體設計
控制部分MCU選用ATMEL公司的ATmega128芯片,是AVR單片機中功能很強的一款單片機,該芯片具有高性能、低功耗的 AVR 8 位微處理器,有先進的RISC結構,具有128KB的系統(tǒng)內在線可編程Flash。
所設計的讀寫器電路如圖4所示,包括三個部分:S6700典型應用電路及外圍輔助電路、CPU接口電路和天線等效電路。S6700各對應端分別連接在ATmega128的PE5、PA0、PA1、PB5引腳上。在S6700的TX_OUT端將調制好的信號輸出,經過一個LC網絡將信號諧振放大,然后經過一個T形網絡(雙L網絡) 進行通帶的選擇與阻抗的匹配,最后輸出到50Ω的天線。由于使用同一收發(fā)天線,在芯片的接收端應接一個2.2kΩ保護電阻,以避免發(fā)射信號電壓過大對芯片接收引腳造成損壞。R4、L4、C8、C9組成串聯諧振電路,匹配阻抗為50Ω,可調電容C9用來準確調整電路諧振點在13.56MHz。因為S6700與外部天線模塊是直接相連,考慮到加上同軸電纜后將使得接口電路的穩(wěn)定性下降,可通過調節(jié)C9得到13.56MHz且滿足50Ω的匹配阻抗。這一設計有利于讀寫器正確地收發(fā)信息。
3 通信協(xié)議
讀寫器與電子標簽通信采用半雙工模式,即一問一答模式。一般都是由讀寫器先發(fā)言(Reader talks first)。參照圖3所示的讀寫器的通信過程,必須符合控制器與收發(fā)器S6700之間的通信協(xié)議以及收發(fā)器S6700與電子標簽遵循的ISO15693-3規(guī)范。這里主要結合這兩部分的通信協(xié)議加以討論。
3.1 請求命令結構
控制器發(fā)送一個命令給收發(fā)器必須保證正確的時序。一個典型命令的結構是:起始位S1,8位命令,數據(域),結束位ES1。
(1)起始位S1、結束位ES1波形。
(2)命令字節(jié):規(guī)定收發(fā)器與電子標簽通信時的相關參數。
(3)數據:數據域內容由ISO15693-3規(guī)定,取決于命令內容。
命令參數是表明遠耦合器(VCD)到遠耦合IC卡(VICC)之間的通信規(guī)則,包括采用什么支持協(xié)議、脈沖位置編碼方式、調制深度、AM或FSK(頻移鍵控),例如:2EH,表示普通模式、支持射頻協(xié)議15693(1 out of 4)、AM調制方式、調制深度100%、返回數據采用高數據率。只有該命令字節(jié)的發(fā)送順序是高位在先,即MSB FIRST,其他的數據、標志位發(fā)送順序都是低位在先,即LSB FIRST。
以命令2E(00101110)和數據4E(01001110)為例的通信如圖所示。
每個數據位在SCLOCK的上升沿時發(fā)送。當SCLOCK的管腳保持高電平時,數據位的電平必須保持不變。命令模式有二種:普通模式和寄存器模式。表明所采用的射頻協(xié)議、調制方式及傳輸速率等是由命令序列中規(guī)定的還是由寄存器所設定的。普通模式指令包含所有參數,而寄存器模式不含這些參數,而是由預先寫入寄存器的數值決定,在該模式下,命令字節(jié)為1位,且該位為1。
15693-3 規(guī)定的請求格式如表1所示。
標志位(FLAG)用來指出將由VICC執(zhí)行的行為以及相應的域存在與否,相當于從VICC到VCD的通信規(guī)則,如采用何種方式:單/雙副載波頻率和高/低數據傳輸率等。比較上面兩個請求命令格式,注意到S1和ES1在收發(fā)器命令中已經存在,這里只需把15693命令序列中的標志位、命令碼、數據、CRC等內容放入收發(fā)器命令的數據域中。序列S1、CMD、DATA、ES1會發(fā)送一個“SOF,數據,EOF”給電子標簽,即從MCU至S6700,從S6700至VICC兩個請求過程,這兩個通信過程不是同時刻發(fā)送的,S6700中存在FIFO緩沖器,并在DOUT中體現出來。傳送的一些編碼等信息會從幀首中體現出來(可參考15693-2定義)。
3.2 響應結構
VICC響應的基本格式如表2所示。
起始位S2和結束位ES2:分別表示VICC響應數據的開始和結束。其波形如圖所示。
4 程序設計流程
4.1 Inventory 及程序流程
Inventory 請求指令和響應結構分別如表3、表4所示,其中請求Flags設置為06,即選擇16時隙(slot),不顯示AFI域。Inventory 命令代碼為01,防沖撞算法參數為Mask length和Mask value。只進行16時隙時,Mask length設為0。
命令流程是SOF/發(fā)送Inventory請求命令/EOF后進入slot 1, 以EOF切換到下一時隙直到slot 16為止。在一時隙中遇到有沖撞或是無標簽響應時,切換到下一時隙。Inventory流程圖如圖所示。
4.2 底層驅動實現
從以上分析 ISO15693 的通信協(xié)議和時序可知,閱讀器軟件設計主要工作是按照 ISO15693 的通信格式及時序要求進行接口驅動程序的編寫。下面是底層驅動的實現方法,主要是寫命令函數 Write_cmd(char cmd)、寫數據函數 Write_data(char data_buf)和讀數據函數Read_data(char *cdata)。
void Write_cmd(char cmd)
{for (char Bitnum=8;Bitnum>0;Bitnum--)
{PB5=0; //DIN=0
if(cmd&0x80)
PB5=1; //DIN=1
PE5=1; //SCLOCK=1
PE5=0; //SCLOCK=0
cmd<<=1;
}}
void Write_data(char data_buf)
{while(PA1); //FIFO Manage
for (char Bitnum=8;Bitnum>0;Bitnum--)
{ while(PA1);
PB5=0; //DIN=0
if(Data_buf&0x01)
PB5=1; //DIN=1
PE5=1; //SCLOCK=1
PE5=0; //SCLOCK=0
Data_buf>>=1;
} }
void Read_data(char *cdata)
{char Readin;
for (char Bitnum=0;Bitnum<8;Bitnum++)
{ while(PE5==1); //等待SCLOCK=0
while(PE5==0); //等待SCLOCK=1
Readin>>=1;
if(PA1==1) //判斷 DOUT=1?
Readin |=80; }
Cdata(bitnum)=Readin; }
本文主要介紹射頻識別系統(tǒng)中讀寫模塊的軟硬件設計,其讀寫器模塊通過PC機和串口通信軟件測試,實現了識別與數據通信,能成功用Inventory命令識別出電子標簽的唯一序列號。通過進一步地改進硬件設計與優(yōu)化軟件編程,將會進一步提高讀寫距離、識別效率、防沖撞性能和穩(wěn)定性。