天天被操天天被操综合网,亚洲黄色一区二区三区性色,国产成人精品日本亚洲11,欧美zozo另类特级,www.黄片视频在线播放,啪啪网站永久免费看,特别一级a免费大片视频网站

現在位置:范文先生網>理工論文>電子通信論文>基于ARM的IEEE802.11bMAC層協議IP核設計

基于ARM的IEEE802.11bMAC層協議IP核設計

時間:2023-02-21 00:16:19 電子通信論文 我要投稿
  • 相關推薦

基于ARM的IEEE802.11bMAC層協議IP核設計

摘要:介紹了IEEE 802.11b MAC層協議IP核設計,提出了基于32位微處理器ARM7DMI的系統(tǒng)設計方案,闡述了系統(tǒng)硬件平臺的設計、結構及主要模塊單元的功能;給出了利用形式描述語言SDL進行MAC層協議設計開發(fā)的完整設計流程;闡述了軟件的層次結構,并針對設計中遇到的代碼生成器的選擇、設計優(yōu)化、與實時操作系統(tǒng)(RTOS)的集成和環(huán)境函數編寫等問題進行了深入討論。

    關鍵詞:ARM 802.11, IP

基于ARM的IEEE802.11bMAC層協議IP核設計

目前各種協議的設計實現,大多數是基于微處理器、微控制器或DSP的嵌入式系統(tǒng)。ARM是ARM公司推出的高性能32位RISC微處理器,具有業(yè)界領先的體系結構,被廣泛6應用于各種系統(tǒng)設計中;贏RM的開發(fā)通常使用C、C++或匯編語言。筆者采用了更高級的形式語言SCL,大大縮短了協議的開發(fā)周期并提高了設計的可移植性。無線局域網是目前通信領域的一個研究熱點,無線局域網的協議是非常典型的協議。本文將詳細討論使用SDL進行無線局域網802.11b MAC層協議的設計以及基于微處理器ARM7TDMI的系統(tǒng)實現方案。其設計方法具有普遍意義。

1 系統(tǒng)硬件平臺設計及功能描述

整個系統(tǒng)硬件平臺的設計主要分MAC層和物理層兩部分。硬件平臺的結構框圖如圖1所示。其中MAC層部分主要圍繞32位微處理器ARM7TDMI和AMBA總線設計,其主要的單元模塊和功能如下:

·PCMCIA接口,此接口為硬件平臺和主機的通信接口。其設計遵循PC Card標準(版本5)。

·WEP算法加解密模塊,此模塊用硬件實現IEEE 802.11b MAC層協議定義的有線網等效加/解密算法。

·物理層數據接口,此接口用于完成物理層與MAC的數據交互操作,內部設計有發(fā)關和接收FIFO,用來完成數據的接收發(fā)送緩存。

·物理層控制接口,此接口用于完成MAC層對物理層的控制功能。例如無數據收發(fā)時,可以通過此接口控制物理層部分轉入節(jié)能狀態(tài)。

·存儲器管理模塊,此模塊用于實現對系統(tǒng)所有存儲器(如FLASH、ROM、RAM)的管理,處理器通過此模塊對存儲器進行訪問。

·中斷控制邏輯,此模塊用于對系統(tǒng)中各模塊產生的中斷信號進行控制和管理。

·微處理器單元ARM7TDMI,用于完成與主機的通信,負責整個系統(tǒng)的控制和管理。

圖1 硬件平臺結構框圖

    物理層部分的設計主要分為四個單元:

·基帶處理單元,主要用于完成基帶信號的處理操作,如Rake接收、均衡、數/模、模/數轉換等。

·中頻處理單元,主要用于完成信號的調制解調處理。

·混頻處理單元,主要用于完成射頻中頻的變頻處理。

·射頻處理單元,主要完成射頻信號的功率放大功能。

MAC層的主要模塊單元(外部存儲器單元除外)用Verilog硬件描述語言設計并用Xilinx的FPGA Vertex II xc2v3000編程實現。物理層部分則主要用Intersil公司的PRISM芯片組及少量外圍電路設計實現。

2 SDL及軟件開發(fā)平臺

SDL是一種層次化的描述語言,采用結構化和自頂向下的設計原則,把系統(tǒng)規(guī)范分為系統(tǒng)、塊、子塊、進程、服務和過程幾個層次進行描述。系統(tǒng)、塊和子塊是靜態(tài)描述,用于描述系統(tǒng)的結構;進程、服務和過程是動態(tài)描述,用于描述系統(tǒng)的行為。SDL的理論模型是通信擴展有限狀態(tài)機,每個進程都是一個通信擴展有限狀態(tài)機。

