chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

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

異構(gòu)多處理器產(chǎn)品系列在嵌入式評(píng)估板上實(shí)現(xiàn)

C29F_xilinx_inc ? 來(lái)源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2018-02-26 09:52 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

作者: Alex He (何曄),賽靈思高級(jí)嵌入式應(yīng)用工程師

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

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

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

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

實(shí) 驗(yàn) 報(bào) 告

實(shí)驗(yàn)人員:本人

實(shí)驗(yàn)材料:

硬件設(shè)計(jì)

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

添加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的圖形化的模塊設(shè)計(jì),豐富的IP庫(kù),加上可以上天的智能連接。有點(diǎn)數(shù)字電路設(shè)計(jì)的基礎(chǔ),很快就能完成這個(gè)小設(shè)計(jì)。整個(gè)設(shè)計(jì)如下圖。

軟件設(shè)計(jì)

這里用到 Xilinx 針對(duì) Linux BSP 開(kāi)發(fā)的 Petalinux。它基于Yocto,加入Xilinx的Layers實(shí)現(xiàn)硬件工程的導(dǎo)入,將復(fù)雜的Yocto的設(shè)計(jì)流程打包簡(jiǎn)化,支持一定的用戶(hù)自定義功能,如QEMU仿真運(yùn)行,增加 out-of-tree 的驅(qū)動(dòng),Device tree 修改,應(yīng)用程序編譯打包,等等。具體信息請(qǐng)移步 https://china.xilinx.com/products/design-tools/embedded-software/petalinux-sdk.html

這里簡(jiǎn)單展示一下具體的命令過(guò)程。

$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

這里只有GPIO UIO。 PIN UIO因?yàn)椴皇荌P,所以相關(guān)信息無(wú)法由工具自動(dòng)生成。所以要做如下修改:

1. 修改GPIO UIO設(shè)備端點(diǎn)

1) 將中斷號(hào)改為93

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

2. 增加 DIP UIO 端點(diǎn)

1) 將compatible改成“generic-uio”

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

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

*DTS里的中斷號(hào)與硬件中斷號(hào)有32的 offset。

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

有兩個(gè)方法來(lái)適配UIO端點(diǎn)和 UIO_PDRV_GENIRQ 驅(qū)動(dòng)

1. bootargs use “uio_pdrv_genirq.of_id=generic-uio”,可以通過(guò)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卡用于啟動(dòng)。

測(cè)試

這里引用下關(guān)于uio_pdrv_genirq驅(qū)動(dòng)的介紹

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

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

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

檢查/proc/interrupts

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

測(cè)試DIP UIO方法一

通過(guò)撥動(dòng)2個(gè)DIP,觀察到

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

測(cè)試DIP UIO方法二

前面的方法比較low,這里有稍微高級(jí)的享受。寫(xiě)個(gè)簡(jiǎn)單的用戶(hù)態(tài)驅(qū)動(dòng)程序,上代碼。

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

