關 閉

        新聞中心

        EEPW首頁 > 工控自動化 > 設計應用 > 一種機載TM總線接口設計

        一種機載TM總線接口設計

        作者: 時間:2010-03-23 來源:網絡 收藏

        POWERUP2_00為上電后或復位后的狀態(tài);XFERl6_1X~XFER00_1X為數據傳送狀態(tài);WAIT_00為出錯狀態(tài),該狀態(tài)結束的條件是MCTL與MMD發(fā)生傳輸沖突消失且消息傳送結束;在PAUSE_01狀態(tài)下插入等待;EOM_00為消息傳送的起始和結束狀態(tài)。主/從兩個狀態(tài)機合為一個狀態(tài)機后,MCS和主權控制狀態(tài)機控制作何種狀態(tài)機運行[M1,M2,M3]控制主狀態(tài)機的狀態(tài)轉換,從狀態(tài)機的狀態(tài)轉換由MCTL和MMD控制。
        2.4 USB
        USB接口芯片采用了ISP1581。ISP1581是Phil-lps 公司提 不應求的高速USB接口芯片,符合USB2.0規(guī)范。它的內部集成了數據收發(fā)器、串行接口引擎(SIE)、并行接口引擎(PIE)、FIFO存儲器(8 KB)、存儲管理單元(MMU)、微控制器接口和DMA(直接內存訪問)管理器。外部電路接口簡單,因ISP1581內部不帶有微控制器,需外接。本文的微控制器采用AT89C52單片機。USB硬件模塊主要包括ISP1581,AT89C52,總體框架結構如圖5所示。

        本文引用地址:http://www.104case.com/article/202554.htm


        ISP1581通過16位數據與FPGA相連,AT89C52負責控制數據的DMA傳輸。ISP1581與微控制器的通信通過一個高速(15 MB/s或15 Mword/s)的通用并行接口AD[7:O]實現,并具有高速DMA接口。
        2.4.1 USB接收數據模塊實現
        本文采用的USB器件是帶有DMA控制器的ISP1581,為了簡化電路,采用ISP1581的DMA主控制器方式。如圖6所示,當FPGA的FIFO滿標志為1時,單片機給ISP1581發(fā)送請求有效信號、寫信號和寫周期信號,給FIFO發(fā)送讀請求信號和讀周期信號,當讀出的數據達到預定的數目時,單片機把ISP1581請求信號設置為無效,等待下一組存儲數據。


        2.4.2 讀數據和并/串轉換
        單片機把接收的控制信號通過DMA傳輸通道把數據傳到FIFO中,其DMA傳輸過程和圖6相似,只要把DIOW改成DIOR,把rdreq改成wreq就可以了,然后通過FPGA的內部邏輯取出16位并行數據進行并/串轉換。

        3 系統軟件設計
        3.1 USB固件(Firmware)程序開發(fā)
        固件其實就是單片機的程序文件,主要完成設備初始化、USB協議標準請求處理以及其他應用程序。一般來說,固件程序的軟件結構可設計為基于中斷的分層結構,如圖7所示。

        在固件程序中,后臺的中斷服務例程(ISR)負責從ISP1581收集數據,當ISR收集到了足夠的數據時,通知前臺主程序循環(huán)數據已經準備好,由主程序循環(huán)進行數據的處理。以的批量傳輸端點為例,當從主機收到一個數據包,就會向為控制器產生一個中斷請求,微控制器立即響應中斷。在中斷服務例程中,固件程序將數據包從內部數據緩沖區(qū)轉移到循環(huán)數據緩沖區(qū),然后將數據緩沖區(qū)清零以使該端點可以接收新的數據包,這時微控制器可以繼續(xù)執(zhí)行當前更為緊急或者還未處理完的任務,例如讀取采集數據,然后返回到主循環(huán)中檢查循環(huán)緩沖區(qū)是否有新的數據,并進行處理。
        3.2 USB設備驅動程序開發(fā)
        驅動程序的基本功能是建立應用程序與USB接口之間的數據通訊。本設計采用Driver Works開發(fā)USB驅動程序。



        關鍵詞: 機載 總線 接口設計

        評論


        相關推薦

        技術專區(qū)

        關閉
        主站蜘蛛池模板: 韶山市| 南召县| 丹阳市| 阜南县| 东方市| 泾阳县| 沁源县| 屏东市| 酒泉市| 吉木乃县| 恩施市| 河源市| 常宁市| 茂名市| 郓城县| 宣武区| 娄底市| 砀山县| 丘北县| 南安市| 自贡市| 丰城市| 合作市| 广饶县| 班戈县| 沛县| 灵台县| 太仓市| 三亚市| 黔西| 永清县| 大石桥市| 吉安市| 西平县| 洪湖市| 临沂市| 五常市| 吴江市| 东城区| 塔河县| 邯郸市|