《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于PCD656的高速PCI總線接口的設計與實現(xiàn)
基于PCD656的高速PCI總線接口的設計與實現(xiàn)
維庫
摘要: 利用PCI9656和FPGA實現(xiàn)了一種高速PCI總線接口,較全面地論述了總線驅動開發(fā)和局部時序設計的過程。這種設計提高了總線傳輸速度,為高速數(shù)據(jù)采集系統(tǒng)的實現(xiàn)創(chuàng)造了條件。
關鍵詞: FPGA PCI總線 PCD656
Abstract:
Key words :

  現(xiàn)代雷達信號處理具有數(shù)據(jù)量大、實時性高等特點,而總線傳輸?shù)男蕸Q定了系統(tǒng)的性能,目前普遍使用標準化的PCI總線技術,以便升級更新。為加快產(chǎn)品開發(fā)和降低設計難度,一般有兩種解決方法:采用通用的PCI芯片或IP核。目前常用的PCI芯片如PCD054、PCD052等雖然性能穩(wěn)定、使用方便,但它們只適用33 MHz、32位總線接口,受時序設計和應用程序效率等影響,總線傳輸速度約穩(wěn)定在70 MB·s-1;使用IP核雖可以兼容66 Hz、64位總線且節(jié)省板卡面積,但其價格昂貴不利于高校及中小企業(yè)推廣使用。而PCI9656適用于66 MHz、64位的PCI總線,因此逐漸成為總線開發(fā)的主流元器件,使得總線傳輸速度達到了150 MB·s-1甚至更高。

  本文利用高效PCI芯片和FPGA設計了一款64位總線傳輸接口電路,傳輸速度達到212 MB·s-1,較以往總線傳輸速度有了較大地提高,滿足了目前高速數(shù)據(jù)傳輸系統(tǒng)的要求。

  1 PCI總線接口架構

  本系統(tǒng)主要由PCI9656和FPGA構成,系統(tǒng)框圖如圖1所示。當主機發(fā)起讀寫操作時PCI9656需要響應其操作,并將相應命令發(fā)送到FPGA進行處理,F(xiàn)PGA進行處理后將數(shù)據(jù)和命令通過PCI9656回傳給主機。PCI9656與主機之間的通信需要相應的設備驅動程序支持,而FPGA響應主機命令則需要配置相應的局部時序。因此,本設計主要的工作為設備驅動程序的開發(fā)和FPGA局部時序的設計。

總體傳輸系統(tǒng)框圖

