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

當(dāng)前位置:首頁 > 物聯(lián)網(wǎng) > 《物聯(lián)網(wǎng)技術(shù)》雜志
[導(dǎo)讀]摘 要:針對Altera SoC FPGA平臺的Linux環(huán)境下ARM核與FPGA邏輯之間的數(shù)據(jù)交換問題,提出了一種簡單有效的異步接口實現(xiàn)方案。該方案在輕量級總線橋上掛載Avalon 三態(tài)控制器,并通過Linux應(yīng)用程序讀寫控制器對應(yīng)的地址,從而實現(xiàn)ARM核與FPGA邏輯間數(shù)據(jù)的異步交換。實驗結(jié)果表明,該方案能夠穩(wěn)定、正確、快速地讀寫數(shù)據(jù),可達到預(yù)期目標。

引 言

FPGA 硬件資源和ARM 處理器的片內(nèi)緊密耦合是Altera SoC FPGA 體系結(jié)構(gòu)最顯著的優(yōu)勢。Altera SoC FPGA 使用高寬帶干線互聯(lián),在 FPGA 架構(gòu)中集成了基于 ARM 的硬核處理器系統(tǒng)(HPS),該系統(tǒng)包括處理器、外設(shè)和存儲器接口。可同時實現(xiàn)硬核知識產(chǎn)權(quán)(IP)的性能和低功耗,以及可編程邏輯的靈活性 [1]。ARM 的AMBA NIC-301 網(wǎng)絡(luò)互聯(lián)基礎(chǔ)架構(gòu)提供了三種交換架構(gòu)——L3 主交換、L3 主機外設(shè)交換、L3 從機外設(shè)交換。在 L3 主交換和 FPGA 之間則由FPGA- to-HPS 總線橋 、HPS-to-FPGA 總線橋、輕量級的 HPS-to- FPGA 總線橋連接,HPS-to-FPGA 總線橋上可以掛載 AXI 接口邏輯或 Avalon 接口邏輯,實現(xiàn)處理器對FPGA 中寄存器的訪問。

在實際應(yīng)用中,許多功能簡單的FPGA 邏輯與ARM 之間的數(shù)據(jù)交換量不是很多,交換速度要求不高,這樣就可以通過在總線上掛載通用的異步接口來實現(xiàn) ARM 對這類外設(shè)或邏輯的訪問。Altera 提供了一種Avalon Tri-State Conduit Components, 該組件可以實現(xiàn)多種異步接口的時序如 CFI Flash、SSRAM、8086 接口外設(shè)等,可使開發(fā)者快速實現(xiàn)簡單有效的數(shù)據(jù)訪問。

1 硬件設(shè)計

1.1 異步接口的實現(xiàn)

本系統(tǒng)可在友晶科技的DE1-SOC 開發(fā)板上實現(xiàn),其系統(tǒng)架構(gòu)如圖 1 所示。

從圖 1可以看出, 雙核 CortexA9由經(jīng) L3主交換通過輕量級的HPS-to-FPGA總線橋?qū)valon三態(tài)電路組件訪問。Altera提供的 Avalon三態(tài)電路組件包括,通用三態(tài)控制器(GenericTri-StateConduitController)、三態(tài)引腳共享器(Tri-State Conduit Pin Sharer)、三態(tài)橋(Tri-State Conduit)[2]。 通用三態(tài)控制器提供了自定義的數(shù)據(jù)位寬和時序功能,以提供不同的外設(shè)兼容。三態(tài)引腳共享器則可將多個態(tài)控制的地址、數(shù)據(jù)、讀寫信號共享到一個三態(tài)橋上,配合片選信號控制特定的外設(shè),三態(tài)橋則實現(xiàn)了與外界的雙向數(shù)據(jù)通路接口。

基于SoCFPGA異步通信接口的實現(xiàn)

本設(shè)計通過 QuartusII軟件中的 Qsys工具向HPS的輕量級HPS-to-FPGA總線橋主端(h2f_lw_axi_master)添加了Avalon通用三態(tài)電路組件,硬核系統(tǒng)的Qsys互聯(lián)如圖2所示。

基于SoCFPGA異步通信接口的實現(xiàn)

