《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > 基于FPGA的PCI接口設計

基于FPGA的PCI接口設計

2008-12-30
作者:宋克柱 楊小軍 王硯方

  摘? 要: 介紹一種使用PCI宏核邏輯進行的更加簡單高效的PCI接口設計方法。該方法將PCI接口和PCI用戶邏輯集成在一片FPGA里,可以對整個邏輯進行仿真調試,大大縮短了開發周期、提高了系統集成度和性能。重點敘述了ALTERA公司提供的32位TARGET接口宏核pci_t32的原理和結構,分析了時序設計要點,給出了典型應用的邏輯設計" title="邏輯設計">邏輯設計框圖和注意事項。

  關鍵詞: PCI總線? 接口? 現場可編程邏輯陣列? 仿真

?

1 PCI總線及其接口概述

  PCI總線是高速同步總線,具有32bit總線寬度,工作頻率是33MHz,最大傳輸率為132Mbyte/s,遠遠大于ISA總線5Mbyte/s的速率。PICMG(PCI工業計算機制造商聯盟)制定的更加堅固耐用的Compact PCI總線規范,支持64位總線寬度,66MHz工作頻率,最大傳輸率為528Mbyte/s。基于PC機的高速數據采集系統和各種虛擬儀器,幾乎都選擇了PCI總線。在現代高速通訊、測試等領域的嵌入式應用中,Compact PCI總線大有超過VME和VXI總線的趨勢。PCI的高性能、高效率以及與現有標準的兼容性和充裕的發展潛力,是其它總線所不能及的,被計算機界公認為最具高瞻遠矚的局部總線標準。

  PCI總線接口相對其它總線接口來說是比較復雜的,它不但有著嚴格的同步時序要求,而且為了實現即插即用和自動配置,PCI接口還必須有許多配置寄存器" title="配置寄存器">配置寄存器。根據用戶設備的性質不同,PCI設備分為MASTER(主設備)和TARGET(從設備),因此PCI接口類型也就分為MASTER和TARGET兩種接口。概括地說,PCI接口主要包括PCI標準配置寄存器(64字節)、PCI 總線邏輯接口、用戶設備邏輯接口、數據緩沖區等。

  作為一般應用設計工程師,為縮短開發周期,沒有必要自己去設計全部的復雜的接口邏輯,甚至可以不必完全理解PCI規范的細節,就能進行PCI用戶設備的設計。目前,市場上有一些專用PCI接口芯片,如AMCC公司的S5920(TARGET接口)、S5933(MASTER接口)等。使用這些專用PCI接口芯片,設計者只需要使用地址線、數據線以及少數幾個讀寫控制信號,就能實現PCI總線與PCI用戶設備之間的連接,類似ISA總線接口那么簡單方便。

  隨著FPGA(現場可編程邏輯陣列)技術的快速發展,萬門以上乃至幾十萬門邏輯陣列的使用越來越普遍,FPGA的單片價格也大幅度下降。與專用PCI接口芯片相似,很多FPGA制造商都提供了PCI接口宏核邏輯(PCI MegaCore)。設計者可以將PCI用戶邏輯與PCI MegaCore集成在一片FPGA里,并且可以在頂層通過仿真來驗證PCI接口以及用戶邏輯設計的正確與否,這樣可以大幅度提高調試速度,縮短開發周期,提高電路板的集成度和系統的性能。

  ALTERA公司提供了多種不同功能的PCI MegaCore,例如:pci_a(帶有DMA的32位MASTER/TARGET接口),pci_mt64(支持64位的MASTER/TARGET接口),pci_mt32(32位的MASTER/TARGET接口),pci_t64(支持64位的TARGET接口),pci_t32(32位的TARGET接口)等。不同的PCI MegaCore占用的資源是不同的,設計者可以根據PCI用戶設備的需求來選擇。

  本文將介紹ALTERA公司提供的最簡單的32位PCI TARGET接口宏核邏輯pci_t32。重點介紹利用pci_t32進行PCI接口設計的方法及應用注意事項,并給出具體設計實例。其它PCI MegaCore的設計方法與此相類似。本文不介紹有關PCI規范的細節內容。

