摘要:傳統(tǒng)測試儀器普遍存在生產(chǎn)出來后普通用戶難以改變其相對固定的功能,無法滿足多樣性的測量?;诖吮疚拈_發(fā)了基于FPGA的可重構(gòu)智能儀器,利用SOPC Builder軟件在FPGA中嵌入了Nios II處理器系統(tǒng),采用可重構(gòu)的應(yīng)用框架技術(shù)利用HAL系統(tǒng)庫進行軟件設(shè)計。解決了由于測試對象復(fù)雜、測試設(shè)備多、測試資源利用率低所造成的測試系統(tǒng)的生產(chǎn)、維修成本過高,資源浪費等問題。
0 引言
傳統(tǒng)測試系統(tǒng)由于專用性強、相互不兼容、擴展性差、缺乏通用化、模塊化,不能共享 軟硬件組成,不僅使開發(fā)效率低下,而且使得開發(fā)一套復(fù)雜測試系統(tǒng)的價格高昂[1]。 目前,傳統(tǒng)的分析儀表正在更新?lián)Q代,向數(shù)字化,智能化方向邁進[2]。改變以往由儀器 生產(chǎn)廠家定義儀器功能、用戶只能使用的局面,使用戶可自定義儀器、根據(jù)不同測試需求對 儀器進行重構(gòu),已經(jīng)成為現(xiàn)代測試技術(shù)發(fā)展的一個重要方面。由于其能夠大大減少測試設(shè)備 的維修成本、提高資源利用率,可重構(gòu)儀器技術(shù)已引起高度重視。
1 可重構(gòu)技術(shù)
目前對可重構(gòu)性還沒有形成公認的定義。可重構(gòu)性一般是指在一個系統(tǒng)中,其硬件模塊 或(和)軟件模塊均能根據(jù)變化的數(shù)據(jù)流或控制流對結(jié)構(gòu)和算法進行重新配置(或重新設(shè)置)。
在可重構(gòu)系統(tǒng)(Reconfigurable System)中,硬件信息(可編程器件的配置信息)也可 以像軟件程序一樣被動態(tài)調(diào)用或修改。這樣既保留了硬件計算的性能,又兼具軟件的靈活性。 尤其是大規(guī)模可編程器件FPGA 的出現(xiàn),實時電路重構(gòu)思想逐漸引起了學(xué)術(shù)界的關(guān)注[3]???重構(gòu)的實現(xiàn)技術(shù)又很多種方式,包括DSP 重構(gòu)技術(shù)、FPGA 重構(gòu)、DSP+FPGA 重構(gòu)、可重 組算法邏輯體系結(jié)構(gòu)、可進化硬件(EHW)、本地重構(gòu)/Internet 遠程重構(gòu)、SOPC/SOC 重構(gòu)。
可重構(gòu)技術(shù)具有以下優(yōu)點:
1)可重構(gòu)技術(shù)能夠高效地實現(xiàn)特定功能??芍貥?gòu)邏輯器件上都是硬連線邏輯,它通過 改變器件的配置來改變功能。2)可重構(gòu)技術(shù)能夠動態(tài)改變器件配置,靈活滿足多種功能的 需求。3)可重構(gòu)技術(shù)適合惡劣工作環(huán)境下的應(yīng)用。利用可重構(gòu)邏輯器件的一個優(yōu)勢是不需 要微處理器必需的散熱系統(tǒng),大大減少了電子產(chǎn)品占據(jù)的空間。4)可重構(gòu)技術(shù)具有強大的 技術(shù)支持來加速產(chǎn)品開發(fā)。5)可重構(gòu)技術(shù)的使用能夠大大降低系統(tǒng)成本。另外,對于不會 同時被使用的功能,可考慮利用動態(tài)重構(gòu)技術(shù)在不同的需求時段里分別實現(xiàn),做到“一片多 用”,節(jié)省了資源、空間和成本。
2 可重構(gòu)智能儀器硬件設(shè)計
2.1 可重構(gòu)儀器硬件結(jié)構(gòu)
可重構(gòu)智能儀器技術(shù)將先進的微電子技術(shù)、半導(dǎo)體技術(shù)和微處理器技術(shù)引入儀器設(shè)計領(lǐng) 域,通過構(gòu)建通用的硬件平臺,最終由用戶通過選擇不同的軟件來實現(xiàn)不同的儀器功能,因 此軟硬件在可重構(gòu)儀器設(shè)計技術(shù)中同樣關(guān)鍵。
可重構(gòu)智能儀器硬件結(jié)構(gòu)由 Nois II 處理器系統(tǒng)(包括可重構(gòu)FPGA 芯片、FPGA 片外 系統(tǒng))和計算機組成,其硬件結(jié)構(gòu)框圖如圖1 所示。
可重構(gòu) FPGA 選用Altera 公司Cyclone II 系列中的EP2C35F672C6 芯片,片外系統(tǒng)主要 包括SDRAM 存儲器、Flash 存儲器、模數(shù)轉(zhuǎn)換芯片、數(shù)模轉(zhuǎn)換芯片、EPC16 增強型配置芯 片、MAX232 芯片等組成。片外系統(tǒng)實現(xiàn)數(shù)據(jù)的采集、預(yù)處理、存儲和輸出等功能。
2.2 控制核
在基于 FPGA 的可重構(gòu)智能儀器中,EP2C35F672C6 是整個系統(tǒng)的核心,為了實現(xiàn)FPGA 與其他芯片、器件的正確通信、數(shù)據(jù)交換,需要在FPGA 上配置Nios II 軟核處理器以及其 他控制器核。
(一)Nios II 嵌入式處理器的設(shè)置。首先在Quartus II 下建立一個Project,在SOPC Builder 中選擇組件列表中的Nios II Processor-Altera Corporation,考慮到芯片的性能以及資 源利用率,選擇Nios II/s(標準型)CPU,在Cache & Tightly Coupled Memories 標簽下設(shè)置 Instruction Cache 為4KB。在JTAG Debug Module 標簽下選擇Level 3,可設(shè)置2 個硬斷點、 2 個數(shù)據(jù)觸發(fā)、指令跟蹤和片上系統(tǒng)。整個Debug 模塊將占用2400~2700 個LE,4 個M4K。
(二)添加SDRAM 控制器內(nèi)核。在SOPC Builder 組件選擇欄中選擇Avalon Components→Memory→SDRAM Controller,加入SDRAM 控制器核,。在Data Width(數(shù)據(jù) 總線寬度)下拉列表框中選擇16Bits,其余設(shè)置不變,因為都滿足SDRAM 芯片IS42S16400 的參數(shù)要求。Timing 選項卡的參數(shù)也滿足芯片要求,不必修改。
(三)添加 Flash 控制器。在對硬件系統(tǒng)進行編程控制時,F(xiàn)lash 用于存儲應(yīng)用程序。 在SOPC Builder 的組件選擇欄中選擇Avalon Components→Bridge→Avalon Tri-State Bridge, 加入Avalon 三態(tài)總線橋; 在SOPC Builder 的組件選擇欄中選擇AvalonComponents→Memery→Flash Memery(Common Flash Interface),添加CFI 控制器。
( 四) 定時器設(shè)置。在SOPC Builder 組件選擇欄中選擇Avalon Components→Other→Interval timer,加入定時器核。定時器的硬件配置選項會影響定時器的 硬件結(jié)構(gòu),SOPC 提供了簡單周期中斷配置、完全功能配置和看門狗配置三種硬件配置。
(五)添加 SPI 核。采用的A/D 轉(zhuǎn)換芯片和D/A 轉(zhuǎn)換芯片都是基于SPI 總線進行數(shù)據(jù) 傳輸?shù)?,要實現(xiàn)Nios II 系統(tǒng)對轉(zhuǎn)換芯片的控制必須添加SPI 核。在SOPC Builder 組件選擇 欄中選擇Avalon Components→Communication→SPI(3 Wire Serial),配置SPI 核。由于用到 的模數(shù)轉(zhuǎn)換芯片AD7810 和數(shù)模轉(zhuǎn)換芯片AD5611 對于Nios II 系統(tǒng)來說都是從SPI 器件, 所以在FPGA 中添加兩個主SPI 核分別控制A/D 和D/A 轉(zhuǎn)換芯片。
2.3 可重構(gòu)配置文件生成
在完成可重構(gòu)智能儀器的各個控制器核之后,要生成相應(yīng)的配置文件,才能配置FPGA 芯片,使其實現(xiàn)各種功能。
配置是對 FPGA 的內(nèi)容進行編程的一個過程。目前大部分FPGA 都是基于SRAM 工藝 的,而SRAM 工藝的芯片在掉電后信息就會丟失,需要外加專用配置芯片,在上電時,由 這個專用配置芯片把配置數(shù)據(jù)加載到FPGA 中,之后FPGA 就可以正常工作了。
在被動模式(PS)方式下,F(xiàn)PGA 處于完全被動的地位。FPGA 接收配置時鐘、配置命 令和配置數(shù)據(jù),給出配置的狀態(tài)信號以及配置完成指示信號等。PS 配置時序如圖2 所示:
根據(jù) SOPC Builder 中對FPGA 添加的各種控制器核,利用Quatus II 軟件例化Nios II 處 理器,生成了完整的FPGA 內(nèi)部頂層模塊圖,如圖3 所示。然后利用引腳規(guī)劃器Pin Planner 對其進行引腳分配。最后用進行Compilation,生成.sof 和.pof 配置文件,完成硬件設(shè)計。
2.4 外圍電路設(shè)計
外圍電路設(shè)計包括存儲器設(shè)計、AD 轉(zhuǎn)換電路設(shè)計、DA 轉(zhuǎn)換設(shè)計、顯示電路設(shè)計、開 關(guān)量DI、DO 設(shè)計和RS232 通信設(shè)計等。
儀器上的存儲器包含 1 片8M 字節(jié)的SDRAM 和一片32M 字節(jié)的FLASH 存儲器。限于 篇幅SDRAM(IS42S16400)與EP2C35F672C6 連接的引腳、FLASH 存儲器(AT49BV163) 與EP2C35F672C6 連接的引腳分配這里不再贅述。
A/D 轉(zhuǎn)換電路采用了AD7810 芯片、DA 轉(zhuǎn)換電路采用AD5611 芯片。
DI、DO 均為16 路,數(shù)字端口滿足標準TTL 電氣特性。數(shù)字量輸入最低的高電平為2V, 數(shù)字量輸入最高的低電平為0.8V;數(shù)字量輸出最低的高電平為3.4V,數(shù)字量輸出最高的低 電平為0.5V。DI、DO 部分的電路如圖4 所示:
3 可重構(gòu)智能儀器軟件設(shè)計
3.1 可重構(gòu)儀器軟件結(jié)構(gòu)
可重構(gòu)智能儀器的軟件結(jié)構(gòu)如圖 5 所示。
系統(tǒng)軟件模塊庫:包含軟件控制模塊、RS232 通訊模塊、模數(shù)轉(zhuǎn)換模塊、數(shù)模轉(zhuǎn)換模塊、 顯示模塊和DI、DO 開關(guān)量模塊。通過軟件控制模塊選擇其他的模塊進行組合就可以實現(xiàn)不 同的軟件功能,從而達到重構(gòu)的目的。
HAL 程序庫實際上包含了各種不同的硬件驅(qū)動,包括MAX232 驅(qū)動、AD 轉(zhuǎn)換芯片驅(qū) 動、DA 轉(zhuǎn)換芯片驅(qū)動、FPGA 的I/O 引腳驅(qū)動等。
通過選擇軟件模塊庫中的軟件模塊,就可以調(diào)用 HAL 程序庫中相應(yīng)的硬件驅(qū)動,從而 實現(xiàn)上層應(yīng)用程序?qū)Φ讓佑布目刂?。軟件模塊的可重構(gòu)性對應(yīng)了底層硬件的可重構(gòu)性。
3.2 基于HAL 的可重構(gòu)智能儀器軟件開發(fā)
硬件抽象層(HAL, Hardware Abstraction Layer),是指在應(yīng)用程序和系統(tǒng)硬件之間的一 個系統(tǒng)庫(System Library),為嵌入式系統(tǒng)與硬件通信的程序提供簡單的設(shè)備驅(qū)動接口。 SOPC Builder 是一個自動化的SOPC 硬件系統(tǒng)工具?;贖AL 的軟件系統(tǒng)由兩個Nios II 工 程所構(gòu)建,用戶的程序包含在一個工程中(用戶應(yīng)用工程),該工程依賴一個獨立的系統(tǒng)庫 工程(HAL 系統(tǒng)庫工程)。用戶應(yīng)用工程包含開發(fā)的所有代碼,編譯該工程可以產(chǎn)生可執(zhí)行 文件。HAL 系統(tǒng)庫工程包含涉及處理器硬件接口的所有信息。系統(tǒng)庫工程依賴于由SOPC Builder 產(chǎn)生的擴展名為.ptf 的Nios II 處理器系統(tǒng)。
由于該工程的依賴結(jié)構(gòu),如果 SOPC Builder 生成的系統(tǒng)改變(即.ptf 文件已修改),則 Nios II IDE 管理HAL 系統(tǒng)庫并且修改驅(qū)動配置來正確的反應(yīng)系統(tǒng)硬件。HAL 系統(tǒng)庫將用戶 程序與底層硬件變化分離開來,這樣,用戶可以不用考慮自己的程序是否與目標硬件匹配來 開發(fā)和調(diào)試代碼,簡而言之,基于HAL 系統(tǒng)庫的程序和目標硬件是同步的。
由于 HAL 系統(tǒng)庫中包含有各種不同的硬件驅(qū)動,用戶可以根據(jù)特定的設(shè)計需要調(diào)用 HAL 系統(tǒng)庫中的相應(yīng)硬件驅(qū)動,從而實現(xiàn)對不同硬件系統(tǒng)的控制,來達到可重構(gòu)設(shè)計的目的。本文所設(shè)計的基于HAL 系統(tǒng)庫的可重構(gòu)智能儀器軟件系統(tǒng)如6 示。在系統(tǒng)軟件控制界 面中選擇了某一功能后,該功能就會調(diào)用HAL 程序庫中相應(yīng)的一些硬件驅(qū)動,從而實現(xiàn)對 硬件設(shè)備的控制。
4 系統(tǒng)分析
基于 FPGA 的可重構(gòu)智能儀器主要是針對目前測試儀器生產(chǎn)出來后功能不能改變、維護 費費用過高、資源浪費嚴重等問題。提出基于FPGA 的可重構(gòu)智能儀器的硬件結(jié)構(gòu)和軟件結(jié) 構(gòu),實現(xiàn)了八種不同的功能,借鑒虛擬儀器的思想,開發(fā)了基于FPGA 的可重構(gòu)智能儀器演 示系統(tǒng),該系統(tǒng)具有A/D 采集、D/A 輸出和開關(guān)量控制三種功能。
本文作者創(chuàng)新點:基于SOPC技術(shù)進行可重構(gòu)設(shè)計;采用了FPGA增強型配置芯片EPC16; 軟件重構(gòu)采用了應(yīng)用框架的復(fù)用技術(shù)。
參考文獻:
[1].EPC16 datasheethttp://www.dzsc.com/datasheet/EPC16+_2058986.html.
[2].MAX232 datasheethttp://www.dzsc.com/datasheet/MAX232+_1074207.html.
[3].Memorydatasheethttp://www.dzsc.com/datasheet/Memory_1082507.html.
[4].IS42S16400 datasheethttp://www.dzsc.com/datasheet/IS42S16400+_1729380.html.
[5].AD7810 datasheethttp://www.dzsc.com/datasheet/AD7810+_1055470.html.
[6].AD5611 datasheethttp://www.dzsc.com/datasheet/AD5611+_248346.html.
[7].DA datasheethttp://www.dzsc.com/datasheet/DA+_1093508.html.
[8].RS232 datasheethttp://www.dzsc.com/datasheet/RS232+_585128.html.
[9].TTL datasheethttp://www.dzsc.com/datasheet/TTL+_1174409.html.
[10].ptf datasheethttp://www.dzsc.com/datasheet/ptf+_2043378.html.
來源:xinxin0次