0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

Xilinx賽靈思官微 ? 來源:djl ? 作者:賽靈思Alex He ? 2019-07-27 11:53 ? 次閱讀

這里的 UIO 即 Userspace I/O,本文中 UIO 泛指 UIO 設備和 UIO 驅(qū)動。它在 Linux kernel 的世界里比較小眾,主要是一些定制設備和相應的驅(qū)動。UIO內(nèi)核驅(qū)動指負責將中斷和設備內(nèi)存暴露給用戶空間,再由UIO用戶態(tài)驅(qū)動(Application)來實現(xiàn)具體的業(yè)務,隨心所欲的玩。學術點叫做高度定制化,柔性設計。

那怎么和 FPGA 扯上了關系呢?是的,F(xiàn)PGA在硬件世界里也是隨心所欲的玩,這一硬一軟還真是登對,在一起啊在一起。

本實驗工程將介紹如何利在賽靈思異構(gòu)多處理器產(chǎn)品系列 Zynq UtralScale+ MPSoC ZCU102 嵌入式評估板上實現(xiàn)多個 UIO,同時借助賽靈思的工具完成硬件工程和 linux BSP 的開發(fā),最后通過測試應用程序完成測試。

ZCU102上的 MPSoC 集成固化了四核 ARM Cortex-A53,雙核Cortex-R5 以及 Mali-400 MP2 GPU,這部分官方稱為PS(Processing System)。另外一部分就是FPGA,即 PL(Programmable Logic)。PS端實現(xiàn)控制,PL用來實現(xiàn)應用加速,兩者通過AXI連接。跑這個小實驗,呵呵,大材小用。只是本人手頭正好有這個板子不得不裝。筒子們可以去買了個Zybo 或者ZedBoard 開發(fā)板, 在板子試試身手。

實 驗 報 告

實驗人員:本人

實驗材料:

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

硬件設計

建立Vivado工程,適配 ZCU102 EVB。通過 IP Integrator 加入PS,在 PL 側(cè)加入5個UIO輸入,其中1個是GPIO模塊(包含中斷輸出和設備內(nèi)存),另外4個是PIN連接到ZCU102 EVB上的DIP開關,作為中斷輸入通過一個concat IP連接到PS的ps_pl_irq管腳。板級細節(jié)請參考[1] UG1182,芯片資料參考[2] UG1085

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

添加PIN約束文件,

set_property PACKAGE_PIN AN13 [get_ports pl_irq_ll]

set_property IOSTANDARD LVCMOS33 [get_ports pl_irq_ll]

set_property PACKAGE_PIN AM14 [get_ports pl_irq_lh]

set_property IOSTANDARD LVCMOS33 [get_ports pl_irq_lh]

set_property PACKAGE_PIN AP14 [get_ports pl_irq_ef]

set_property IOSTANDARD LVCMOS33 [get_ports pl_irq_ef]

set_property PACKAGE_PIN AN14 [get_ports pl_irq_er]

set_property IOSTANDARD LVCMOS33 [get_ports pl_irq_er]

Vivado的圖形化的模塊設計,豐富的IP庫,加上可以上天的智能連接。有點數(shù)字電路設計的基礎,很快就能完成這個小設計。整個設計如下圖。

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

軟件設計

這里用到 Xilinx 針對 Linux BSP 開發(fā)的 Petalinux。它基于Yocto,加入Xilinx的Layers實現(xiàn)硬件工程的導入,將復雜的Yocto的設計流程打包簡化,支持一定的用戶自定義功能,如QEMU仿真運行,增加 out-of-tree 的驅(qū)動,Device tree 修改,應用程序編譯打包,等等。

這里簡單展示一下具體的命令過程。

$petalinux-create -t project --template zynqMP -n zcu102-pl2ps_irq

$cd ./ zcu102-pl2ps_irq

$petalinux-config --get-hw-description

$petalinux-config -c kernel

Enable UIO_PDRV_GENIRQ driver

CONFIG_UIO=y

# CONFIG_UIO_CIF is not set

CONFIG_UIO_PDRV_GENIRQ=y

$petalinux-build -c device-tree

PL側(cè)的dtsi文件生成與./components/plnx_workspace/device-tree-generation/pl.dtsi

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

這里只有GPIO UIO。 PIN UIO因為不是IP,所以相關信息無法由工具自動生成。所以要做如下修改:

1. 修改GPIO UIO設備端點

1) 將中斷號改為93

2) 將compatible改成“generic-uio” //我們后面要用 Linux 自帶的 UIO_PDRV_GENIRQ 驅(qū)動

2. 增加 DIP UIO 端點

1) 將compatible改成“generic-uio”

2) 依次設置中斷值89到93

3) 按照每個 DIP PIN 的 interrupt trigger type 設置屬性值

*DTS里的中斷號與硬件中斷號有32的 offset。

Petalinux 提供了自定義DTS文件./project-spec/meta-user/recipes-bsp/device-tree/files/system-user.dtsi,將以上修改定義到system-user.dtsi.

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