運(yùn)行測(cè)試程序并配合DIP開(kāi)關(guān)測(cè)試。(為了更好的體現(xiàn)測(cè)試運(yùn)行情況,在UIO內(nèi)核驅(qū)動(dòng)里增加了irqcontrol的調(diào)用打?。?/span>

測(cè)試GPIO UIO

UIO驅(qū)動(dòng)會(huì)將設(shè)備內(nèi)存(寄存器)空間枚舉出來(lái),由用戶(hù)態(tài)驅(qū)動(dòng)程序通過(guò)mmap導(dǎo)出進(jìn)行讀寫(xiě)控制。參見(jiàn)AXI_GPIO IP的文檔pg144-axi-gpio.pdf,其寄存器如下。

測(cè)試應(yīng)用程序會(huì)通過(guò)設(shè)置GIER和IP_IER來(lái)使能中斷。上代碼。

測(cè)試過(guò)程

或許你覺(jué)得這么貼圖代碼不厚道而不能施展復(fù)制黏貼大法,可不知我拙與WORD,沒(méi)try出好排版。莫急莫急,這里有GIT,https://gitenterprise.xilinx.com/AlexHe/UIO_Linux_Demo

硬件資源文件和Image,測(cè)試代碼一個(gè)都不能少,統(tǒng)統(tǒng)獻(xiàn)上。酸爽否?

實(shí) 驗(yàn) 結(jié) 論

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

參考文獻(xiàn)

The Userspace I/O HOWTO https://01.org/linuxgraphics/gfx-docs/drm/driver-api/uio-howto.html

[Xilinx Document]

[1] UG1182 - ZCU102 評(píng)估板用戶(hù)指南

[2] UG1085 - Zynq UltraScale+ MPSoC 技術(shù)參考手冊(cè)

[3] UG1144 - PetaLinux 工具文檔:參考指南

[4] UG940 - Vivado Design Suite 培訓(xùn): 嵌入式處理器硬件設(shè)計(jì)

[5] PG144 - AXI GPIO v2.0 產(chǎn)品指南

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

    關(guān)注

    33

    文章

    1798

    瀏覽量

    133281
  • 異構(gòu)多處理器
    +關(guān)注

    關(guān)注

    0

    文章

    4

    瀏覽量

    9759
  • zcu102
    +關(guān)注

    關(guān)注

    0

    文章

    24

    瀏覽量

    7572

原文標(biāo)題:如何在 Zynq UltraScale+ MPSoC 上實(shí)現(xiàn) Linux UIO 設(shè)計(jì)

文章出處:【微信號(hào):xilinx_inc,微信公眾號(hào):賽靈思】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    新品上市!AMD Zynq UltraScale+MPSoC EG異構(gòu)多處理開(kāi)發(fā)平臺(tái)

    。AMDZynqUltraScale+MPSoCEG系列是AMD推出的高性能多處理器系統(tǒng)芯片(MPSoC),主要面向需要強(qiáng)大處理能力和靈活硬件加速的復(fù)雜應(yīng)用。集成了高性能
    的頭像 發(fā)表于 01-12 08:18 ?775次閱讀
    新品上市!AMD Zynq UltraScale+MPSoC EG<b class='flag-5'>異構(gòu)</b><b class='flag-5'>多處理</b>開(kāi)發(fā)平臺(tái)

    arm嵌入式主板優(yōu)缺點(diǎn)

    設(shè)備里面做控制、數(shù)據(jù)處理使用的CPU。一般作為工控主板使用。   ARM處理器是一種16/32位的嵌入式RISC微處理器,具有低成本、高
    發(fā)表于 01-08 07:08

    AMD重磅打造邊緣AI,CES2026官宣這顆嵌入式處理器!

    Research 預(yù)測(cè),2021-2026 年具備邊緣機(jī)器學(xué)習(xí)功能的設(shè)備出貨量年復(fù)合增長(zhǎng)率達(dá)24.5%。作為AMD的三大支柱業(yè)務(wù)之一的嵌入式產(chǎn)品,囊括FPGA、銳龍、EPYC嵌入式處理器
    的頭像 發(fā)表于 01-07 15:19 ?5860次閱讀
    AMD重磅打造邊緣AI,CES2026官宣這顆<b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b>!

    探索 KIT_XMC71_EVK_LITE_V1 XMC7100 評(píng)估嵌入式開(kāi)發(fā)新選擇

    探索 KIT_XMC71_EVK_LITE_V1 XMC7100 評(píng)估嵌入式開(kāi)發(fā)新選擇 嵌入式開(kāi)發(fā)領(lǐng)域,一款合適的
    的頭像 發(fā)表于 12-19 16:15 ?284次閱讀

    OPTIGA? Trust Adapter:嵌入式安全解決方案評(píng)估利器

    OPTIGA? Trust Adapter是一款PCB適配器,其主要功能是將OPTIGA?產(chǎn)品系列的附加或樣品芯片連接到帶有Arduino兼容連接的微控制
    的頭像 發(fā)表于 12-19 11:50 ?271次閱讀

    AMD推出 EPYC 嵌入式 2005 系列處理器 滿(mǎn)足長(zhǎng)期部署需求

    AMD 推出 AMD EPYC(霄龍)嵌入式 2005 系列處理器正是為了滿(mǎn)足這些不斷演進(jìn)的需求。該系列處理器以小巧的 BGA(球柵陣列)封
    的頭像 發(fā)表于 12-17 09:53 ?6.5w次閱讀
    AMD推出 EPYC <b class='flag-5'>嵌入式</b> 2005 <b class='flag-5'>系列</b><b class='flag-5'>處理器</b> 滿(mǎn)足長(zhǎng)期部署需求

    嵌入式和FPGA的區(qū)別

    開(kāi)發(fā)中做出更明智的技術(shù)選擇。 基本概念解析 嵌入式系統(tǒng)(Embedded System)是一種專(zhuān)用計(jì)算機(jī)系統(tǒng),通常包含微處理器/微控制、存儲(chǔ)和專(zhuān)用外圍設(shè)備,被設(shè)計(jì)用于執(zhí)行特定功
    發(fā)表于 11-19 06:55

    AMD 推出 EPYC? 嵌入式 4005 處理器,助力低時(shí)延邊緣應(yīng)用

    AMD宣布推出EPYC?(霄龍)嵌入式4005系列處理器,專(zhuān)為滿(mǎn)足對(duì)實(shí)時(shí)計(jì)算性能和成本效率日益增長(zhǎng)的需求而設(shè)計(jì),同時(shí)還優(yōu)化了系統(tǒng)成本并延長(zhǎng)了網(wǎng)絡(luò)安全設(shè)備和入門(mén)級(jí)工業(yè)邊緣服務(wù)的部署生命
    的頭像 發(fā)表于 09-17 10:37 ?781次閱讀
    AMD 推出 EPYC? <b class='flag-5'>嵌入式</b> 4005 <b class='flag-5'>處理器</b>,助力低時(shí)延邊緣應(yīng)用

    如何在 MA35 系列處理器 (MPU) 開(kāi)發(fā) AMP(非對(duì)稱(chēng)多處理)應(yīng)用程序?

    如何在 MA35 系列處理器 (MPU) 開(kāi)發(fā) AMP(非對(duì)稱(chēng)多處理)應(yīng)用程序,并通過(guò)建立多個(gè)端點(diǎn)的過(guò)程促進(jìn)與其他內(nèi)核的多通道數(shù)據(jù)傳輸。
    發(fā)表于 08-19 06:11

    【老法師】多核異構(gòu)處理器中M核程序的啟動(dòng)、編寫(xiě)和仿真

    文章,小編就將以飛凌嵌入式的OKMX8MP-C開(kāi)發(fā)為例,為大家介紹多核異構(gòu)處理器M核程序的啟動(dòng)配置、程序編寫(xiě)和實(shí)時(shí)仿真的過(guò)程。
    的頭像 發(fā)表于 08-13 09:05 ?3858次閱讀
    【老法師】多核<b class='flag-5'>異構(gòu)</b><b class='flag-5'>處理器</b>中M核程序的啟動(dòng)、編寫(xiě)和仿真

    MicroBlaze處理器嵌入式設(shè)計(jì)用戶(hù)指南

    *本指南內(nèi)容涵蓋了嵌入式設(shè)計(jì)中使用 MicroBlaze 處理器、含存儲(chǔ) IP 核的設(shè)計(jì)、IP integrator 中的復(fù)位和時(shí)鐘拓?fù)浣Y(jié)構(gòu)。獲取完整版《 MicroBlaze
    的頭像 發(fā)表于 07-28 10:43 ?967次閱讀

    AMD嵌入式處理器為您的應(yīng)用添能助力

    AMD 面向嵌入式應(yīng)用打造高性能、高能效處理器,全方位滿(mǎn)足網(wǎng)絡(luò)、存儲(chǔ)、汽車(chē)、工業(yè)、零售、醫(yī)療、測(cè)試與測(cè)量等領(lǐng)域的各種需求。無(wú)論您的應(yīng)用是涉及 AI 加速、機(jī)器視覺(jué)、安全數(shù)據(jù)處理還是高分辨率顯示
    的頭像 發(fā)表于 07-07 14:09 ?1809次閱讀

    服務(wù)級(jí)芯片進(jìn)軍嵌入式市場(chǎng),AMD這顆處理器駕馭AI洪流

    市場(chǎng)進(jìn)行了優(yōu)化,計(jì)算能力與專(zhuān)門(mén)設(shè)計(jì)的嵌入式特性之間實(shí)現(xiàn)平衡,增強(qiáng)產(chǎn)品壽命、系統(tǒng)彈性和嵌入式應(yīng)用開(kāi)發(fā)的便利性。 ? ? 該
    的頭像 發(fā)表于 03-28 09:18 ?3930次閱讀
    服務(wù)<b class='flag-5'>器</b>級(jí)芯片進(jìn)軍<b class='flag-5'>嵌入式</b>市場(chǎng),AMD這顆<b class='flag-5'>處理器</b>駕馭AI洪流

    AMD EPYC嵌入式9005系列處理器的功能特性

    AMD EPYC(霄龍)嵌入式 9005 系列處理器嵌入式應(yīng)用帶來(lái)服務(wù)級(jí)性能。它們基于“Zen 5”架構(gòu),可提供卓越的核心密度、能效和計(jì)
    的頭像 發(fā)表于 03-27 11:30 ?1490次閱讀
    AMD EPYC<b class='flag-5'>嵌入式</b>9005<b class='flag-5'>系列</b><b class='flag-5'>處理器</b>的功能特性

    AMD EPYC嵌入式9005系列處理器發(fā)布

    AMD(超威,納斯達(dá)克股票代碼:AMD )今日宣布推出第五代 AMD EPYC(霄龍)嵌入式處理器,擴(kuò)展其 x86 嵌入式處理器產(chǎn)品組合。
    的頭像 發(fā)表于 03-12 17:08 ?1491次閱讀