采用Xilinx 和FPGA的DDR2 SDRAM存儲(chǔ)器接口控制器的設(shè)計(jì)
用不了一分鐘,MIG 工具即可生成 RTL 和 UCF 文件,前者是 HDL 代碼文件,后者是約束文件。這些文件是用一個(gè)經(jīng)過硬件驗(yàn)證的參考設(shè)計(jì)庫生成的,并根據(jù)用戶輸入進(jìn)行了修改。
設(shè)計(jì)人員享有完全的靈活性,可進(jìn)一步修改 RTL 代碼。與提供“黑匣子”實(shí)現(xiàn)方法的其他解決方案不同,此設(shè)計(jì)中的代碼未加密,設(shè)計(jì)人員完全可以對(duì)設(shè)計(jì)進(jìn)行任意修改和進(jìn)一步定制。輸出文件按模塊分類,這些模塊被應(yīng)用于此設(shè)計(jì)的不同構(gòu)建模塊:用戶界面、物理層、控制器狀態(tài)機(jī)等等。因此,設(shè)計(jì)人員可選擇對(duì)控制組存取算法的狀態(tài)機(jī)進(jìn)行自定義。由 MIG 工具生成的 Virtex-4 和 Virtex-5 DDR2 的組存取算法彼此不同。Virtex-5 設(shè)計(jì)采用一種最近最少使用 (LRU) 算法,使多達(dá)四組中的一行總是打開,以縮減因打開/ 關(guān)閉行而造成的開銷。如果需要在一個(gè)新組中打開一行,控制器會(huì)關(guān)閉最近最少使用組中的行,并在新組中打開一行。而在 Virtex-4 控制器實(shí)現(xiàn)中,任何時(shí)候只有單個(gè)組有一個(gè)打開的行。每個(gè)應(yīng)用都可能需要有自己的存取算法來最大化吞吐量,設(shè)計(jì)人員可通過改變 RTL 代碼來修改算法,以更加適合其應(yīng)用的訪問模式。
本文引用地址:http://2s4d.com/article/148961.htm修改可選代碼之后,設(shè)計(jì)人員可再次進(jìn)行仿真,以驗(yàn)證整體設(shè)計(jì)的功能。MIG 工具還可生成具有存儲(chǔ)器校驗(yàn)功能的可綜合測試平臺(tái)。該測試平臺(tái)是一個(gè)設(shè)計(jì)示例,用于Xilinx 基礎(chǔ)設(shè)計(jì)的功能仿真和硬件驗(yàn)證。測試平臺(tái)向存儲(chǔ)控制器發(fā)出一系列寫和讀回命令。它還可以用作模板,來生成自定義的測試平臺(tái)。
設(shè)計(jì)的最后階段是把 MIG 文件導(dǎo)入 ISE 項(xiàng)目,將它們與其余 FPGA 設(shè)計(jì)文件合并,然后進(jìn)行綜合、布局和布線,必要時(shí)還運(yùn)行其他時(shí)序仿真,并最終進(jìn)行硬件驗(yàn)證。MIG軟件工具還會(huì)生成一個(gè)批處理文件,包括相應(yīng)的綜合、映射以及布局和布線選項(xiàng),以幫助優(yōu)化生成最終的 bit 文件。
評(píng)論