有兩個方法來適配UIO端點和 UIO_PDRV_GENIRQ 驅(qū)動

1. bootargs use “uio_pdrv_genirq.of_id=generic-uio”,可以通過DTS定義。

2. insmod uio_pdrv_genirq.ko of_id=generic-uio when install the driver

修改完后,編譯出Image.

$petalinu-build

$cd ./images/linux

$petalinux-package --boot --fsbl zynqmp_fsbl.elf --fpga --atf --pmufw --u-boot --force

將生成的BOOT.bin(bootloader)和image.ub(FIT uImage)拷貝到SD卡用于啟動。\

測試

這里引用下關于uio_pdrv_genirq驅(qū)動的介紹

https://01.org/linuxgraphics/gfx-docs/drm/driver-api/uio-howto.html

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

結(jié)合驅(qū)動代碼./drviver/uio/uio_pdrv_genirq.c)可知,每個UIO設備會有對應的/dev/uioX的設備節(jié)點。用戶態(tài)驅(qū)動程序的讀操作會阻塞直到UIO硬件中斷發(fā)生。UIO的中斷處理程序uio_pdrv_denirq_handler()會關閉該硬件中斷。用戶態(tài)驅(qū)動程序需要通過write函數(shù)來觸發(fā)uio_pdrv_genirq_irqcontrol()以完成中斷的使能和關閉。代碼如下,

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

啟動內(nèi)核及加載uio_pdrv_genirq驅(qū)動

檢查/proc/interrupts

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

細心的你一定發(fā)現(xiàn)了一個坑,少了2個UIO中斷(IRQ122和IRQ124),原來是硬件不支持Edge falling和Level Low的觸發(fā)模式。kernel log如下。

測試DIP UIO方法一

通過撥動2個DIP,觀察到

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

2個DIP中斷發(fā)生了,可是不論怎么再撥動DIP開關,始終是1。前文鋪墊過,這個中斷在驅(qū)動的中斷處理程序里會被關掉,需要通過應用程序調(diào)用write()來打開。這里有個easy way,使用萬能的echo命令“echo 0x1 > /dev/uioX”,再配合DIP可以觸發(fā)多次中斷。

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

測試DIP UIO方法二

前面的方法比較low,這里有稍微高級的享受。寫個簡單的用戶態(tài)驅(qū)動程序,上代碼。

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

借助petalinux提供的交叉編譯工具編譯出bin文件,拷貝到啟動SD卡。

運行測試程序并配合DIP開關測試。(為了更好的體現(xiàn)測試運行情況,在UIO內(nèi)核驅(qū)動里增加了irqcontrol的調(diào)用打印)

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

測試GPIO UIO

UIO驅(qū)動會將設備內(nèi)存(寄存器)空間枚舉出來,由用戶態(tài)驅(qū)動程序通過mmap導出進行讀寫控制。參見AXI_GPIO IP的文檔pg144-axi-gpio.pdf,其寄存器如下。

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

測試應用程序會通過設置GIER和IP_IER來使能中斷。上代碼。

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

測試過程

在賽靈思異構(gòu)多處理器產(chǎn)品系列嵌入式評估板上實現(xiàn)多個 UIO

或許你覺得這么貼圖代碼不厚道而不能施展復制黏貼大法,可不知我拙與WORD,沒try出好排版。莫急莫急,這里有GIT,

實 驗 結(jié) 論

UIO這種可高度自定義的設備結(jié)合Xilinx的MPSoC可以實現(xiàn)非常靈活的應用。Xilinx提供的完備的工具集,給用戶帶來了高效的開發(fā)體驗。本例雖然簡單,但Xilinx所推崇的All Programmable的概念和實際的FPGA加速應用的的確確是建立在這些軟硬件協(xié)同技術之上。忘周知!

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 開發(fā)板
    +關注

    關注

    25

    文章

    4846

    瀏覽量

    96887
  • 編譯
    +關注

    關注

    0

    文章

    647

    瀏覽量

    32745
  • 異構(gòu)多處理器

    關注

    0

    文章

    4

    瀏覽量

    9658
