日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > EDA > 電子設計自動化
[導讀]隨著高速數(shù)據(jù)采集設備傳輸帶寬的日益提高,開發(fā)者需要采用新的計算機總線進行數(shù)據(jù)傳輸。這里敘述了使用EP2SGX90系列FPGA完成PCI-Express協(xié)議轉換,多種DMA工作方式及相關寄存器的作用。以鏈式DMA傳輸方式為例,詳細介紹該傳輸方式下的寄存器設置及在驅動程序中的實現(xiàn)范例。實驗表明,用FPGA實現(xiàn)協(xié)議轉換,總線持續(xù)傳輸速率最高可以達到1.2 Gb/s,滿足大多數(shù)高速數(shù)據(jù)采集設備的要求。在此摒棄了采用專用總線接口芯片的傳統(tǒng)方法,將開發(fā)者的邏輯設計和總線協(xié)議轉換放到同一個FPGA芯片中,不但節(jié)省了硬件成本,利用其可編程特性,大大提高了設計可擴展性,同樣的硬件很容易完成由PCIE1.O到PCIE2.O的升級。

0 引言
    PCIE(PCI express)是用來互聯(lián)諸如計算機和通信平臺應用中外圍設備的第三代高性能I/0總線。PCIE體系結構繼承了第二代總線體系結構最有用的特點,采用與PCI相同的使用模型和讀/寫通信模型,支持各種常見的事務。其存儲器、I/0和配置地址空間與PCI的地址空間相同。由于地址空間模型沒有變化,所以現(xiàn)有的OS和驅動軟件無需進行修改就可以在PCIE系統(tǒng)上運行。
    PCIE是串行協(xié)議,與原有的PCI并行總線相比,它沒有大量的數(shù)據(jù)和控制線,對于硬件電路設計者來說,省去了很多硬件設計工作。PCIE的傳輸速度遠遠大于PCI總線,PCIE1.1版本單個鏈路的單向吞吐量能達到250 MB/s。對于需要與主機進行大容量傳輸?shù)南到y(tǒng)來說,該總線標準的優(yōu)勢是非常明顯的。
    由于PCIE總線硬件設計簡單,吞吐量大,軟件向下兼容,只要找到合適的總線接口芯片,很容易將現(xiàn)有的PCI總線設備升級為PCIExpress設備。Altera公司最新推出的EP2SGX90系列的芯片,給用戶提供了PCIE接口IP核。本文將結合實際的應用,詳細介紹該IP核的使用情況,包括寄存器設置,DMA操作等。

1 功能描述及參數(shù)設置
    按照PCIE協(xié)議的要求,該FPGA的IP核也采用三層體系結構,即傳輸層、數(shù)據(jù)鏈路層和物理層。這三層功能模塊完成了PCIE的協(xié)議轉換,在傳輸層上給開發(fā)人員提供了非常豐富的接口。開發(fā)人員的所有開發(fā),包括DMA傳輸?shù)榷际窃趥鬏攲右陨线M行的。
    傳輸層(transaction layer):完成TLP(數(shù)據(jù)傳輸包)的收發(fā),含有虛擬信道(VC)緩沖區(qū),具有端口仲裁、VC仲裁、流控制、數(shù)據(jù)重新排序和數(shù)據(jù)校驗等功能。
    數(shù)據(jù)鏈路層(data link layer):數(shù)據(jù)鏈路層的主要功能是保證在各鏈路上發(fā)送和接收數(shù)據(jù)包時數(shù)據(jù)的完整性。在接收端,對數(shù)據(jù)進行嚴格的CRC校驗,如果有錯誤,會給發(fā)送方返回1個NAK信號。發(fā)送端具有重傳緩沖區(qū),如果收到NAK信號,則把數(shù)據(jù)重新發(fā)送1次。
    物理層(physical layer):對于發(fā)送端,接收數(shù)據(jù)鏈路層的數(shù)據(jù)包,把這些數(shù)據(jù)進行8 b/10 b編碼,送到串行發(fā)送器上;對于接收端則剛好相反,收到串行碼后,先解碼,然后送給數(shù)據(jù)鏈路層。
    在生成PCIE的IP核時,至少選擇2個存儲區(qū),一個是BAR[1:O],用作用戶開發(fā)板的擴展存儲區(qū)用;還有一個是BAR2,下面所有的寄存器操作都是基于該地址的。新生成的IP核不帶有DMA功能,但是在工程文件夾下面有一個xxxx_examples(xxx代表工程名稱)的文件夾,文件夾里有簡單DMA和鏈式DMA的例子代碼,開發(fā)者只需要對這些代碼進行修改,就能開發(fā)出適合自己的DMA功能模塊。

