Versal 介紹
Versal 包含了 Cortex-A72 處理器和 Cortex-R5 處理器,PL 端可編程邏輯部分,PMC 平臺(tái)管理控制器,AI Engine 等模塊,與以往的 ZYNQ 7000 和 MPSoC 不同,Versal 內(nèi)部是通過 NoC 片上網(wǎng)絡(luò)進(jìn)行互聯(lián)。
Versal 芯片的總體框圖
Versal 芯片的總體框圖
PS: 處理系統(tǒng) (Processing System) , 就是與 FPGA 無關(guān)的 ARM 的 SoC 的部分。
PL: 可編程邏輯 (Progarmmable Logic), 就是 FPGA 部分。
NoC 架構(gòu)
Versal 可編程片上網(wǎng)絡(luò)(NoC) 是一種 AXI 互連網(wǎng)絡(luò),用于在可編程邏輯 PL,處理器系統(tǒng) PS 等之間共享數(shù)據(jù),而之前的 Versal 系列采用的 AXI 交叉互聯(lián)模塊,這是 Versal 的不同之處。
NoC 是為可擴(kuò)展性而設(shè)計(jì)的。它由一系列相互連接的水平(HNoC)和垂直(VNoC)路徑,由一組可定制的硬件實(shí)現(xiàn)組件支持,這些組件可以以不同的方式進(jìn)行配置,以滿足設(shè)計(jì)時(shí)序、速度和邏輯利用率要求。以下是 NoC 的結(jié)構(gòu)圖
NoC 的結(jié)構(gòu)圖
從 NoC 的結(jié)構(gòu)圖,可以看到,其主要由 NMU(NoC master units),NSU(NoC slave units),NPI(NoC programming interface),NPS(NoC packet switch)組成。PS 端可以連接到 NMU,再通過 NPS 連接訪問到 DDRMC,同樣 PL 端也可以通過 NMU,NPS 訪問到 DDRMC。通過 NPS 路由的方式,靈活地訪問各模塊。
NMU 結(jié)構(gòu)
NSU 結(jié)構(gòu)
從以上的 NMU, NSU 結(jié)構(gòu)可以看到,對用戶的接口仍然是 AXI 總線,在其內(nèi)部,將 AXI 數(shù)據(jù)進(jìn)行組包或解包,連接到 NoC 網(wǎng)絡(luò)。
NPS 結(jié)構(gòu)
而 NMU 和 NSU 都是連接到 NPS 上的,它相當(dāng)于一個(gè)路由器,將數(shù)據(jù)轉(zhuǎn)發(fā)給目的設(shè)備。它是一個(gè)全雙工的 4x4 switch,每個(gè)端口在每個(gè)方向支持 8 個(gè)虛擬通道,采用基于信用的流控,類似于 TCP 的滑動(dòng)窗口。
NoC 是 Versal 開發(fā)中非常重要的部件,PS 端訪問 DDR,PL 端訪問 DDR 都是通過 NoC,與 Versal 不同的是,versal 在 PS 端沒有 DDR 控制器,都是通過 NoC 訪問,因此了解 NoC 結(jié)構(gòu)是很有必要的,更多的內(nèi)容可以參考官方的 pg313 文檔。
PMC 架構(gòu)
PMC(平臺(tái)管理控制器)在啟動(dòng),配置,運(yùn)行時(shí)做平臺(tái)的管理。從下圖的結(jié)構(gòu)圖中可以看出,PMC 由 ROM Code Unit,Platform Processing Unit,PMC I/O Peripherals 等單元組成,功能豐富。在這里主要介紹一下 PMC 是如何引導(dǎo)程序啟動(dòng)的。
PMC 結(jié)構(gòu)圖
第一階段:Pre-Boot
2. PMC 讀取啟動(dòng)模式引腳并存入 boot mode 寄存器
3. PMC 發(fā)送復(fù)位給 RCU(ROM code unit)
第二階段:Boot Setup
4. RCU 從 RCU ROM 中執(zhí)行 BootROM
5. BootROM 讀出 boot mode 寄存器,選擇啟動(dòng)設(shè)備
6. BootROM 從啟動(dòng)設(shè)備讀取 PDI(programmable device image) 并校驗(yàn)
7. BootROM 釋放 PPU 的復(fù)位,將 PLM 加載到 PPU RAM 并校驗(yàn)。校驗(yàn)后,PPU 喚醒,PLM 軟件開始執(zhí)行。
8. BootROM 進(jìn)入睡眠狀態(tài)
第三階段:Load Platform
9. PPU 開始從 PPU RAM 中執(zhí)行 PLM
10. PLM 開始讀取并運(yùn)行 PDI 模塊
11. PLM 利用 PDI 內(nèi)容配置 Versal 其他部分
11a: PLM 為以下模塊配置數(shù)據(jù):PMC, PS clocks
(MIO ,clocks, resets 等)(CDO 文件)
NoC 初始化和 NPI 模塊(DDR 控制器,NoC,
GT,XPIPE,I/Os,clocking 和其他 NPI 模塊
PLM 加載 APU 和 RPU 的應(yīng)用程序 ELF 到存儲(chǔ)空間,
如 DDR,OCM,TCM 等
11b: PL 端邏輯配置
PL 端數(shù)據(jù)(CFI 文件)
AI Engine 配置(AI Engine CDO)
第四階段:Post-Boot
12. PLM 繼續(xù)運(yùn)行,直到下一次 POR 或系統(tǒng)復(fù)位。并負(fù)責(zé) DFX 重配置,電源管理,子系統(tǒng)重啟,錯(cuò)誤管理,安全服務(wù)。
Versal 芯片開發(fā)流程的簡介
由于 Versal 將 CPU 與 FPGA 集成在了一起,開發(fā)人員既需要設(shè)計(jì) ARM 的操作系統(tǒng)應(yīng)用程序和設(shè)備的驅(qū)動(dòng)程序,又需要設(shè)計(jì) FPGA 部分的硬件邏輯設(shè)計(jì)。開發(fā)中既要了解 Linux 操作系統(tǒng),系統(tǒng)的構(gòu)架,也需要搭建一個(gè) FPGA 和 ARM 系統(tǒng)之間的硬件設(shè)計(jì)平臺(tái)。所以 Versal 的開發(fā)是需要軟件人員和硬件硬件人員協(xié)同設(shè)計(jì)并開發(fā)的。這既是 Versal 開發(fā)中所謂的 " 軟硬件協(xié)同設(shè)計(jì)”。
Versal 系統(tǒng)的硬件系統(tǒng)和軟件系統(tǒng)的設(shè)計(jì)和開發(fā)需要用到一下的開發(fā)環(huán)境和調(diào)試工具:Xilinx Vivado。Vivado 設(shè)計(jì)套件實(shí)現(xiàn) FPGA 部分的設(shè)計(jì)和開發(fā),管腳和時(shí)序的約束,編譯和仿真,實(shí)現(xiàn) RTL 到比特流的設(shè)計(jì)流程。
Xilinx Vitis 是 Xilinx 軟件開發(fā)套件 (SDK), 在 Vivado 硬件系統(tǒng)的基礎(chǔ)上,系統(tǒng)會(huì)自動(dòng)配置一些重要參數(shù),其中包括工具和庫路徑、編譯器選項(xiàng)、JTAG 和閃存設(shè)置,調(diào)試器連接已經(jīng)裸機(jī)板支持包 (BSP)。SDK 也為所有支持的 Xilinx IP 硬核提供了驅(qū)動(dòng)程序。Vitis 支持 IP 硬核(FPGA 上)和處理器軟件協(xié)同調(diào)試,我們可以使用高級(jí) C 或 C++ 語言來開發(fā)和調(diào)試 ARM 和 FPGA 系統(tǒng),測試硬件系統(tǒng)是否工作正常。Vitis 軟件也是 Vivado 軟件自帶的,無需單獨(dú)安裝。
Versal 的開發(fā)也是先硬件后軟件的方法。具體流程如下:
在 Vivado 上新建工程,增加一個(gè)嵌入式的源文件。
在 Vivado 里添加和配置 PS 和 PL 部分基本的外設(shè),或需要添加自定義的外設(shè)。
在 Vivado 里生成頂層 HDL 文件,并添加約束文件。再編譯生成比特流文件(*.pdi)。
導(dǎo)出硬件信息到 Vitis 軟件開發(fā)環(huán)境,在 Vitis 環(huán)境里可以編寫一些調(diào)試軟件驗(yàn)證硬件和軟件,結(jié)合比特流文件單獨(dú)調(diào)試 Versal 系統(tǒng)。
在 VMware 虛擬機(jī)里生成 u-boot.elf、 bootloader 鏡像。
在 Vitis 里將比特流文件和 u-boot.elf 文件生成一個(gè) BOOT.pdi 文件。
在 VMware 里生成 Ubuntu 的內(nèi)核鏡像文件 Zimage 和 Ubuntu 的根文件系統(tǒng)。另外還需要要對 FPGA 自定義的 IP 編寫驅(qū)動(dòng)。
把 BOOT、內(nèi)核、設(shè)備樹、根文件系統(tǒng)文件放入到 SD 卡中,啟動(dòng)開發(fā)板電源,Linux 操作系統(tǒng)會(huì)從 SD 卡里啟動(dòng)。
學(xué)習(xí) Versal 要具備哪些技能
學(xué)習(xí) Versal 比學(xué)習(xí) FPGA、MCU、ARM 等傳統(tǒng)工具開發(fā)要求更高,想學(xué)好 Versal 也不是一蹴而就的事情。
軟件開發(fā)人員
計(jì)算機(jī)組成原理
C、C++ 語言
計(jì)算機(jī)操作系統(tǒng)
tcl 腳本
良好的英語閱讀基礎(chǔ)
邏輯開發(fā)人員
計(jì)算機(jī)組成原理
C 語言
數(shù)字電路基礎(chǔ)
訪問ALINX官網(wǎng)了解 Versal AIEdge 自適應(yīng)計(jì)算加速平臺(tái)更多詳情。
如需購買Versal AIEdge 自適應(yīng)計(jì)算加速平臺(tái) SOM 及配套開發(fā)板,請登錄天貓或京東:ALINX旗艦店。
ALINX| AUMO 智能車載
芯驛電子科技(上海)有限公司,成立于 2012 年,總部位于上海松江臨港科技城,高新技術(shù)企業(yè)、上海市專精特新企業(yè),是一家車載智能產(chǎn)品和 FPGA 技術(shù)方案公司,擁有 “AUMO” 和 “ALINX” 兩大品牌,先后獲得國家級(jí)科技型中小企業(yè)認(rèn)定、上海市創(chuàng)新型中小企業(yè)認(rèn)證、ISO9001 質(zhì)量體系認(rèn)證等。
AUMO 品牌專注車載智能產(chǎn)品,提供一站式自動(dòng)駕駛硬件在環(huán)仿真 HIL、電子后視鏡 CMS 產(chǎn)品及方案,與多家車載自動(dòng)駕駛客戶已開展深度合作;ALINX 品牌專注于 FPGA 產(chǎn)品和方案定制,是全球 FPGA 芯片龍頭企業(yè) AMD/XILINX 官方合作伙伴,國內(nèi) FPGA 芯片龍頭企業(yè)紫光同創(chuàng)官方合作伙伴,同時(shí)作為百度 AI 合作伙伴,為百度定制了國產(chǎn) AI 飛槳系統(tǒng)的 Edgeboard 系列邊緣設(shè)備。經(jīng)歷十余年發(fā)展,公司產(chǎn)品已經(jīng)遠(yuǎn)銷海外 30 多個(gè)國家,服務(wù)數(shù)千家企業(yè)客戶。
業(yè)務(wù)范圍
主要聚焦于 FPGA 行業(yè)解決方案,自動(dòng)駕駛 HIL、FPGA 國產(chǎn)化,F(xiàn)PGA SOM 開發(fā)套件。
應(yīng)用領(lǐng)域
公司涉及的行業(yè)解決方案涉及人工智能、自動(dòng)駕駛、醫(yī)療成像、智能制造、數(shù)據(jù)中心、交通電力、5G 通信、機(jī)器視覺、工業(yè)互聯(lián)、儀器儀表、IC 測試等行業(yè)。
審核編輯 黃宇
-
處理器
+關(guān)注
關(guān)注
68文章
19371瀏覽量
230420 -
FPGA
+關(guān)注
關(guān)注
1630文章
21766瀏覽量
604575 -
Xilinx
+關(guān)注
關(guān)注
71文章
2168瀏覽量
121762 -
Versal
+關(guān)注
關(guān)注
1文章
160瀏覽量
7682
發(fā)布評論請先 登錄
相關(guān)推薦
評論