日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

3天內不再提示

異構多處理器產品系列在嵌入式評估板上實現(xiàn)

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

掃碼添加小助手

加入工程師交流群

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

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

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

本實驗工程將介紹如何利在賽靈思異構多處理器產品系列 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ā)板, 在板子試試身手。

實 驗 報 告

實驗人員:本人

實驗材料:

硬件設計

建立Vivado工程,適配 ZCU102 EVB。通過 IP Integrator 加入PS,在 PL 側加入5個UIO輸入,其中1個是GPIO模塊(包含中斷輸出和設備內存),另外4個是PIN連接到ZCU102 EVB上的DIP開關,作為中斷輸入通過一個concat IP連接到PS的ps_pl_irq管腳。板級細節(jié)請參考[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的圖形化的模塊設計,豐富的IP庫,加上可以上天的智能連接。有點數(shù)字電路設計的基礎,很快就能完成這個小設計。整個設計如下圖。

軟件設計

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

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

$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側的dtsi文件生成與./components/plnx_workspace/device-tree-generation/pl.dtsi

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

1. 修改GPIO UIO設備端點

1) 將中斷號改為93

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

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.

有兩個方法來適配UIO端點和 UIO_PDRV_GENIRQ 驅動

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驅動的介紹

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

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

啟動內核及加載uio_pdrv_genirq驅動

檢查/proc/interrupts

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

測試DIP UIO方法一

通過撥動2個DIP,觀察到

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

測試DIP UIO方法二

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

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

運行測試程序并配合DIP開關測試。(為了更好的體現(xiàn)測試運行情況,在UIO內核驅動里增加了irqcontrol的調用打?。?/span>

測試GPIO UIO

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

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

測試過程

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

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

實 驗 結 論

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

參考文獻

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

[Xilinx Document]

[1] UG1182 - ZCU102 評估板用戶指南

[2] UG1085 - Zynq UltraScale+ MPSoC 技術參考手冊

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

[4] UG940 - Vivado Design Suite 培訓: 嵌入式處理器硬件設計

[5] PG144 - AXI GPIO v2.0 產品指南

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

    關注

    33

    文章

    1798

    瀏覽量

    133682
  • 異構多處理器

    關注

    0

    文章

    4

    瀏覽量

    9781
  • zcu102
    +關注

    關注

    0

    文章

    24

    瀏覽量

    7669

原文標題:如何在 Zynq UltraScale+ MPSoC 上實現(xiàn) Linux UIO 設計

文章出處:【微信號:xilinx_inc,微信公眾號:賽靈思】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    華北工控SOMB-6581嵌入式核心:以RK3588多核異構架構賦能關鍵行業(yè)智能化升級

    近期,華北工控正式推出搭載RK3588多核異構處理器的SOMB-6581嵌入式核心,憑借其靈活定制能力、工業(yè)級穩(wěn)定特性及強大的AI算力支持,迅速成為工業(yè)自動化、智慧交通、智慧醫(yī)療等關
    的頭像 發(fā)表于 04-24 11:28 ?1653次閱讀

    探索E MC6W201:多處理器系統(tǒng)的智能環(huán)境監(jiān)測與風扇控制專家

    探索E MC6W201:多處理器系統(tǒng)的智能環(huán)境監(jiān)測與風扇控制專家 引言 多處理器系統(tǒng)的設計領域,如何高效地進行溫度管理、電壓監(jiān)測以及風扇控制一直是工程師們面臨的關鍵挑戰(zhàn)。今天,我們要深入了解一款
    的頭像 發(fā)表于 04-07 10:50 ?118次閱讀

    ADSP - BF561:高性能嵌入式對稱多處理器的深度解析

    ADSP - BF561:高性能嵌入式對稱多處理器的深度解析 電子設計領域,一款優(yōu)秀的處理器對于產品的性能和功能起著至關重要的作用。今天,
    的頭像 發(fā)表于 03-23 17:20 ?812次閱讀

    過時的 Blackfin 嵌入式處理器:ADSP - BF51x 系列

    過時的 Blackfin 嵌入式處理器:ADSP - BF51x 系列 大家好,作為電子工程師,我們設計過程中常常會與各種處理器打交道。今
    的頭像 發(fā)表于 03-23 17:10 ?1194次閱讀

    8-12核、80 TOPS系統(tǒng)級算力!AMD銳龍AI P100嵌入式處理器進階!

    2026年初CES展,AMD推出銳龍嵌入式P100系列處理器4-6核,針對下一代數(shù)字座艙和人機界面HMI 進行優(yōu)化,實現(xiàn)車載信息娛樂顯示屏
    的頭像 發(fā)表于 03-10 18:59 ?6454次閱讀
    8-12核、80 TOPS系統(tǒng)級算力!AMD銳龍AI P100<b class='flag-5'>嵌入式</b><b class='flag-5'>處理器</b>進階!

    AMD銳龍AI嵌入式P100系列處理器產品簡介

    AMD 銳龍 AI 嵌入式 P100 系列處理器代表了 AMD 在車規(guī)級(通過 AECQ 100 認證)和工業(yè)級(寬溫)嵌入式處理器領域的下
    的頭像 發(fā)表于 01-23 09:19 ?2561次閱讀
    AMD銳龍AI<b class='flag-5'>嵌入式</b>P100<b class='flag-5'>系列</b><b class='flag-5'>處理器</b><b class='flag-5'>產品</b>簡介

    新品上市!AMD Zynq UltraScale+MPSoC EG異構多處理開發(fā)平臺

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

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

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

    OPTIGA? Trust Adapter:嵌入式安全解決方案評估利器

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

    AMD推出 EPYC 嵌入式 2005 系列處理器 滿足長期部署需求

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

    AMD 推出 EPYC? 嵌入式 4005 處理器,助力低時延邊緣應用

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

    如何在 MA35 系列處理器 (MPU) 開發(fā) AMP(非對稱多處理)應用程序?

    如何在 MA35 系列處理器 (MPU) 開發(fā) AMP(非對稱多處理)應用程序,并通過建立多個端點的過程促進與其他內核的多通道數(shù)據(jù)傳輸。
    發(fā)表于 08-19 06:11

    【老法師】多核異構處理器中M核程序的啟動、編寫和仿真

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

    MicroBlaze處理器嵌入式設計用戶指南

    *本指南內容涵蓋了嵌入式設計中使用 MicroBlaze 處理器、含存儲 IP 核的設計、IP integrator 中的復位和時鐘拓撲結構。獲取完整版《 MicroBlaze
    的頭像 發(fā)表于 07-28 10:43 ?1325次閱讀

    AMD嵌入式處理器為您的應用添能助力

    AMD 面向嵌入式應用打造高性能、高能效處理器,全方位滿足網絡、存儲、汽車、工業(yè)、零售、醫(yī)療、測試與測量等領域的各種需求。無論您的應用是涉及 AI 加速、機器視覺、安全數(shù)據(jù)處理還是高分辨率顯示
    的頭像 發(fā)表于 07-07 14:09 ?2078次閱讀
    开化县| 江都市| 喀喇沁旗| 南丰县| 新民市| 海丰县| 永城市| 郁南县| 泰来县| 和林格尔县| 阿拉善右旗| 四会市| 临海市| 屯门区| 西丰县| 平安县| 汉沽区| 平乐县| 叙永县| 马关县| 兰坪| 房产| 齐河县| 丁青县| 盐亭县| 青州市| 金寨县| 秭归县| 沙洋县| 辽中县| 拉孜县| 福清市| 景洪市| 佳木斯市| 柳州市| 嘉义县| 肥西县| 南昌市| 中山市| 石嘴山市| 阳春市|