圖1 總體傳輸系統(tǒng)框圖

  2 PCI9656性能概述

  PCI9656是PLX公司推出的一款兼容32位和64位PCI總線標準的橋接芯片,采用PLX數(shù)據(jù)流水線結構(Data Pipe Architecture),內部配有DMA控制器、可編程主模式傳輸及從模式傳輸;內部有PCI優(yōu)先判決器,可以支持外部7個外部主控器;可由本地中斷信號LINTi和LINTo生成一個PCI中斷信號INTA;本地時鐘獨立于PCI時鐘工作;支持位寬為8位、16位和32位的66,MHz本地總線。PCI9656寄存器與PCI9054寄存器兼容,可容易地進行基于32位PCI總線與基于64位PCI總線的軟件移植。

  PCI 9656具有6條獨立的數(shù)據(jù)通道,分別支持Direct Master、Direct Slave以及DMA功能模式下的數(shù)據(jù)傳輸。

 ?。?)Direct Master模式。用于局部總線到PCI(CompactPCI)的數(shù)據(jù)傳輸,主控設備在局部總線端。16 QWord(128 Byte)和32 QWords(256Byte)的FIFO各應用于數(shù)據(jù)的讀、寫通道。

 ?。?)Direct Slave模式。用于PCI(CompactPCI)到局部總線的數(shù)據(jù)傳輸,主控設備在PCI端。16QWords(128 Byte)和32 QWords(256 Byte)的FIFO各應用于數(shù)據(jù)的讀、寫通道。

 ?。?)DMA模式。DMA傳輸時PCI9656同時是PCI和局部總線的主控設備,PCI 9656有兩條DMA通道(Channel 0、Channel 1),每條通道都由一DMA控制器和32 QWords(256 Byte)雙向FIFO組成。其DMA方式有常規(guī)的塊模式(Block Mode)、集散模式(Scatter/Gather Mode)和命令模式(Demand Mode)。

  在局部總線端,根據(jù)不同的處理器PCI9656有3種工作模式。

 ?。?)M模式。支持Motorola 32 bit的處理器,提供了可與MPC850/860 PowerQUICC直接相連的接口。

 ?。?)C模式。適合大多數(shù)處理器的通用模式,比如常用的FPGA,在本設計中采用此模式。

  (3)J模式。與C模式類似,但其地址線與數(shù)據(jù)線復用。

 

  3 總線設備驅動開發(fā)

  在Windows環(huán)境下開發(fā)PCI設備驅動程序主要有兩種模型,即WinDriver和WDM。本設計使用了WDM驅動模型。開發(fā)PCI設備驅動程序WDM需要處理:硬件訪問、中斷處理和DMA傳輸3方面問題。

  3.1 硬件訪問

  X86處理器有兩種獨立的映射空間:I/O空間和內存空間,I/O空間只能通過I/O指令來訪問,KIoRange類封裝了對I/O空間的操作命令。對于設計的PCI設備,可以通過實例化KIoRange類來對I/O空間進行相應的操作。

  對于PCI設備可以使用KMemoryRange類對內存進行相應操作,具體操作與KIoRange類對I/O空間的操作相似。

  3.2 中斷處理

  驅動程序使用KInterrupt類來實現(xiàn)對中斷操作的處理,其中包括中斷的初始化、將一個中斷服務例程連接到一個中斷和解除其連接等。

  中斷服務例程不是KInterrupt類的成員函數(shù),這是為了減少中斷延遲時間。中斷處理需要中斷服務例程和延遲過程調用例程,在中斷服務例程中,首先判斷該中斷是否是自己設備產(chǎn)生的,若不是,則返回False;若是,則請求一個延遲過程調用例程(DPC)。

  3.3 DMA傳輸

  PCI9656使用DMA方式進行數(shù)據(jù)傳輸。實現(xiàn)DMA傳輸需要3個類:KDmaAdapter,KDmaTransfer和KCommonDmaBuffer。其中,KDmaAdapter類用于建立一個DMA適配器,它說明了DMA通道的特性,如總線寬度,單次傳輸最大個數(shù)等,需要注意的是本設備使用的是64位總線寬度,因此需要特別指出;KDmaTransfer類用于DMA傳輸控制,如傳輸開始、傳輸字節(jié)數(shù)等;KCommonDmaBuffer類用于申請系統(tǒng)提供的公共緩沖區(qū)。具體DMA傳輸設置如下

 ?。?)實例化三個類


 


  OnDmaReady例程中獲取傳輸?shù)奈锢韮却娴牡刂泛妥止?jié)數(shù),然后設置相應的DMA寄存器值開始DMA傳輸。DMA傳輸結束后,應使m_CmxentTm-nsfer無效并刪除。具體流程如圖2所示。

 DMA傳輸流程

圖2 DMA傳輸流程

  4 局部總線端設計

  本設計中,局部總線端采用了C模式。C模式下可配置3種數(shù)據(jù)傳輸方式:單周期方式(Single Cycle Mode)、4字方式(Brust-4 Mode)和連續(xù)突發(fā)傳輸方式(Continuous Mode),在本設計中采用了連續(xù)突發(fā)方式,可以有效地提高輸出效率。

  PCI9656在局部總線為為主設備,始終占用局部總線,局部總線端的FPGA始終響應PCI9656的操作。方案中使用PCI9656的DMA傳輸模式,在本地端不需要進行地址譯碼,因此可以對PCI9656的控制信號進行簡化處理,PCI9656的局部端主要控制信號如下

  ADS#:一次總線訪問開始;

  Blast#:總線訪問結束;

  LW/R#:讀寫控制信號;

  Ready#:從設備準備好信號,有效時表示總線訪問進行中;

  LHOLD:PCI9656占用本地總線申請信號;

  LHOLDA:占用本地總線應答信號;

  Wait#:主設備傳輸暫停信號;

  EOT#:數(shù)據(jù)傳輸異常中止信號,用于FIFO溢出或空時中斷數(shù)據(jù)傳輸;

  Lint#:用于引起CompaetPCI總線端的中斷信號;

  LRST#:本地總線復位信號;

  CCS#:配置寄存器選擇信號。

  在DMA傳輸過程中主要關心的信號可簡化為:ADS#、Blast#、LW/R#、Ready#、LHOLD、LHOLDA,如圖3所示。