2 簡單DMA
    該DMA傳輸模式相對比較簡單,只需要對相應的寄存器進行設置即可完成,DMA傳輸步驟如下所示,每進行1次DMA傳輸,都需要按照下面的步驟進行1次設置。下面所述的偏移量都是相對于BAR2地址。
    (1)設置偏移量為0x00和0x04的寄存器,寫入DMA傳輸?shù)闹鳈C端地址;
    (2)設置偏移量為0x14的寄存器,寫入DMA傳輸?shù)腜CIE端點地址;
    (3)在偏移量為0x08的寄存器中寫入本次DMA傳輸?shù)拈L度,以字節(jié)為單位;
    (4)設置偏移量為0x0C的寄存器,設置DMA傳輸?shù)膶傩裕瑢υ摷拇嫫鞯膶懖僮鲗颖敬蜠MA傳輸;
    (5)讀取0x0C的寄存器DMA傳輸狀態(tài)位,察看本次DMA是否完成。

3 鏈式DMA
    鏈式DMA是一種效率遠遠高于簡單DMA的傳輸方式,它只需要1次啟動操作,就可以完成多次DMA傳輸。這里將結合實際使用情況,詳細介紹鏈式DMA的傳輸過程。
3.1 描述符表
    實現(xiàn)鏈式DMA傳輸時,需要開發(fā)人員在主機內存中開辟一塊空間,用來存儲描述符表,它由一個表頭和多個描述符組成,其中每一個描述符對應一次DMA操作。用戶根據(jù)自己的需求填寫該描述符表,關于該描述符表的詳細說明如表1和表2所示。


    控制區(qū)域中含有一些控制信息,其中第16位用來控制傳輸方向,為O是DMA寫,為1是DMA讀,這里的讀/寫是以主機端為參考的,如果以PCIE核為參考,方向剛好相反。第18位用來使能DMA傳輸計數(shù),如果該位使能為1,那么在DMA傳輸過程中,PCIE核每完成1次DMA操作,都會進行1次計數(shù)操作,然后把這個計數(shù)結果傳送給主機,主機把這個結果填寫到描述符表的RCLAST字段中。
    表大小是指本次鏈式DMA操作對應的描述符個數(shù),每個描述符對應一次DMA操作。
    RCLAST是一個計數(shù)單元,它有兩個作用,在鏈式DMA傳輸前,表示還有多少個DMA操作等待傳輸,由于它是從0開始計數(shù)的,所以這個值等于表大小減1。還有一個重要作用是在鏈式DMA傳輸過程中,用來表示鏈式DMA傳輸?shù)臓顟B(tài)。如上所述,如果控制區(qū)域的第18位設置為1,那么每完成1次DMA操作,主機都會更新這個計數(shù)器。當計數(shù)器的數(shù)值(也是從O開始計數(shù)的)等于前面設置的期望傳輸?shù)腄MA次數(shù),就表示鏈式DMA傳輸操作結束。開發(fā)人員可以用這個狀態(tài)單元來察看本次傳輸是否結束,從而開始一個新的傳輸周期。
    DMA長度用來設置本描述符對應的DMA傳輸?shù)拈L度,是以32位為單位的。主機端地址用來指示數(shù)據(jù)存放存放的位置。
3. 2 實現(xiàn)范例
    根據(jù)上面介紹的描述符表,下面給出一個鏈式DMA讀的驅動程序例子。首先生成一個描述符表,然后把描述符表表頭的4個字段的內容分別寫入BAR2地址偏移量為0x0,0x4,0x8和0xC寄存器中。寫完后即開始此次鏈式DMA讀傳輸,while循環(huán)用于等待鏈式DMA結束。從下面的代碼可以看出,2個描述符對應2次DMA操作。

    圖1是用SignalTap工具獲取的鏈式DMA讀時序圖。PCIE核接收tx_req0請求信號,然后給出一個tx_ack0,同時將tx_dr0置為有效,該信號套住的TXData就是需要讀取的有效數(shù)據(jù)。在每次DMA結束之后,PCIE核都會用同樣的控制邏輯給主機傳送1個已完成DMA次數(shù)的狀態(tài)字,如圖1中的44040000h。