SDL與常用的高級語音有很好的接口,如可以從SDL描述的系統(tǒng)規(guī)范直接導出C、CHILL甚至VHDL語言,以嵌入式系統(tǒng)和軟硬件混合系統(tǒng)實現;在進行規(guī)范定義時,SDL又允許嵌入高級語言,如C/C++語音、義等。因而可以在多個層次上對系統(tǒng)進行準確的規(guī)范和描述。因為SDL的上述特性,目前已被越來越多地用于協議軟件的開發(fā)實現。

本文選用Telelogic公司的SDT4.3和ARM公司的ADS1.2作為主要的軟件開發(fā)工具。使用SDT進行協議軟件的開發(fā)步驟如圖2所示。
(范文先生網m.gymyzhishaji.com收集整理)
    在系統(tǒng)行為定義階段,要特別注意代碼生成器對SDL設計的結束,例如對于C advanced生成器不支持信道子結構、信號細化等;對于C micro生成器不支持連續(xù)信號、服務、優(yōu)先輸入/輸出等。在系統(tǒng)行為分析仿真調試階

段,使用C basic/C advanced代碼生成器產生系統(tǒng)代碼,與SDT提供的仿真內核一起編譯連接,得到系統(tǒng)行為的仿真醋,然后可以使用text、SDL、MSC等多種跟蹤方式進行仿真調試。在系統(tǒng)行為驗證時,使用相同的代碼只不編譯連接時加入SDT提供的驗證內核,可得到系統(tǒng)行為的驗證模型,可以使用自動狀態(tài)空間遍歷、覆蓋率分析等方式進行系統(tǒng)行為的驗證。仿真和驗證都無環(huán)境函數,由仿真器和驗證器充當系統(tǒng)的環(huán)境,產生和接收與系統(tǒng)交互的信號。在系統(tǒng)行為經仿真驗證正確后,可以應用C advanced/C micro生成器產生面向應用的系統(tǒng)代碼和環(huán)境函數。

應用SDT生成的代碼經過適當修改和處理后可以輸入ARM開發(fā)工具ADS,進行嵌入式系統(tǒng)的開發(fā),其方法和設計流程詳見后。

3 系統(tǒng)軟件的設計和開發(fā)

系統(tǒng)的軟件設計主要分為三部分:協議軟件、驅動軟件和接口軟件。其中協議軟件部分主要用于實現IEEE 802.11bMAC層協議定義的各種服務(如授權、關聯等)和算法(如DCF、PCF、時鐘同步算法等)。這一部分軟件采用圖2所示的設計流程,完全使用形式描述語言SDL進行設計實現,并使用SDT的代碼生成器將SDL的系統(tǒng)描述換成面向應用的C/C++代碼。驅動軟件部分主要用于實現對硬件設備的驅動功能。如PCMCIA接口驅動,這一部分軟件用C/C++語言進行設計實現。接口軟件部分主要完成SDL轉換出的系統(tǒng)代碼與RTOS及硬件平臺的接口功能。這一部分軟件借用于代碼生成器產生的環(huán)境函數,用C/C++語言設計實現。軟件部分的層次結構如圖3所示。

4 與ADS接口及軟件后端開發(fā)

從SDL轉化出C/C++代碼后,可使用ARM的開發(fā)工具ADS進行后續(xù)的軟件開發(fā)。其與SDT工具的接口及開發(fā)流程如圖4所示。

由SDL描述轉換出的C/C++代碼,與環(huán)境函數、Runtime庫以及C/C++庫一起用ARM的編譯器編譯,產生面向ARM的可執(zhí)行程序。其中,環(huán)境函數主要用描述系統(tǒng)運行的具體物理環(huán)境。由SDT工具根據用戶所作的系統(tǒng)描述自動生成一個結構框架,然后用戶根據的采用的具體硬件平臺環(huán)境編輯這個文件,以描述真實的系統(tǒng)工作環(huán)境。Runtime庫主要包含SDL預定義的數據類型、操作符的實現、調度函數、運行錯誤處理等信息。SDT工具提供簡單的Runtime庫。C advanced/C micro代碼生成器都有各自對應的Runtime庫。C/C++庫是ADS本身攜帶的函數庫,主要包含ISO標準定義的C/C++庫函數。

在使用ARM編譯器編譯后,產生ARM的目標文件(.o文件)。如果還有用ARM匯編指令編寫的匯編程序,可用匯編器(armasm)匯編,產生相應的目標文件。把所有的目標文件用鏈接器(armlink)鏈接,便可得到能在ARM7TDMI處理器上執(zhí)行的映像文件(.aof文件)。這時可以用ADS提供的調試工具AXD進行程序的調試。