2 Pci_t32 MegaCore的內部結構及外圍信號

  Pci_t32 是ALTERA公司提供的最簡單的32位PCI TARGET接口宏核邏輯,支持33MHz和66MHz的PCI時鐘。

  Pci_t32內部結構包含如下幾個模塊:

  PCI總線配置寄存器,是符合PCI規范2.2版規定的所有配置寄存器。配置寄存器用于識別設備、控制PCI總線功能、提供PCI總線狀態等。

  奇偶校驗模塊,用于對數據、地址、命令等進行奇偶校驗。

  PCI側TARGET控制模塊(PCI target control block),用于控制pci_t32(作為TARGET)與PCI總線的各種操作。

  用戶設備側TARGET控制模塊(local target control block),用于控制pci_t32(作為TARGET)與用戶邏輯的各種操作。

  用戶設備側地址/數據/命令/字節使能模塊,接收和輸出用戶側的所有地址/數據/命令/字節使能等信號。

  Pci_t32內部功能模塊及周邊信號如圖1所示。左側PCI信號是符合PCI規范的標準信號,在這里不多加解釋。下面重點介紹右側用戶邏輯接口local信號:

?

?

  l_adi[31:0],local側地址、數據輸入信號" title="輸入信號">輸入信號。

  l_cbeni[3:0],local側命令、字節使能輸入信號,位定義及時序符合PCI規范。

  l_dato[31:0],local側數據輸出信號。

  l_adro[31:0],local側地址輸出信號。

  l_beno[3:0],local側字節使能輸出信號,位定義及時序符合PCI規范。

  l_cmdo[3:0],local側命令輸出信號,位定義及時序符合PCI規范。

  lt_rdyn,local側目標設備準備好信號(target ready),對pci_t32是輸入信號。

  lt_discn,local側目標設備通過置低該信號請求pci_t32向PCI 側主設備發出斷開連接信號(disconnect request),對pci_t32是輸入信號。

  lt_abortn,local側目標設備通過置低該信號來請求pci_t32向PCI 側主設備發出放棄操作信號,對pci_t32是輸入信號。

  lt_irqn,local側目標設備中斷請求信號,對pci_t32是輸入信號。

  lt_framen,PCI主設備通過pci_t32讀寫local側目標設備時,pci_t32置低該信號(輸出信號)。

  lt_ackn,當為目標寫操作時,PCI_t32置低該信號(輸出信號),表示數據有效;當為目標讀操作時,PCI_t32置低該信號(輸出信號),表示已準備好讀數。

  lt_dxfrn,輸出信號,表示local 目標設備數據傳輸成功。

  lt_tsr[11:0],輸出信號,控制local目標設備狀態寄存器。

  cmd_reg[5:0],配置命令寄存器輸出信號。bit0,I/O" title="I/O">I/O操作使能;bit1,Memory操作使能;bit2,保留;bit3,memory寫無效使能;bit4,奇偶校驗出錯響應使能;bit5,系統出錯響應使能。

  stat_reg[5:0],配置狀態寄存器輸出信號。

3?讀寫操作時序分析與設計要點

  pci規范中定義了兩種讀寫操作,即Memory和I/O的讀寫。pci_t32的讀寫操作包括:32位的Memory單周期" title="單周期">單周期讀寫、Memory猝發讀寫、I/O單周期讀寫以及配置讀寫。Pci_t32 的Memory讀寫分為單周期和猝發兩種模式,而I/O的讀寫只有單周期模式。所謂猝發模式,即在給出首地址后,主設備連續讀寫多個數據,用戶設備應能對首地址自動加1。配置讀寫是指pci主設備對pci_t32的配置空間寄存器進行讀寫操作,pci主設備與pci_t32之間的接口是無縫連接。本文只分析32位Memory單周期讀寫時序,其它模式的讀寫時序大同小異,此略。