4 性能測試
    在做總線性能測試時,采用鏈式DMA傳輸方式,共4個描述符表。根據(jù)實際使用的PCIE總線通道數(shù)和DMA長度的不同,實際測試得到的總線速度也不同,表3給出了參考數(shù)據(jù)。



5 結語
    使用FPGA來設計PCIE總線擴展卡,可以省去專用的PCIE接口芯片,降低了硬件設計成本,提高了硬件的集成度。利用FPGA的可編程特性,大大提高了設計靈活性、適應性和可擴展性。PCIE總線提供了高速、獨享的數(shù)據(jù)交換通道,確保在大數(shù)據(jù)量的數(shù)據(jù)交換時不會出現(xiàn)瓶頸,而且作為新一代總線,它使系統(tǒng)在獲得更高性能的同時,具有了良好的升級性。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

最近為什么越來越多的研究開始利用FPGA作為CNN加速器?FPGA與CNN的相遇究竟能帶來什么神奇效果呢?原來,F(xiàn)PGA擁有大量的可編程邏輯資源,相對于GPU,它的可重構性以及高功耗能效比的優(yōu)點,是GPU無法比擬的;同時...

關鍵字: FPGA 可編程邏輯資源 GPU

FPGA的應用領域包羅萬象,我們今天來看看在音樂科技領域及醫(yī)療照護的智能巧思。

關鍵字: FPGA 科技領域 智能

強大的產品可降低信號噪音并提高分辨率與動態(tài)

關鍵字: Spectrum儀器 數(shù)字化儀 FPGA

最近某項目采用以太網通信,實踐起來有些奇怪,好像設計成只能應答某類計算機的ICMP(ping)命令, 某類計算機指的是Windows特定系統(tǒng),其他系統(tǒng)發(fā)送ping都不能正確識別。

關鍵字: 嵌入式Linux FPGA 協(xié)議

近兩年,國外廠商的FPGA芯片價格飆升,由于價格,貨期,出口管制等多方面因素的影響,很多公司都在尋找FPGA國產化替代方案。我工作中正在使用的幾款芯片也面臨停產的風險,用一片少一片,了解到國產FPGA發(fā)展的也不錯,完全自...

關鍵字: FPGA 芯片 EDA

本篇是FPGA之旅設計的第十二例,在前面的例程中,完成了DS18B20溫度傳感器數(shù)據(jù)的采集,并且將采集到的數(shù)據(jù)顯示在數(shù)碼管上。由于本例將對溫濕度傳感器DHT11進行采集,而且兩者的數(shù)據(jù)采集過程類似,所以可以參考一下前面的...

關鍵字: FPGA DS18B20溫度傳感器

這是FPGA之旅設計的第十三例啦,本例是一個綜合性的例程,基于OLED屏幕顯示,和DHT11溫濕度采集,將DHT11采集到的溫濕度顯示到OLED屏幕上。

關鍵字: FPGA OLED屏幕

第八例啦,本例將介紹如何通過FPGA采集DS18B20傳感器的溫度值。

關鍵字: FPGA DS18B20傳感器

這是FPGA之旅設計的第九例啦!?。”纠龑⒔榻B如何使用FPGA驅動OLED屏幕,并在接下來的幾例中,配合其它模塊,進行一些有趣的綜合實驗。由于使用的OLED屏是IIC接口的,對IIC接口不是很清楚的,可以參考第五例的設計...

關鍵字: FPGA OLED屏幕

這是FPGA之旅設計的第十例啦,在上一例中,已經成功驅動了OLED屏幕,本例將結合上一例,以及第四例多bytes串口通信做一個有趣的例程。

關鍵字: FPGA OLED屏 串口

電子設計自動化

21369 篇文章

關注

發(fā)布文章

編輯精選

技術子站

關閉