新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 基于FPGA的PCI總線接口原理研究與設計

        基于FPGA的PCI總線接口原理研究與設計

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

          在現代數據采集及處理系統中,ISA、EISA、MCA等擴展總線已無法適應高速數據傳輸的要求,而PCI局部總線以其優異性價比和適應性成為大多數系統的主流總線。

          PCI總線特點

          PCI總線寬度32位,可升級到64位;最高工作頻率33MHz,支持猝發工作方式,使傳輸速度更高;低隨機訪問延遲(對從總線上的主控寄存器到從屬寄存器的寫訪問延遲為60ns);處理器/內存子系統能力完全一致;隱含的中央仲裁器;多路復用體系結構減少了管腳數和PCI部件;給于ISA、EISA、MAC系統的PCI擴展板,減少了用戶的開發成本;對PCI擴展卡及元件能夠自動配置,實現設備的即插即用;處理器獨立,不依賴任何CPU,支持多種處理器及將來更高性能的處理器;支持64位地址;多主控制允許任何PCI主設備和從設備之間進行點對點訪問;PCI提供數據和地址的奇偶校驗功能,保證了數據的完整性和準確性。

          PCI接口開發現狀

          目前開發PCI接口大體有兩種方式,一是使用專用的PCI接口芯片,可以實現完整的PCI主控模塊和目標模塊接口功能,將復雜的轉換為相對簡單的用戶接口。用戶只要設計轉換后的總線接口即可,縮短了開發周期,缺點是用戶可能只用到部分PCI接口功能,這樣造成了一定的邏輯資源浪費,也缺乏靈活性,很可能增加板上的組件,導致產品成本的增加和可靠性的降低。二是使用可編程器件,采用的優點在于其靈活的可編程性,首先PCI接口可以依據插卡功能進行最優化,而不必實現所有的PCI功能,這樣可以節約系統的邏輯資源。而且,用戶可以將PCI插卡上的其他用戶邏輯與PCI接口邏輯集成在一個芯片上,實現緊湊的系統設計。當系統升級時,只需對可編程器件重新進行邏輯設計,而無需更新PCB版圖。現在已經有越來越多的用戶使用可編程器件如、CPLD等進行PCI設備的開發。

          本文所論述的PCI接口控制器是作為一個轉換接口工作于PCI總線與用戶設備之間,也可以認為其主要功能是起一個橋梁作用,完成用戶設備與PCI總線間的信息傳送。

          PCI接口設計

          在PCI板卡的設計中,核心設計有時序控制和配置空間兩部分。時序控制保證了板卡能按正常的PCI時序工作,配置空間部分保證了板卡的即插即用功能。在進行設計時本設計使用的軟件是Altera的MAX+PLUSII,開發芯片是EPF10K20RC240-3。

          ● PCI接口配置空間的實現

          PCI總線定義了3種物理地址空間,分別是存儲器地址空間、I/O地址空間和配置地址空間。

          配置空間是PCI所特有的一種空間,其目的在于提供一套適當的配置措施,使之滿足現行的和可預見的系統配置機構。配置空間是一長度為256字節并且有特定記錄結構的地址空間,可以在系統自舉時訪問,也可在其他時間訪問。該空間分為首部區和設備有關區兩部分,設備在每個區中只須實現必要的和與之相關的寄存器。配置空間的基地址寄存器提供了一種為設備指定存儲空間或I/O空間的機制。操作系統在啟動的時候要判斷系統中有多少存儲器、系統中的I/O設備需要多少地址空間,然后根據得到的結果,自動配置系統的存儲空間和I/O空間,實現設備無關管理。在本設計中,那些只讀的配置寄存器通過硬件連線到相應的值,因而不占用宏單元。通過配置寄存器,配置軟件可了解目標設備的存在、功能及配置要求。

          (1)廠商ID:此16位的只讀寄存器定義了設備的生產廠商,可以使用MACH芯片最初的生產廠商-AMD公司的ID值1022。

          (2)設備ID:該值由生產廠商分配以識別其產品,可為除00000000H和0FFFFFFFFH中的任意值。

          (3)命令寄存器:此寄存器控制了設備響應PCI訪問的能力。位1、6、8在本設計中被實現。本設計要求實現對存儲空間的訪問,位1設置為1,則設備響應PCI對存儲器訪問;位6控制了設備對奇偶校驗錯誤的響應;當位8被設置為1時,設備能夠驅動SERR線,0則禁止設備的SERR輸出驅動器。在這里當系統復位后,位1、6、8被設置為0。

          (4)狀態寄存器:此寄存器記錄了PCI相關事件的信息。在本系統中,位9、10、11、14、15被設計實現。位10∶9為設備選擇(DEVSEL#)定時,00B為慢速,01B為中速,10B為快速,11B保留。本設計這兩位被硬件連線為01B。當目標設備失敗時,位11被設置為1,當發生系統錯誤時位14置1,發生奇偶校驗錯誤時位15置1。

          (5)基地址寄存器:該寄存器用來映射設備的存儲器地址空間,與設備地址空間大小相應的低位被強制為0,因此在配置寫交易中,配置軟件通過對這個寄存器的所有位寫1,然后再讀出該寄存器的值來決定設備存儲器所占用的地址范圍。位0用來定義設備是存儲器映射還是I/O映射,在本設計中,位0被設為低以表明目標設備為存儲器映射的。

          如需要256字節的存儲空間,配置軟件寫入0FFFFFFFFH,本設備送出0FFFFFF00H,而配置軟件再次寫入基地址寄存器的值與本設備的0FFFFFF00H相與的結果就是基地址值,如配置軟件再次寫入0CD000000H則基地址值為0CD000000H。

          (6)類代碼寄存器:這個24位的只讀寄存器用來說明設備的基本功能和它的可編程接口。這里,此寄存器被強制為018000H,即設備為大容量存儲控制器。

          (7)首部類型寄存器:這個只讀寄存器的位0~6定義了首部格式,位7說明了設備為單功能還是多功能。首部類型1為PCI-PCI橋定義,首部類型2則用于PCI CardBus橋。在本設計中寄存器被強制為0來顯示其為單功能設備且首部類型為0。


        上一頁 1 2 3 下一頁

        關鍵詞: FPGA PCI總線接口

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 英德市| 华坪县| 临城县| 兴国县| 上饶县| 武胜县| 正镶白旗| 泾川县| 扬州市| 东安县| 台湾省| 连山| 西藏| 双江| 资阳市| 乐山市| 醴陵市| 威海市| 文安县| 定结县| 当阳市| 汶上县| 梨树县| 昌平区| 高州市| 法库县| 余庆县| 德州市| 蓝田县| 柳林县| 阳东县| 嘉峪关市| 雷波县| 台中市| 江源县| 响水县| 博罗县| 桃江县| 定安县| 德保县| 紫金县|