3.1? Memory 讀操作

  pci_t32的單周期memory read操作時序如圖2所示。

?

?

  時序分析及用戶邏輯設計要點:pci主設備在第2個clk給出要讀的目標地址ad[31:0]和Memory讀命令cben[3:0]=6,pci_t32在第3個clk向用戶設備給出讀目標地址l_adro[31:0]和Memory讀命令l_cmdo[3:0]=6。用戶設備要對l_cmdo[3:0]譯碼來判斷是何種操作,對l_adro[31:0]譯碼來選擇目標地址。在lt_framen輸出為低的下個時鐘周期,若用戶設備邏輯準備好要輸出的數據,可以置低lt_rdyn。若用戶邏輯沒有準備好,可以延遲置低lt_rdyn來產生延時等待周期。當lt_dxfrn輸出為低電平時(第6個clk),pci用戶設備必須將目標地址的數據D0放到l_adi[31:0],用戶邏輯可以用lt_dxfrn來作為存儲單元的輸出使能信號(/Output Enable)。這樣,在第7個clk的上升沿pci_t32可以采樣到數據D0。在第8個clk的上升沿pci主設備可以得到數據D0。

3.2 Memory寫操作

  pci_t32的單周期memory 寫操作時序如圖3所示。

?

?

  時序分析及用戶邏輯設計要點:pci主設備在第2個clk給出要寫的目標地址ad[31:0]和Memory寫命令cben[3:0]=7,pci_t32在第3個clk向用戶設備給出寫目標地址l_adro[31:0]和Memory寫命令l_cmdo[3:0]=7。用戶設備要對l_cmdo[3:0]譯碼來判斷是何種操作,對l_adro[31:0]譯碼來選擇目標地址。在lt_framen輸出為低的下個時鐘周期,若用戶設備邏輯準備好接收pci_32t寫的數據,可以置低lt_rdyn。若用戶邏輯沒有準備好,可以延遲置低lt_rdyn來產生延時等待周期。當lt_dxfrn輸出為低電平時(第7個clk),pci_t32已經將輸出的有效數據放在l_dato[31:0]上,pci用戶設備必須在第8個clk的上升沿將l_dato[31:0]輸出的數據D0鎖存至目標地址l_adro[31:0],用戶設備邏輯可以用第8個clk的上升沿來作為鎖存器的鎖存時鐘,用lt_dxfrn作為鎖存器的鎖存使能信號(/Latch Enable)或存儲單元的寫使能信號(/Write Enable)。

4 應用設計實例及注意事項

  筆者已經成功地將pci_t32用于一個compact PCI的TARGET控制模塊中。在這個模塊中,主設備Master通過pci_t32來讀寫64個32bit控制寄存器,再由這些寄存器組去控制外部設備。在本系統的FPGA里,還有仲裁器等其它邏輯,PCI時鐘是33MHz,芯片選用的是EPF10K100EQC240-2。系統邏輯設計的框架如圖4所示。在寄存器組里還有一些簡單的選通、三態控制等邏輯,此略。l_adro[6:0]譯碼選擇寄存器組里的目標寄存器。當/WE有效時,l_dato[31:0]上是pci_t32輸出的有效數據;當/OE有效時,寄存器組必須將要輸出的數據放到l_adi[31:0]總線上。

?

