《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于FPGA的DDR3六通道讀寫防沖突設計
基于FPGA的DDR3六通道讀寫防沖突設計
2018年電子技術應用第7期
張鳳麒,張延彬,王忠勇
鄭州大學 產業技術研究院,河南 鄭州450000
摘要: 為了解決期貨行情數據加速處理中多個通道同時訪問DDR3時出現的數據讀寫沖突問題,實現了一種基于FPGA的DDR3六通道讀寫防沖突設計,完成了對單片DDR3內存條的多通道實時訪問控制需求。通過ChipScope工具采樣結果證明了設計的可行性,提高了并行處理的速度,極大程度地降低了期貨行情數據處理中行情計算的時間開銷,最高通道速率可達5.0 GB/s以上,帶寬利用率可達80%以上,在多通道數據讀寫應用中具有很高的實用價值。
關鍵詞: 多通道 防沖突 DDR3 FPGA
中圖分類號: TP334.4
文獻標識碼: A
DOI:10.16157/j.issn.0258-7998.175167
中文引用格式: 張鳳麒,張延彬,王忠勇. 基于FPGA的DDR3六通道讀寫防沖突設計[J].電子技術應用,2018,44(7):68-71,80.
英文引用格式: Zhang Fengqi,Zhang Yanbin,Wang Zhongyong. Anti-conflict design for reading and writing of DDR3 six channels based on FPGA[J]. Application of Electronic Technique,2018,44(7):68-71,80.
Anti-conflict design for reading and writing of DDR3 six channels based on FPGA
Zhang Fengqi,Zhang Yanbin,Wang Zhongyong
Industrial Technology Research Institute,Zhengzhou University,Zhengzhou 450000,China
Abstract: In order to solve the problem of data conflict of reading and writing when multiple channels access DDR3 at the same time in the acceleration processing of futures market data, an anti-conflict design for reading and writing of DDR3 six channels based on FPGA is implemented and the requirement of multiple channels′ real-time access control for monolithic DDR3 memory bar is completed. The result of ChipScope sampling proves the feasibility of the design, it improves the parallel processing speed and reduces the prices of time overhead in the calculation of futures market data processing. The highest channel rate can reach more than 5.0 GB/s and the bandwidth utilization rate can reach more than 80%. The design has a very high practical value in the application of multiple channels′ reading and writing.
Key words : multiple channels;anti-conflict;DDR3;FPGA

0 引言

    基于FPGA的期貨行情數據加速處理過程中,不同的消息類型采用并行處理的方式,并且每一次的處理結果需要使用內存來緩存一次行情數據信息。行情數據信息容量巨大,片上存儲難以滿足需求,采用DDR3 SDRAM成為首選方法[1]。但由于DDR3只有一套數據訪問通道,不能滿足多個通道同時訪問的需求[2]。此前的對于SDRAM的多通道解決方案中,比如曹一江[3]等設計的基于NPI總線的片外存儲器,最大帶寬可達743 Mb/s;樊博[4]等使用UI接口,DDR3通信的最大帶寬可達3.8 Gb/s;張宇嘉[5]等設計的基于AXI4的DDR3多端口方案雖然傳輸速率有所提高,但由于AXI4協議本身的復雜性增加了開發使用的難度。本文實現并驗證了期貨行情數據加速處理中基于FPGA的DDR3六通道UI接口讀寫防沖突設計,簡化了DDR3多通道讀寫的復雜度,隨著有效數據周期的提升,最高端口速率可達5.0 GB/s以上,帶寬利用率可達80%以上。

1 總體設計架構

    本文所設計的六通道讀寫防沖突總體架構如圖1所示,主要包括通道判優仲裁模塊、讀寫邏輯控制模塊和DDR3存儲器控制模塊。

