汪迅寶
(安徽國際商務職業(yè)學院, 安徽 合肥 230000)
隨著高要求的需求的提出,CDLS的設計目前面臨諸多問題:系統(tǒng)復雜度越來越高,系統(tǒng)成本、周期、實時、高效和低功耗等要求越來越高。當前,CDLS設計常采用現(xiàn)有的集成開發(fā)工具進行建模,如Quartus IDE、Vivado IDE等。為解決出現(xiàn)的問題,首先進行需求分析、建模,然后采用多種驗證方法對所建模型進行驗證。
本設計包含面向XML規(guī)范的復雜數(shù)字邏輯建模與驗證2部分內容,前者為后者提供理論依據(jù)。
(1)面向XML規(guī)范的復雜數(shù)字邏輯建模。結合XML語言的結構化、層次性的特征和數(shù)字邏輯系統(tǒng)建模理論,實現(xiàn)對CDLS建模,達到更加高級的數(shù)字邏輯系統(tǒng)描述的目的,使開發(fā)者只需要考慮模塊功能需求,避免模塊功能的邏輯結構實現(xiàn)的時間開銷。針對高層次復雜邏輯系統(tǒng),采用系統(tǒng)-模型策略(即將復雜的問題分解為多個細小問題),將復雜系統(tǒng)問題細粒度化解決。
(2)面向XML規(guī)范的復雜數(shù)字邏輯驗證。它是利用多級驗證技術對采用XML規(guī)范建立的復雜數(shù)字邏輯模型進行驗證其功能及其時序的正確性。結合了編譯原理中的詞法、語法和語義分析以及電子設計自動化相關理論和技術,包括有效性、功能/時序仿真和基于FPGA開發(fā)板的在線驗證,以實現(xiàn)將XML自動轉換為Verilog并進行仿真驗證,以下載到目標板上進行在線驗證。 本項XModel工具的設計,能夠將用XML規(guī)范描述的數(shù)字邏輯電路自動轉換為Verilog并進行仿真驗證,以便下載到FPGA板上進行在線驗證。
XModel系統(tǒng)的總目標是:基于Microsoft Visual Studio 2010平臺,開發(fā)一個體系結構完善,便于擴展、更新、維護,且具有良好人機交互的復雜數(shù)字邏輯建模與驗證平臺。采用XML源語言設計的數(shù)字邏輯組件,經(jīng)過仿真調試,并進一步轉換為Verilog文件,為下一步利用其他EDA工具下載至FPGA上進行在線驗證。XModel系統(tǒng)的主要功能如圖1所示,其中HDL仿真、HDL綜合、FPGA板級驗證3個模塊使用現(xiàn)有成熟的EDA工具完成。
圖1 系統(tǒng)功能結構圖
根據(jù)系統(tǒng)描述,對Xmodel系統(tǒng)進行模塊分析設計,主要模塊有:語法分析 模塊、詞法分析 模塊、語義分析模塊、XML綜合模塊、有效性驗證模塊、原型仿真模塊。
(1) 詞法分析(XM_Lexer)。它是以源程序字符文件為輸入對象,以源程序語法規(guī)則為策略,從輸入對象中過濾出關鍵字、運算符號以及其他標識符等,并標記。在Xmodel系統(tǒng)的詞法分析的主要功能如圖2所示。
圖2 詞法分析器的功能
(2) 語法分析(XM_Parse)。Xmodel系統(tǒng)以詞法分析為基礎,以源程序語法規(guī)則為基準,分析詞法Fenix中的標記是否符合基準要求,以及標記對應結構是否符合基準要求,如程序設計中的“{”與“}”是否成對出現(xiàn)、“=”兩邊應有2個對象等,分析結果給出相應分析報告或指示,Xmodel系統(tǒng)的語法分析的主要功能如圖3所示。
圖3 語法分析的功能
(3)語義分析(XM_Syn)。Xmodel系統(tǒng)在語法分析和語義分析基礎之上,結合模塊程序完整性,檢測程序中結構中的標記對象的語義規(guī)則,分析標記對象是否符合語義規(guī)則約束,并給出分析結果,如在源程序是否存在變量同名、賦值非法等。
(4)有效性驗證(XM_Eff)。包含完整性驗證(XM_Com)和穩(wěn)定性驗證(XM_Stab)兩方面內容,順序調用模塊XM_Com、XM_Stab;可重用。
在Xmodel系統(tǒng)設計過程中,首先,根據(jù)客戶需求設計出系統(tǒng)組件模型,在模型設計流程里,組件模型與用戶實際需求可能會存在一定差別。為盡快縮小這種差別,盡最大程度滿足客戶需求,可以對早期建立的系統(tǒng)組件模型進行初步驗證檢測,(即有效性檢測),由系統(tǒng)模型完整性和穩(wěn)定性的驗證組成。
(5) 原型仿真(XM_Fs)。原型仿真即對源代碼進行功能仿真,不涉及延時考慮,其作用是:對源代碼進行功能仿真,功能仿真對上生成的XML代碼加入測試信號(激勵文件.in),生成波形,檢查波形結果是否滿足要求,并記錄于波形文件內。
對復雜邏輯組件功能驗證,驗證仿真前,對復雜邏輯組件展開處理,約定輸入信號組,驗證各子組件的端口信號變換,生成輸出結果。
(6)系統(tǒng)實例驗證。本文以全加器的XML描述為例,使用XModel系統(tǒng)對其進行設計驗證,設計驗證步驟主要有:源文件輸入、仿真、綜合,后續(xù)驗證可調用第3方EDA工具進行。
本項設計的建模與驗證工具XModel不需要高端的硬件設備,具有很高的可行性,可擴展性強,適用于各種數(shù)字邏輯開發(fā)。本項目設計的建模與驗證工具XModel具有如下創(chuàng)新點:① 采用XML描述數(shù)字邏輯電路;② 采用組件式建模,便于復用;③ XModel系統(tǒng)可將XML自動轉換為Verilog并進行驗證。
當前,建模與驗證工具多數(shù)為直接采用Verilog和VHDL描述數(shù)字邏輯,而此設計采用XML描述數(shù)字邏輯,易于開發(fā)者進行開發(fā)。