PCI局部總線控制時序

圖3 PCI局部總線控制時序

  圖3中,lclk為本地總線時鐘,當PCI9656要發(fā)起一次DMA操作時,先發(fā)送lhold信號申請本地總線,若本地總線空閑則FPGA發(fā)出lholda信號響應PCI9656,然后PCI有效ads_n信號以示總線傳輸開始,F(xiàn)PGA使ready_n有效以示總線傳輸正在進行中,此時本地數(shù)據(jù)通過局部數(shù)據(jù)線傳送到PCI總線,或著數(shù)據(jù)由PCI總線傳送到局部邏輯。一次傳輸結束時PCI使blast_n信號有效并使lhold信號無效,然后FPGA使lholda信號和ready_n信號無效,一次DMA傳輸完成。傳輸中若是DMA讀操作則lwr信號拉低,若為寫操作則拉高。

  本地總線位寬為32位,因此本地總線理論速度為264MB·s-1,由于應用程序的效率問題和傳輸中一些無效狀態(tài)的存在,目前PCI總線平均速率達到212 MB·s-1,可以滿足目前高速數(shù)據(jù)采集、傳輸對總線傳輸速度的要求。

  PCI9656本地總線時序設計中需要注意blast_n信號有效說明為突發(fā)傳輸最后一個時鐘周期,此時ready_n信號仍然為有效,否則會造成總線等待;在正常讀寫訪問中CCS#信號應置高,否則總線訪問將指向配置空間而非內存或I/O空間。

  5 結束語

  利用PCI9656和FPGA實現(xiàn)了一種高速PCI總線接口,較全面地論述了總線驅動開發(fā)和局部時序設計的過程。這種設計提高了總線傳輸速度,為高速數(shù)據(jù)采集系統(tǒng)的實現(xiàn)創(chuàng)造了條件。

 