qrs3-t1.gif

    DDR3存儲控制器模塊采用Xilinx公司的MIG核,用戶只需要通過IP核的GUI選擇內存芯片并進行相關參數設置,即可完成DDR3的配置工作[6]。

    通道判優仲裁模塊將對六路通道進行仲裁,對于同一時刻有讀寫請求的不同通道,該模塊按照優先級的高低判定訪問DDR3的順序,利用中斷思想解決多通道讀寫的沖突問題。

    讀寫邏輯控制模塊控制DDR3的接口生成,根據不同操作完成對應接口的時序控制[7],進而實現對DDR3的正確讀寫訪問。

2 DDR3存儲器控制模塊設計

    DDR3 IP核生成的控制器邏輯框圖如圖2所示,采用UI接口的方式相比于AXI4接口,不需要自己組織數據,容易操作,大大簡化了DDR3的使用復雜度,為DDR3的擴展使用帶來了方便[8]

qrs3-t2.gif

2.1 存儲控制模塊寫操作

    DDR3寫操作接口信號如表1所示。

qrs3-b1.gif

    寫操作過程:當app_rdy和app_wdf_rdy同時為高的情況下,寫入DDR3的地址app_addr與app_cmd綁定對齊,寫入DDR3的數據app_wdf_data與數據掩碼app_wdf_mask綁定對齊,app_cmd置為3′b000,與此同時app_en、app_wdf_wren、app_wdf_end置高,即可將數據寫到對應的地址中。

    因為DDR3的寫時序不只一種,為了簡化系統設計,本文設計的用戶接口寫操作時序為地址和數據完全對齊,便于理解和操作[9]。

2.2 存儲控制模塊讀操作

    DDR3的讀操作接口信號如表2所示。

qrs3-b2.gif

    讀操作過程:在app_rdy為高時,用戶發送讀命令并同時將app_en置高,則讀命令和讀地址會寫到DDR3中,DDR3會返回數據和有效指示信號,兩者共同決定返回的數據是否有效。

    通常情況下,DDR3的讀請求結束之后不會馬上返回數據,需要延遲一定的時鐘周期。

3 通道判優仲裁模塊設計

    通常情況下,由于DDR3只有一組控制、地址和數據總線,因此同一時刻只能有一個通道在訪問。根據期貨交易的處理規則,優先級由高到低的順序依次為合約信息消息、市場狀態消息、品種交易狀態消息、成交統計行情消息、多檔定單簿行情消息、多檔成交量統計行情消息。在通道判優的過程中,首先將6種不同的消息經封裝后分別寄存到相應的消息緩存中,每一通道寫入消息緩存中的數據格式,從高到低位依次為寫使能、讀使能、寫數據、寫地址、讀地址;然后首先判斷合約信息消息緩存是否為空,如果不為空,則證明當前有合約信息消息的請求發生,此時狀態機會跳轉到合約信息消息處理狀態;待合約信息消息的緩存全部讀取完畢之后,再次按優先級順序判斷其他消息緩存是否為空,狀態機隨即做相應的跳轉,完成不同通道之間的切換,如圖3所示。

qrs3-t3.gif

    對于不同的消息類型,對應著不同的消息處理單元,目的是增加系統的并行處理操作,降低處理延遲。

4 讀寫邏輯控制模塊

    讀寫邏輯控制模塊主要對不同類型消息做并行化處理,生成DDR3的接口信號,每個消息的處理流程如圖4所示。