收藏 人收藏

    評論

    相關推薦

    異構(gòu)多處理器產(chǎn)品系列嵌入式評估實現(xiàn)

    本實驗工程將介紹如何利異構(gòu)多處理器產(chǎn)品系列
    的頭像 發(fā)表于 02-26 09:52 ?8169次閱讀

    嵌入式系統(tǒng)選擇合適的多處理器(一)

    成本是很多嵌入式系統(tǒng)設計的關鍵。為削減成本,因為考慮到越少的器件意味著越少的成本,所以設計者一般會使用單獨的微處理器處理整個系統(tǒng)。使用多個處理器
    發(fā)表于 12-06 10:20

    多核處理器SoC設計怎么才能滿足嵌入式系統(tǒng)應用?

    )解決方案成為現(xiàn)實。目前的挑戰(zhàn)在于如何在該解決方案的范疇內(nèi)快速完成設計的開發(fā)與創(chuàng)建。嵌入式開發(fā)套件(EDK)工具和IP具有很大的靈活性,那么多核
    發(fā)表于 08-01 07:53

    異構(gòu)多處理器系統(tǒng)Cache一致性解決方案

    SoC技術的發(fā)展使多個異構(gòu)處理器集成到一個芯片成為可能,這種結(jié)構(gòu)已成為提高微處理器性能的重要途徑。與傳統(tǒng)的多處理器系統(tǒng)一樣,Cache一致
    發(fā)表于 09-26 15:02 ?11次下載

    嵌入式處理器選型

    嵌入式處理器分類 處理器造型需考慮的因素 多處理器復雜系統(tǒng)中的應用
    發(fā)表于 02-28 11:57 ?64次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b>選型

    嵌入式異構(gòu)多處理器系統(tǒng)中的通信實現(xiàn)

    摘要:提出一種嵌入式異構(gòu)多處理器系統(tǒng)的結(jié)構(gòu)模型,論述這種系統(tǒng)的通信機制,并闡述基于這種嵌入式異構(gòu)
    發(fā)表于 03-01 01:34 ?47次下載

    強化嵌入式視覺應用與工業(yè)物聯(lián)網(wǎng)產(chǎn)品系列

    (Xilinx)近期宣布透過拓展產(chǎn)業(yè)生態(tài)系與硬件平臺加強其嵌入式視覺應用與工業(yè)物聯(lián)網(wǎng)市場的產(chǎn)品系列。這項發(fā)表強化該公司于2015年全新
    發(fā)表于 02-08 17:37 ?190次閱讀

    面向異構(gòu)多處理器設備的自適應命令解釋系統(tǒng)

    與低功耗的系統(tǒng)需求,但異構(gòu)多處理器結(jié)構(gòu)下軟件編程難度大的問題以及如何優(yōu)化頂層應用在多處理器設備的運行性能都是目前亟待解決的技術難題.針對以上問題,i-計并
    發(fā)表于 12-19 15:06 ?0次下載
    面向<b class='flag-5'>異構(gòu)</b><b class='flag-5'>多處理器</b>設備的自適應命令解釋系統(tǒng)

    Zynq UltraScale+ MPSoC 多個Linux UIO設計

    本實驗工程將介紹如何利異構(gòu)多處理器產(chǎn)品系列
    發(fā)表于 03-21 14:55 ?3262次閱讀
    Zynq UltraScale+ MPSoC <b class='flag-5'>上</b>的<b class='flag-5'>多個</b>Linux <b class='flag-5'>UIO</b>設計

    針對Linux BSP開發(fā)的Petalinux,如何實現(xiàn)硬件工程導入

    本實驗工程將介紹如何利異構(gòu)多處理器產(chǎn)品系列
    的頭像 發(fā)表于 02-27 11:01 ?1.7w次閱讀
    針對Linux BSP開發(fā)的Petalinux,如何<b class='flag-5'>實現(xiàn)</b>硬件工程導入

    嵌入式視覺應用于機器學習的設計方案

    于可編程邏輯的解決方案,例如異構(gòu) All Programmable Zynq -7000 SoC(片系統(tǒng))和 Zynq UltraS
    的頭像 發(fā)表于 07-29 10:49 ?2351次閱讀

    性能優(yōu)良的FPGA嵌入式處理器平臺

    公司昨天宣布了由獨立的第三方對運行Accelerated Technology公司(AT)的Nucleus實時操作系統(tǒng)(RTOS)的32位MicroBlaze處理器平臺進行的測試
    發(fā)表于 06-28 11:38 ?2294次閱讀

    ADSP-BF561:Blackfin嵌入式對稱多處理器數(shù)據(jù)手冊

    ADSP-BF561:Blackfin嵌入式對稱多處理器數(shù)據(jù)手冊
    發(fā)表于 03-21 06:39 ?9次下載
    ADSP-BF561:Blackfin<b class='flag-5'>嵌入式</b>對稱<b class='flag-5'>多處理器</b>數(shù)據(jù)手冊

    GPGPU流式多處理器架構(gòu)剖析(

    流式多處理器(Stream Multi-processor,SM)是構(gòu)建整個 GPU的核心模塊(執(zhí)行整個 Kernel Grid),一個流式多處理器一般同時運行多個線程塊。每個流式
    的頭像 發(fā)表于 04-03 14:28 ?1872次閱讀
    GPGPU流式<b class='flag-5'>多處理器</b>架構(gòu)剖析(<b class='flag-5'>上</b>)

    對稱多處理器和非對稱多處理器的區(qū)別

    隨著計算需求的日益增長,單處理器系統(tǒng)已經(jīng)無法滿足高性能計算的需求。多處理器系統(tǒng)應運而生,它們通過將多個處理器集成到一個系統(tǒng)中來提高計算能力。
    的頭像 發(fā)表于 10-10 15:58 ?239次閱讀