圖2 中ext_bus 即為三態(tài)控制器,其包含片選信號、讀信號、寫信號、片選、讀信號、寫信號、16 位地址線和 16 位數(shù)據(jù)線。

1.2 異步接口解析邏輯的實現(xiàn)

與上述異步接口對應(yīng),解析邏輯包括片選信號 cs_n、讀使能 oe_n、寫使能 wr_n、16 位的地址 addr 和 16 位雙向數(shù)據(jù)線data。當(dāng)cs_n 為低電平且是 oe_n 的下降沿時,總線根據(jù)給出的addr上的地址在相應(yīng)的mem 寄存器上讀取數(shù)據(jù)到data 數(shù)據(jù)線上完成讀操作;當(dāng) cs_n 為低電平且是wr_n 的上跳沿時, 總線根據(jù)給出的addr上的地址將 data 數(shù)據(jù)線上的數(shù)據(jù)寫入對應(yīng)的mem 寄存器完成寫操作。mem 寄存器讀寫的HDL 代碼如下:

基于SoCFPGA異步通信接口的實現(xiàn)

2 軟件設(shè)計

2.1 在設(shè)備樹中添加接口信息

為解決arm 體系內(nèi)核代碼中充斥著大量的板級垃圾代碼, Device Tree(設(shè)備樹)被引入到 Linux 3.x 內(nèi)核中。Device Tree 是一種用以描述硬件的數(shù)據(jù)結(jié)構(gòu),由一系列的硬件節(jié)點和屬性構(gòu)成,許多硬件細節(jié)可以直接透過它傳遞給內(nèi)核 [3]。在修改硬件后,一般要修改相應(yīng)的設(shè)備樹描述文件與之對應(yīng)以便內(nèi)核能正確識別硬件。由于在上述過程中,三態(tài)控制被添加到輕量級的HPS-to-FPGA 總線上,對應(yīng)需要修改相關(guān)設(shè)備描述信息如下:

hps_0_h2f_lw :bridge@0xff200000 {

compatible = "altr,h2f_lw_bridge-1.0","simple-bus" ;

reg = < 0xFF200100 0x00200000 > ;

ranges = < 0x00000100 0xFF200100 0x00000080 

                0x00030000 0xFF230000 0x00010000

              > ;

ext_bus :bus_ctr@0x30000 {

compatible =“altr,generic_tristate_controller-14.0”,

“altr,generic_tristate_controller-1.0”;

reg = < 0x00030000 0x00010000 > ;

} ;//end bus_ctr@0x30000(bus_ctr_0)

} ;//endbridge@0xff200000(hps_0_h2f_lw)

由描述信息可知,ext_bus位于h2f_lw(輕量級的HPS- to-FPGA總線橋)下。它的起始地址為 0xFF23000(總線地址0xff200000 + 偏移地址為 0x30000),地址長度為 0x10000。

2.2 應(yīng)用程序設(shè)計

Linux 應(yīng) 用 程 序 通 過 Linux 內(nèi) 核 的 memory-mapped device 驅(qū)動訪問[4],由ext_bus 所在的物理地址進而實現(xiàn)對ext_bus 所在的地址空間進行讀寫。首先,使用系統(tǒng) open 函數(shù)打開/dev/mem 設(shè)備,然后調(diào)用系統(tǒng) mmap 函數(shù)映射 HPS 的 L3 外設(shè)區(qū)域的物理地址到一個虛擬地址, 并根據(jù)輕量級HPS-to-FPGA 總線相對于L3 外設(shè)區(qū)域基地址的偏移量和ext_bus 相對于輕量級HPS-to-FPGA 總線的偏移量計算出ext_bus 的虛擬地址。讀寫則直接操作對應(yīng)的虛擬地址完成操作,異步總線的地址獲取代碼實現(xiàn)如下:

基于SoCFPGA異步通信接口的實現(xiàn)

3 結(jié) 語

實驗表明,這種設(shè)計方法可以正確有效地完成對異步接口的讀寫操作。其設(shè)計思路非常簡單,只需要將控制器添加到總線上,在應(yīng)用程序中操作相應(yīng)的虛擬地址即可,是一種快速有效的ARM 與FPGA 數(shù)據(jù)交換的實現(xiàn)方式。

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

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