qrs3-t4.gif

    對于期貨交易中的各種合約行情,種類多,但占用空間小,通常DDR3中一個地址就可完成一個行情的存儲,在行情的還原、計算、發布中,需要讀取多個行情。由于DDR3的突發長度為8,為了便于對行情的準確存取,6個通道的數據位寬均設定為DDR3位寬的1/8,即一次只存取一個地址的數據。

    對于通道判優仲裁模塊輸出的數據,寫使能與讀使能均為1 bit位寬,高電平表示請求發生;寫數據為64 bit位寬;寫地址和讀地址為28 bit位寬,DDR3的數據位寬在IP核中配置為512 bit,地址位寬為28 bit。因寫數據位寬與DDR3數據位寬不匹配,所以DDR3的寫操作需要掩碼配合共同完成。

    處理過程如下:首先進行讀寫判斷,若寫使能置高,則跳轉到寫操作狀態;若讀使能置高,則跳轉到讀操作狀態,若無讀寫操作,處于等待狀態。(期貨行情消息處理中不會出現同一通道讀寫同時進行的情況,因此同一通道讀寫使能同為高電平的情況不會出現。)

    如果是寫操作,一方面生成寫入DDR3的地址和命令,另一方面將寫數據封裝成512 bit位寬。其中寫入DDR3的地址app_addr為{寫地址[27:3],3′d0},寫入的數據app_wdf_data和掩碼app_wdf_mask由寫地址[2:0]確定。數據地址命令控制模塊也會相應的產生app_en、app_wdf_wren、app_wdf_end控制信號,這些信號共同作用關于DDR3 SDRAM存儲器,配合完成DDR3的寫入操作,如圖5所示。

qrs3-t5.gif

    如果是讀操作,地址命令選擇模塊將讀地址[27:3]賦值給app_addr作為寫入DDR3的基地址,同時將讀地址[2:0]作為寫入DDR3的偏移地址存入對應通道的偏移地址緩存中,在數據地址命令控制模塊生成其他的控制信號傳送給DDR3 SDRAM存儲器。DDR3 SDRAM根據地址返回相應的512 bit位寬的數據。在返回數據的同時讀取對應通道偏移地址緩存中的偏移地址,并根據此偏移提取對應的64 bit數據從而完成DDR3的一次讀取操作,如圖6所示。

qrs3-t6.gif

5 實驗結果與分析

5.1 實驗結果

    本文以Xilinx公司的Kintex-7系列XC7K325T FPGA芯片和Micron公司的JBF9C256x72AKZ DDR3芯片為硬件平臺,并以此來驗證本文設計的正確性,分析其性能。

    測試方法:六通道在同一時刻發起DDR3的讀寫請求,其中1~4通道進行DDR3的寫請求,5、6通道進行DDR3的讀請求,狀態機按照消息優先級的順序依次進行狀態跳轉完成處理,最后將數據分別返回到相應通道中,ChipScope結果如圖7所示。

qrs3-t7.gif

5.2 實驗分析

    為了更好描述設計的性能,本文引入以下參數。仲裁時間:請求信號發生到通道開始處理的時間間隔;IP核處理時間:DDR3 IP核從接收指令到返回數據的時間;有效提取時間:從512 bit的DDR3返回數據中提取對應的64 bit的時間間隔;有效數據時間:數據有效的維持時間;總時間:消息請求到數據返回的時間,即仲裁時間、IP核處理時間與有效數據時間之和。因此:

     qrs3-gs1-2.gif

    在本設計中,實測仲裁時間為3個時鐘周期,IP核處理時間為22個時鐘周期,有效提取時間2個時鐘周期,如圖8所示。

qrs3-t8.gif

    每個通道的有效數據時間不相同,性能也不相同,具體測試結果如表3所示。

qrs3-b3.gif

    測試結果表明,本設計能穩定高效地完成多通道對DDR3的訪問,隨著有效數據周期的提升,通道速率可達5 GB/s以上,帶寬利用率可達80%以上,能夠滿足期貨行情數據處理過程中的實時性要求。

6 結論

    本文設計并實現了基于FPGA的DDR3六通道讀寫防沖突設計,能有效地解決在期貨行情數據處理中多通道同時訪問DDR3的沖突問題,在現有的Kintex-7系列FPGA平臺期貨行情數據處理系統中取得了良好的應用效果。測試結果表明該防沖突設計能高效正確地完成多通道對DDR3的訪問,具有穩定性好、仲裁時間固定、效率高等特點。本文設計的DDR3多通道讀寫防沖突設計簡化了多通道讀寫DDR3的復雜度,降低了在期貨行情數據處理過程中的延遲,提高了并行處理速度。

參考文獻