?

  在使用pci_t32時,還有一些值得注意的地方,如下所述:

  (1)用戶邏輯的時鐘(本系統的寄存器組的時鐘clk)與進入pci_t32的時鐘必須是同一個時鐘,并且在定義管腳時應選用全局時鐘線(global clock)。這樣,可以保證時鐘的同步,提高系統的性能。

  (2)從庫中調出pci_t32.gdf的symbol,在其右上角,可以看到一些默認設置,雙擊這些參數,可以改變設置。包括:DEVICE_ID、REVISION_ID、CLASS_CODE、VENDOR_ID、基地址等PCI標準配置寄存器。

  (3)選擇芯片主要考慮兩個因素:容量和速度。芯片容量包括片內的邏輯單元和可用I/O管腳數。芯片速度主要由PCI系統工作的時鐘頻率以及用戶邏輯的大小和優化程度兩方面決定。

  pci_t32的資源占用較小,在用EPF10K100EFC484-1芯片編譯時,占用621個LC(Logic Cell)。而PCI 宏核pci_a,在用EPF10K100EFC484-1芯片編譯時,占用923個LC。EPF10K100共有約5000個LC。

  Altera的FPGA有多種容量和速度級,一般來說,-1速度級的芯片可以滿足66MHz時鐘的PCI時序要求,-2速度級的芯片只能滿足33MHz時鐘的PCI時序要求。

  速度和容量是否能滿足用戶的要求,必須要進行仿真才能最終確定。

  現在FPGA的價格日漸下降,大容量的FPGA使用越來越普遍。各家芯片供應商都提供了各種 PCI宏核邏輯。設計者可以將PCI用戶邏輯與PCI接口宏核邏輯集成在一片FPGA里,在頂層通過仿真來驗證PCI接口以及用戶邏輯設計的正確與否。這樣,可以大幅度提高調試速度,縮短開發周期,提高電路板的集成度和系統性能。可以肯定地預言,使用PCI接口宏核邏輯來進行PCI接口設計是今后設計PCI接口的主要方法。PCI接口宏核邏輯將會受到越來越多的設計工程師的青睞。

?

參考文獻

1 ALTERA? Device Data Book 1999.ALTERA,1999

2 PCI MegaCore Function User Guider,Version 1.0. ALTERA,1999年12月