此內容為AET網(wǎng)站原創(chuàng),未經(jīng)授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美日韩国产精品一区二区亚洲| 国产一区二区三区观看| 亚洲女同性videos| 99pao成人国产永久免费视频| 欧美在线1区| 亚洲女性裸体视频| 亚洲视频成人| 一区二区三区精密机械公司| 亚洲精品乱码久久久久久蜜桃91| 亚洲国产高清aⅴ视频| 在线观看国产日韩| 激情视频一区二区| 精品999在线播放| 在线观看成人一级片| 在线观看91精品国产麻豆| 狠狠色噜噜狠狠色综合久 | 欧美午夜不卡| 欧美午夜激情在线| 国产精品久久国产愉拍| 国产精品大片wwwwww| 国产精品国产三级国产aⅴ入口 | 久热精品在线| 欧美国内亚洲| 欧美色大人视频| 国产精品高潮呻吟久久| 国产精品久久久久久久app| 国产精品久久久久久久久免费桃花| 欧美日韩精品一区二区天天拍小说| 欧美乱在线观看| 欧美日韩在线三级| 国产精品欧美日韩一区二区| 国产精品乱码妇女bbbb| 国产亚洲精品7777| 激情亚洲网站| 亚洲欧洲另类| 一本一本久久| 午夜精品视频在线观看| 亚洲国产精品成人| 一本一本久久a久久精品综合麻豆| 一区二区三区高清在线| 午夜精品免费在线| 久久亚裔精品欧美| 欧美喷水视频| 国产日韩一区在线| 亚洲国产成人高清精品| 99伊人成综合| 欧美一区午夜视频在线观看| 亚洲激情视频在线播放| 这里只有精品丝袜| 欧美在线free| 欧美阿v一级看视频| 欧美日韩在线精品一区二区三区| 国产精品一卡二卡| 亚洲成人在线网站| 中文一区字幕| 亚洲高清在线播放| 亚洲图片在线| 久久免费午夜影院| 欧美日韩在线直播| 狠狠干成人综合网| 日韩午夜av电影| 性8sex亚洲区入口| 日韩午夜电影在线观看| 欧美在线观看一区二区| 欧美成人精品在线视频| 国产精品国产三级国产aⅴ入口 | 国产精品二区三区四区| 国外成人免费视频| 日韩视频在线一区二区三区| 久久大香伊蕉在人线观看热2| 一本一本久久a久久精品综合麻豆| 久久国产精品久久久久久电车| 欧美激情一区二区三区四区| 国产欧美日韩精品专区| 亚洲欧洲日本mm| 欧美一区二区三区视频在线| 99精品视频一区二区三区| 久久国产一区| 欧美视频一区二区三区…| 狠狠久久亚洲欧美专区| 一区二区三区视频观看| 最新成人av网站| 欧美在线一级va免费观看| 欧美日韩免费区域视频在线观看| 国产亚洲精品v| 一区二区三区欧美成人| 亚洲精品美女在线| 久久久av毛片精品| 国产精品免费看久久久香蕉| 91久久夜色精品国产九色| 久久国产精品72免费观看| 亚洲欧美激情一区二区| 欧美黄色大片网站| 一区二区三区在线看| 亚洲欧美日韩中文视频| 正在播放亚洲| 欧美大片一区二区| 激情91久久| 欧美一区二区三区在| 亚洲欧美日韩国产另类专区| 欧美日本亚洲| 亚洲国产高潮在线观看| 亚洲国产精品va在线看黑人动漫| 欧美一区免费| 国产精品久久久久影院亚瑟| 一区二区三区高清不卡| 中文国产亚洲喷潮| 欧美日韩亚洲国产精品| 日韩视频不卡| 亚洲伦理久久| 欧美激情网站在线观看| 亚洲福利国产| 亚洲国产一区二区a毛片| 久久久亚洲国产天美传媒修理工 | 欧美亚洲一区| 欧美一级久久久| 国产精品视频99| 亚洲综合日韩| 午夜在线精品偷拍| 国产精品免费看| 亚洲一区三区电影在线观看| 亚洲在线日韩| 国产精品日日摸夜夜摸av| 亚洲午夜久久久久久久久电影网| 亚洲午夜未删减在线观看| 欧美网站在线观看| 在线性视频日韩欧美| 亚洲男人的天堂在线| 国产精品嫩草影院av蜜臀| 亚洲一区二区网站| 欧美在线精品一区| 狠狠色丁香久久综合频道| 亚洲国产成人久久| 欧美成人黑人xx视频免费观看| 在线欧美日韩国产| 亚洲精品一区在线观看| 欧美美女福利视频| 一本久道综合久久精品| 亚洲欧美在线x视频| 国产精一区二区三区| 欧美一级日韩一级| 久久综合精品一区| 亚洲精品国产视频| 中文一区二区| 国产精品天天摸av网| 欧美一区二区三区免费看| 久久综合久久久| 亚洲精品久久嫩草网站秘色| 中文在线一区| 国产精品夜色7777狼人 | 亚洲国内精品在线| 欧美日韩不卡| 亚洲自拍都市欧美小说| 久久精品国产成人| 91久久精品日日躁夜夜躁欧美 | 午夜视频精品| 韩国一区二区三区在线观看| 亚洲精品乱码久久久久久按摩观 | 亚洲男人av电影| 美女精品网站| 夜夜嗨av一区二区三区| 欧美一区二区精品久久911| 狠狠色狠狠色综合人人| 亚洲免费观看| 国产精品一区=区| 亚洲人成毛片在线播放| 欧美日韩在线亚洲一区蜜芽| 欧美亚洲一区| 欧美日韩精品综合| 久久爱www久久做| 欧美日韩a区| 午夜日韩福利| 欧美片在线播放| 欧美一区日本一区韩国一区| 欧美日韩高清在线观看| 亚洲欧美中文在线视频| 欧美成人dvd在线视频| 亚洲在线第一页| 欧美刺激性大交免费视频| 亚洲一区网站| 欧美大片91| 性欧美video另类hd性玩具| 欧美华人在线视频| 欧美一区二区三区免费在线看| 欧美日本国产| 久久激情视频久久| 国产精品大片免费观看| 亚洲欧洲久久| 国产人成精品一区二区三| 日韩午夜电影av| 狠狠噜噜久久| 翔田千里一区二区| 亚洲精品视频在线播放| 久久久一二三| 亚洲一区免费看| 欧美日韩免费| 91久久精品国产91性色tv| 国产欧美精品在线| 在线视频精品一区| 亚洲国产欧美一区二区三区同亚洲 |