[1] 曠立強.基于FPGA的DDR3設計與實現[D].長沙:國防科學技術大學,2014.

[2] 吳連慧.基于FPGA的DDR3多端口讀寫存儲管理設計[J].單片機與嵌入式系統應用,2015,14(11):71-74.

[3] 曹一江,馬寧,王建民.MPMC高速存儲器接口IP核設計[J].哈爾濱理工大學學報,2012,17(6):75-80.

[4] 樊博,王延東,孫宏海,等.FPGA實現高速實時多端口SDRAM控制器的研究[J].計算機工程與應用,2013,49(12):60-64.

[5] 張宇嘉,楊曉非,姚行中.基于AXI4的衛星接收機DDR3多端口存儲的設計[J].電子器件,2016,39(3):74-78.

[6] 梁晨,趙邦信.基于FPGA和DDR3 SDRAM的大規模查找表設計與實現[J].電子器件,2017,40(4):849-855.

[7] 宋明,趙英瀟,林錢強.基于FPGA的DDR3 SDRAM控制器的設計與優化[J].電子科技,2016,29(11):47-50.

[8] 姜文博,陳維蛇,司蓉蓉.Xilinx系列FPGA對DDR3的訪問接口設計[J].通訊世界,2016,15(5):243-247.

[9] 潘一飛,余海.基于FPGA的DDR3用戶接口設計[J].電子制作,2013,24(15):9-13.



作者信息:

張鳳麒,張延彬,王忠勇