3 金 革.可編程邏輯陣列FPGA和EPLD.合肥:中國科技大學出版社,1996

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲欧美综合v| 一区二区三区亚洲| 久久精品国产成人| 国产亚洲欧美日韩日本| 久久综合九色| 日韩视频专区| 亚洲私人影院| 国产亚洲精品一区二区| 欧美视频官网| 久久精品动漫| 亚洲高清在线播放| 夜夜爽www精品| 国产欧美亚洲日本| 欧美大片在线影院| 亚洲一区二区视频| 欧美在线观看你懂的| 91久久中文字幕| 国产精品亚发布| 欧美a级一区二区| 亚洲男女毛片无遮挡| 亚洲大胆人体在线| 99国产精品久久久| 国产亚洲精品福利| 欧美日韩国产小视频| 久久成人精品视频| 日韩视频一区二区| 亚洲最新色图| 亚洲欧美综合v| 性久久久久久久久久久久| 亚洲精品你懂的| 国产视频一区在线观看一区免费| 国产欧美精品一区| 国内偷自视频区视频综合| 欧美视频在线观看| 国产精品久久久久久久电影| 看欧美日韩国产| 欧美freesex8一10精品| 欧美久久视频| 久久综合激情| 欧美成人激情视频| 欧美日韩mp4| 国产精品免费网站| 欧美日韩国产一级片| 欧美日韩综合不卡| 国产精品一级二级三级| 黄色成人精品网站| 国产精品视频xxx| 国产一区999| 亚洲国产成人久久| 国产一区二区毛片| 在线播放不卡| 韩国精品在线观看| 亚洲国产精品久久久久婷婷老年 | 亚洲一区三区在线观看| 亚洲人成精品久久久久| 宅男噜噜噜66一区二区66| 亚洲激情婷婷| 亚洲第一精品福利| 国产一区二区三区四区五区美女| 在线播放中文一区| 99国内精品久久久久久久软件| 亚洲直播在线一区| 亚洲人妖在线| 亚洲国产第一页| 一区二区三区高清在线| 亚洲伦理久久| 日韩系列在线| 欧美中文字幕视频| 欧美精品一区二| 欧美激情第六页| 欧美本精品男人aⅴ天堂| 欧美日韩在线免费| 欧美色一级片| 国产丝袜美腿一区二区三区| 亚洲精品一区二区三区樱花| 午夜在线一区二区| 宅男噜噜噜66一区二区| 中文av一区特黄| 久久久av水蜜桃| 久久国产主播| 欧美美女bbbb| 国内精品久久久久影院 日本资源| 日韩午夜免费视频| 久久精品一二三区| 香蕉av777xxx色综合一区| 午夜精品一区二区三区电影天堂| 亚洲在线第一页| 蜜臀久久99精品久久久久久9| 免费在线观看一区二区| 国产精品日韩一区二区| 亚洲精品一区二区在线| 亚洲二区免费| 欧美在线啊v| 国产精品久久波多野结衣| 亚洲电影在线免费观看| 欧美一区二区| 亚洲免费影院| 欧美日本在线播放| 亚洲第一二三四五区| 欧美在线国产| 欧美一区二区久久久| 久久久噜噜噜久久| 免费视频一区| 国产午夜精品在线观看| 亚洲小说欧美另类婷婷| 欧美一区二区三区日韩| 亚洲在线观看视频网站| 欧美精品一区三区| 在线成人h网| 亚洲高清精品中出| 久久午夜色播影院免费高清| 欧美成年人网站| 狠狠色丁香婷婷综合久久片| 午夜一区不卡| 久久爱另类一区二区小说| 国产精品色午夜在线观看| 亚洲私人影院在线观看| 亚洲一区二区免费看| 一区二区三区.www| 一本色道久久综合亚洲精品按摩 | 在线性视频日韩欧美| 欧美日韩1区2区3区| 91久久国产综合久久91精品网站| 91久久精品www人人做人人爽| 在线亚洲精品| 欧美日韩成人网| 亚洲日本久久| 中文久久精品| 国产精品v日韩精品| 狠狠色狠狠色综合日日小说| 欧美一区二区免费| 久久久久九九视频| 国产亚洲一区二区精品| 欧美亚洲一区| 久久综合久色欧美综合狠狠| 在线成人激情| 日韩小视频在线观看专区| 欧美日韩国产限制| 中文av字幕一区| 欧美一区二区三区在线观看| 国产日韩欧美亚洲一区| 欧美在线资源| 亚洲一区二区免费视频| 欧美日韩一级视频| 亚洲一区二区欧美日韩| 欧美一区二区三区四区视频| 国产欧美日韩另类一区 | 久久在线免费观看视频| 亚洲电影免费在线观看| 一卡二卡3卡四卡高清精品视频| 欧美性猛交xxxx乱大交退制版| 亚洲综合电影一区二区三区| 久久精品久久99精品久久| 激情小说另类小说亚洲欧美| 亚洲欧洲日产国产网站| 欧美丝袜一区二区| 欧美在线播放视频| 欧美激情精品久久久久久蜜臀| 一区二区三区视频在线| 久久久久久穴| 亚洲人成毛片在线播放| 午夜精品一区二区三区四区 | 久久精品一本| 亚洲破处大片| 欧美一级夜夜爽| 亚洲第一精品在线| 亚洲一区二区精品在线| 国产综合网站| 在线一区欧美| 国产在线播放一区二区三区| 99国产精品久久| 国产欧美精品va在线观看| 91久久午夜| 国产精品久久77777| 亚洲国产综合视频在线观看| 午夜视频在线观看一区二区| 国产一区二区欧美日韩| 夜夜爽夜夜爽精品视频| 国产亚洲精品福利| 亚洲最快最全在线视频| 国产一区二区三区免费不卡| 亚洲视频第一页| 一区二区视频免费完整版观看| 亚洲伊人久久综合| 激情综合视频| 亚洲欧美日韩国产综合精品二区| 在线观看日韩www视频免费| 亚洲欧美一区在线| 亚洲黑丝在线| 久久免费的精品国产v∧| 日韩天堂在线视频| 日韩亚洲成人av在线| 国产免费一区二区三区香蕉精| 亚洲一区二区三区免费视频| 麻豆国产精品777777在线| 亚洲无限av看| 欧美精品二区三区四区免费看视频| 亚洲欧美日韩电影| 欧美一区二区大片| 亚洲欧洲一二三|