因為SDL的系統(tǒng)設計在高層進行了仿真和驗證,所以調試的主要工作集中在驅動、中斷和環(huán)境函數的調試上。對SDL系統(tǒng)的調度主要是通過仿真確定對系統(tǒng)性能影響嚴重的模塊并對其進行優(yōu)化以及系統(tǒng)在實時運行狀態(tài)下能否滿足設計要求。如果在調試中發(fā)現問題需要修改SDL的系統(tǒng)設計,可重新執(zhí)行如圖4所示的流程,直到滿足設計要求。

5 問題及分析

(1)代碼生成器的選擇問題。SDT提供三種代碼生成器,即C basic、C advanced和C micro。其中C basic是最簡單的代碼產生器,一般只用于在SDT開發(fā)環(huán)境中仿真系統(tǒng)的行為。C advanced和C Micro是面向應用的代碼產生器,可以產生高效的代碼。C advanced支持幾乎所有的SDL概念,對SDL設計的約束較少。C micro可以產生性能更優(yōu)越、占用存儲空間更小的代碼,代價是對SDL設計的約束較多,例如不支持使能條件、連續(xù)信號、過程的繼承等。

(2)設計優(yōu)化問題。在進行系統(tǒng)設計時,應注意的設計要點有:當輸出信號時,應帶上接收進程的PID,這樣可以減少對信號進行路由的開銷;信號應盡量少帶占用大量存儲空間的參數,因為在信號傳遞時同時復制信號的參數,占用大量存儲空間的參數將占用過多存儲空間并引起附加延時;兩個狀態(tài)之間的傳輸操作不宜過多,否則會帶來較大延時(可以用實時仿真確定影響時延的關鍵路徑并進行優(yōu)化);如果系統(tǒng)中有比較復雜的模塊,對時延又有嚴格要求,可以用C/C++或匯匯編單獨編寫,也可用硬件完成,如圖1的WEP算法模塊。

(3)與RTOS的集成問題。用戶可以不使用RTOS,而使用SDT提供的缺省內核程序,也可以自己編寫所需的調度算法、內存管理、中斷處理等。SDT工具直接支持的RTOS有Solaris(Posix 4)、Win32、VxWorks和OSE delta。SDT提供三種與RTOS的集成方式,即松集成、線程集成和緊集成。松集成把整個系統(tǒng)映射為OS的一個任務,使用SDT提供的標準內核進行調度,每次進行一個完整的傳輸。因此松集成調度的最大延時是SDL設計中狀態(tài)之間傳輸的最長時間。緊集成把每個進程映射為一個OS的任務,可以使用OS的調度算法,給不同的任務以不同的優(yōu)先級執(zhí)行,因而性能好于松集成。線程集成則是兩者的折衷。

(4)環(huán)境函數的編寫。環(huán)境函數主要是完成四個函數的編寫。XInitEnv():主要用于完成系統(tǒng)的初始化操作。XInEnv():主

要用于接收來自硬件或RTOS的信號并轉換成SDL系統(tǒng)所需要的信號。調度器每隔一段時間輪詢一次xInEnv()函數,檢查是否有信號輸入。如果發(fā)現有信號輸入則發(fā)送適當信號給SDL系統(tǒng)。XInEnv()函數中不能使用阻塞函數,如getchar()等。阻塞函數會妨礙調度器處理SDL系統(tǒng)。XOutEnv():主要用于接收來自SDL系統(tǒng)的信號并轉換成對RTOS的信號或對硬件的操作。當SDL系統(tǒng)有信號輸出時,則調用xOutEnv()函數,根據用戶編寫的代碼產生相應的物理信號或硬件操作。XCloseEnv():用來完成關閉環(huán)境的操作。


【基于ARM的IEEE802.11bMAC層協議IP核設計】相關文章:

基于ARM平臺的MAC協議IP核設計08-06

基于ARM的嵌入式TCP/IP協議的實現08-06

基于ARM7核處理器VxWorks系統(tǒng)BSP設計08-06

異步串行通信接口的IP核設計08-06

可復用SPI模塊IP核的設計與驗證08-06

基于ARM核的AT75C220及其在指紋識別系統(tǒng)中的應用08-19

基于ARM體系的嵌入式系統(tǒng)BSP的程序設計08-06

一種可進化IP核的設計和實現08-06

I2C器件接口IP核的CPLD設計08-06