(鄭州大學 產業技術研究院,河南 鄭州450000)

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品男人爽免费视频1| 久久久久久午夜| 国产一区二区精品| 久久久xxx| 亚洲日本激情| 亚洲伦理在线| 国产精品久久久久一区| 欧美日韩国产一区精品一区| 亚洲一区视频| 欧美在线黄色| 亚洲区一区二| 国产欧美一区二区三区在线看蜜臀 | 一本到12不卡视频在线dvd| 一区二区不卡在线视频 午夜欧美不卡在 | 国产午夜亚洲精品羞羞网站 | 欧美日韩一二区| 久久精品一区二区三区中文字幕 | 国产精品一级在线| 欧美aⅴ一区二区三区视频| 一区二区三区久久| 香蕉久久国产| 99国产精品久久久| 国产一区二区三区自拍| 国产午夜精品福利| 国产一区日韩二区欧美三区| 国产亚洲精品一区二区| 国产在线不卡| 欧美日韩在线亚洲一区蜜芽| 欧美日韩精品综合在线| 欧美亚洲第一区| 欧美成人中文| 久久精品国内一区二区三区| 亚洲视频免费看| 久久精品夜色噜噜亚洲aⅴ| 99天天综合性| 亚洲一级在线观看| 亚洲精品麻豆| 一区在线观看视频| 国产精品婷婷| 国产一区二区三区在线播放免费观看| 狠狠色2019综合网| 国产欧美日韩精品a在线观看| 国产欧亚日韩视频| 一区在线免费| 99热精品在线| 欧美一区2区三区4区公司二百| 亚洲二区免费| 欧美亚洲一区| 亚洲欧洲另类| 亚洲福利视频一区| 99国产精品视频免费观看| 亚洲免费视频成人| 亚洲一区二区三区免费在线观看| 欧美在线播放一区二区| 午夜在线视频观看日韩17c| 在线视频欧美日韩精品| 午夜久久99| 蜜臀av一级做a爰片久久| 久久精品国产清自在天天线| 久久综合九色综合欧美狠狠| 久久国产一二区| 欧美成人精品一区| 国产精品乱码人人做人人爱| 红桃视频一区| 亚洲桃花岛网站| 中文亚洲字幕| 亚洲成人直播| 亚洲电影中文字幕| 亚洲无线一线二线三线区别av| 99re66热这里只有精品4| 亚洲精品老司机| 午夜在线不卡| 久久精品论坛| 欧美中文字幕第一页| 免费成人黄色片| 欧美日韩一区二区三区免费看| 国产乱人伦精品一区二区| 国产精品日韩在线观看| 亚洲大胆视频| 在线播放视频一区| 一色屋精品视频在线观看网站| 一本色道久久综合亚洲精品按摩| 久久国产色av| 亚洲欧美成人一区二区三区| 欧美国产精品劲爆| 欧美精品一区二区三区四区| 欧美大片国产精品| 国产日韩av在线播放| 亚洲乱码精品一二三四区日韩在线| 久久国产欧美精品| 香蕉av福利精品导航| 欧美日韩国产不卡在线看| 一区二区自拍| 香蕉久久夜色精品| 亚洲免费综合| 欧美日韩精品免费在线观看视频| 激情久久中文字幕| 亚洲欧美日韩在线高清直播| 欧美在线观看视频在线| 亚洲一区国产精品| 欧美激情91| 亚洲福利视频三区| 日韩图片一区| 亚洲黄色成人久久久| 日韩西西人体444www| 久久久久.com| 国产日韩精品综合网站| 亚洲色图自拍| 亚洲婷婷综合色高清在线| 欧美精品自拍| 国产精品爽爽爽| 一区二区三区成人精品| 性一交一乱一区二区洋洋av| 亚洲欧美一区二区原创| 久久天天狠狠| 欧美激情影音先锋| 在线不卡亚洲| 亚洲国产欧美日韩| 玖玖玖免费嫩草在线影院一区| 国色天香一区二区| 久久精品成人欧美大片古装| 久久久99精品免费观看不卡| 国产一区二区在线观看免费| 久久不射电影网| 久久一区二区三区av| 国自产拍偷拍福利精品免费一| 久久精品99无色码中文字幕 | 午夜久久一区| 国产精品免费一区二区三区在线观看 | 一本久久精品一区二区| 亚洲视频狠狠| 国产精品久久一区二区三区| 亚洲在线观看免费| 亚洲国产视频a| 久久野战av| 亚洲风情在线资源站| 亚洲国内自拍| 欧美好骚综合网| 99热精品在线观看| 亚洲午夜久久久| 国产精品日韩一区二区| 小黄鸭精品aⅴ导航网站入口| 久久狠狠婷婷| 影音欧美亚洲| 一区二区三区欧美| 国产精品网站在线观看| 欧美亚洲免费高清在线观看| 久久在线免费观看| 亚洲精品少妇| 欧美一激情一区二区三区| 欧美精品精品一区| 亚洲美女电影在线| 小嫩嫩精品导航| 国内久久精品视频| 亚洲美女视频在线免费观看| 久久久久久久欧美精品| 在线观看不卡| 一区二区三区www| 国产精品免费一区二区三区在线观看| 午夜亚洲福利| 亚洲午夜精品一区二区| 国产精品性做久久久久久| 欧美永久精品| 欧美成人一区二免费视频软件| 99国内精品久久| 久久se精品一区精品二区| 一区视频在线播放| 这里只有精品电影| 国产在线播精品第三| 9久草视频在线视频精品| 国产精品一区二区女厕厕| 亚洲第一区在线观看| 欧美日韩中文另类| 欧美中文字幕| 欧美视频第二页| 亚洲欧洲午夜| 欧美一区二区高清在线观看| 曰本成人黄色| 午夜久久tv| 最近中文字幕mv在线一区二区三区四区 | 日韩视频免费观看| 久久久久国产精品www| 99re6这里只有精品视频在线观看| 久久精品国产77777蜜臀| 亚洲精品欧美精品| 久久精品99国产精品| 亚洲精品一级| 久久男人资源视频| 亚洲午夜在线视频| 欧美久久久久免费| 久久国产日本精品| 国产精品老女人精品视频| 亚洲欧洲一区二区天堂久久| 国产乱码精品1区2区3区| 一本久道久久综合婷婷鲸鱼| 韩国三级在线一区| 午夜精品在线看| 99国产精品久久久久老师| 欧美本精品男人aⅴ天堂| 欧美亚洲网站|