新聞中心

        EEPW首頁 > EDA/PCB > 設計應用 > 一款基于FPGA的RFID閱讀器設計

        一款基于FPGA的RFID閱讀器設計

        作者: 時間:2010-12-06 來源:網絡 收藏

        軟件部分程序執行流程

        圖4 軟件部分程序執行流程。

          4 的實現

          本文使用日立產射頻模塊、2.4GHz 電子標簽、Xilinx Spartan-3 LC1500 開發板、Xilinx PlatformStudio 7.1i 集成開發環境和Xilinx ISE 7.1i 集成開發環境硬件連接見圖5。 開發板設計一個串口連接射頻模塊,用于向射頻模塊發送標簽操作命令和接收標簽的信息。圖中URAT 為設計的串口,G16和H16 為 的I/O 引腳,74LS04 為電平轉換模塊。1602 為液晶顯示模塊。

        硬件連接

        圖5 硬件連接。

          4.1 中的CPU 模塊

          嵌入式CPU 的設計是SOC 設計的核心。FPGA可以方便地實現嵌入式CPU 核[6],在FPGA 器件中嵌入式CPU 有硬核和軟核兩種,如Xilinx 的VirtexII器件中含有CPU 硬核POWERPC401 核,Altera 的Excalibur 器件中含有PowerTrace 核;軟核如Xilinx的PicoBlaze 和MicroBlaze, Altera 的Nios, Tensilica的Xtensa 和OpenCores 的OpenRISC 軟核。硬核提供了豐富的指令和功能,但不能改變其電路結構。硬核具有高速和高效的優點,但熟悉和充分掌握硬核的使用比較困難,硬核并不是所有的FPGA 器件都有的。而軟核是用VHDL 語言設計實現,設計者可以根據具體需要進行設計或對軟核進行適當的修改,適當增加或減少硬件電路,如寄存器數量,RAM容量和總線寬度等,,提高芯片利用率,,還可以提高CPU 運行速度,并且軟核還具有使用靈活和低成本的特點。本文使用的是Microblaze 軟核。

          4.2 實現過程

          在集成開發環境中添加LCD、 URAT 和DIP的軟件IP 核,其中DIP 用于模擬鍵盤輸入。然后配置各個接口IP 核的總線類型、地址范圍和外部端口,在項目的UCF 文件中配置接口IP 核的引腳和FGPA 的I/O 的連接關系。

          從串口接收數據有兩種方法:一種是采用定時器讀;另一種采用串口的中斷服務程序來讀。采用定時器消耗資源比較大,本文采用串口中斷的方法,當串口有數據到達時,激活串口中斷服務程序,在中斷服務程序中讀出串口緩沖區的數據,然后寫道FIFO 對列。

          URAT 中斷服務程序的主要代碼如下:

          Void XUartLite_InterruptHandler ( XUartLite *

          InstancePtr)

          /*判斷Uart 緩沖區是否為空*/

          if(!XUartLite_mIsReceiveEmpty(RS232_BASEADD

          R))

          {

          /*接收URAT 數據*/

          Data=XUartLite_RecvByte(RS232_BASEADDR);//

          /*寫入FIFO 緩沖隊列*/

          Add_Queue(Data);

          }

          其中FIFO 緩沖隊列是由一個自定義的數據結構和對它的操作實現的。

          下面是主程序的主要代碼。



        關鍵詞: FPGA RFID 閱讀器

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 柳江县| 金堂县| 渭源县| 娄烦县| 侯马市| 阿瓦提县| 景德镇市| 府谷县| 舒城县| 雷波县| 南木林县| 贺兰县| 革吉县| 南投县| 贡山| 仁布县| 鲁甸县| 高要市| 安丘市| 富锦市| 井陉县| 大新县| 武冈市| 依安县| 南江县| 乳山市| 陇西县| 彭泽县| 丽江市| 涟水县| 昭平县| 陵水| 建湖县| 玉山县| 安岳县| 玛曲县| 岳普湖县| 衡山县| 博罗县| 安化县| 阳春市|