伦伦影院久久影视,天天操天天干天天射,ririsao久久精品一区 ,一本大道香蕉大久在红桃,999久久久免费精品国产色夜,色悠悠久久综合88,亚洲国产精品久久无套麻豆,亚洲香蕉毛片久久网站,一本一道久久综合狠狠老

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

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

3天內不再提示

如何在 Vitis 中使用 UIO 驅動框架創建簡單的 Linux 用戶應用

電子工程師 ? 來源:XILINX技術社區 ? 作者:XILINX技術社區 ? 2020-11-20 14:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Linux嵌入式設計中最基本的任務之一是創建用戶應用程序。

在本篇博文中,我們將探討如何在 Vitis 中使用 UIO 驅動框架創建簡單的 Linux 用戶應用。

1

硬件設計

本次使用的是 Zynq UltraScale+ MPSoC ZCU104 評估板。但是,無論您使用任何器件,下列步驟都應適用。

先使用 Vivado 來創建了塊設計。建立了 Zynq UltraScale PS,并把 AXI GPIO 連接到 ZCU104 評估板上的 4 個 LED

地址映射如下所示:

首先 在創建 XSA 時使用了以下選項:

2

Linux 鏡像

如果您使用開發板,則建議使用 BSP(如果存在)。

但在本示例中,我們使用模板來創建鏡像。已經添加了 UIO 驅動程序,用于 AXI GPIO。

然后創建了 sysroot,在 Vitis 中需要使用它來進行交叉編譯。

petalinux-create -t project --template zynqMP -n zcu104_linux

cd zcu104_linux

petalinux-config --get-hw-description=

依次選擇“DTG Settings -> (zcu104-revc)MACHINE_NAME”

petalinux-config -c kernel
Select Device Drivers -> Userspace I/O drivers
<*> Userspace I/O platform driver with generic IRQ handing
<*> Userspace platform driver with generic irq and dynamic memory

將 system-user.dtsi 替換為:

/include/ "system-conf.dtsi"

/ {

chosen {

bootargs = "earlycon clk_ignore_unused uio_pdrv_genirq.of_id=generic-uio";

stdout-path = "serial0:115200n8";

};

};

&axi_gpio_0 {

compatible = "generic-uio";

};

然后,運行以下命令:

petalinux-build

cd images/linux
petalinux-build --sdk
petalinux-package --sysroot

3

創建平臺

這并非必要步驟,因為用戶只需在 Vitis 中使用 sysroot 即可。

但為了便于使用,我們可以創建一個平臺并在 Vitis 中使用此平臺來創建 Linux 應用。

首先,設置平臺文件。

把平臺文件組織為一種文件夾結構。這并非必要步驟,但用戶需要注意 BIF 中的文件路徑。

在 Bootgen 中使用 BIF 來創建可啟動的鏡像。此處我們僅使用占位符文件名。

mkdir -p sw_comp/src/a53/xrt/image
mkdir sw_comp/src/boot

將 image.ub、boot.scr 和 rootfs.cpio.gz 文件從 PetaLinux image/linux 文件夾復制到sw_comp/src/a53/image

將 system.bit、bl31.elf、uboot.elf、zynqmp_fsbl(已重命名為 fsbl.elf)和 pmufw.elf 文件從 PetaLinux image/linux 文件夾復制到sw_comp/src/boot

創建 BIF:

the_ROM_image:

{

[fsbl_config] a53_x64

[bootloader]

[pmufw_image]

[destination_device=pl]

[destination_cpu=a53-0, exception_level=el-3, trustzone]

[destination_cpu=a53-0, exception_level=el-2]

}

將 linux.bif 復制到sw_comp/src/boot。現在,在 Vitis 中創建一個新平臺工程,如下所示:

這樣就會在zcu104_base/export中創建平臺。

4

在 Vitis 中創建 Linux 鏡像

選擇“從存儲庫中選擇平臺 (Select a platform from therepository)”,單擊 + 圖標并瀏覽至您的平臺。

創建新應用:

此處可以看到,“應用設置 (Application settings)”默認使用的是平臺中的設置。

選擇“空白應用 (Empty Application)”模板,因為我們將創建自己的自定義應用。

右鍵單擊 led_test 應用下的 src 文件夾,然后選擇“新建 (New)”->“文件 (File)”

指定其文件名 (.c),然后單擊“完成 (Finish)”。

現在,即可將以下代碼復制到其中。這是一個簡單的 UIO 示例,可用于開關 LED。

#include

#include

#include

#include

#include

#define GPIO_MAP_SIZE 0x10000

#define GPIO_DATA 0x00

#define GPIO_TRI 0x04

#define LED_NUM 256

#define LED_DELAY 10000000

int main(int argc, char *argv[])

{

int fd;

char *uiod = "/dev/uio0";

void *gpio_ptr;

volatile int Delay;

printf("AXI GPIO UIO test. ");

// open the UIO device file to allow access to the device in user space

fd = open(uiod, O_RDWR);

if (fd < 1) {

printf("Invalid UIO device file:%s. ", uiod);

return -1;

}

// mmap the GPIO device into user space

gpio_ptr = mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0);

if (gpio_ptr == MAP_FAILED) {

printf("Mmap call failure. ");

return -1;

}

// set bit0 on the GPIO to be output

// see pg144 for ref

*((volatile unsigned *)(gpio_ptr + GPIO_TRI)) = 0x0;

// Toggle the LED

while (1) {

int i;

unsigned char led_pin = 0x0;

for (i = 0; i < LED_NUM; i++) {

*((volatile unsigned *)(gpio_ptr + GPIO_DATA)) = led_pin;

for (Delay = 0; Delay < LED_DELAY; Delay++);

*((volatile unsigned *)(gpio_ptr + GPIO_DATA)) = 0x0;

led_pin++;

}

}

// unmap the GPIO device from user space

munmap(gpio_ptr, 4096);

return 0;

}

選擇系統工程,然后單擊錘子圖標。這樣即可構建可執行文件,并創建啟動鏡像。

5

在硬件上執行測試

將所有鏡像從led_app_systemDebugsd_card復制到 SD 卡上。

啟動后,將自動裝載 SD 卡。

在此處更改目錄,并執行led_app.elf,如下所示:

同時,您在板上應該還可以看到 LED 閃爍。

使用 Ctrl + c 即可取消。

責任編輯:xj

原文標題:開發者分享 | 在 Zynq UltraScale 器件上通過 Vitis 創建 Linux 用戶應用

文章出處:【微信公眾號:XILINX技術社區】歡迎添加關注!文章轉載請注明出處。

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

    關注

    88

    文章

    11798

    瀏覽量

    219403
  • Zynq
    +關注

    關注

    10

    文章

    632

    瀏覽量

    49542
  • Vitis
    +關注

    關注

    0

    文章

    158

    瀏覽量

    8421

原文標題:開發者分享 | 在 Zynq UltraScale 器件上通過 Vitis 創建 Linux 用戶應用

文章出處:【微信號:gh_2d1c7e2d540e,微信公眾號:XILINX開發者社區】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    何在運行 Linux作系統的 i.MX 8M Plus EVK 板上創建用戶友好的 GUI?

    我正在嘗試創建一個用戶友好的GUI to display some data. i have flashed the imx-image-full (所有
    發表于 04-08 06:33

    uIO-Stick v2 用戶指南:設計、應用與安全要點

    uIO-Stick v2 用戶指南:設計、應用與安全要點 在電子工程領域,接口設備對于連接不同系統和實現功能交互起著至關重要的作用。uIO-Stick v2 作為一款用于 MOTIX? MCU 設備
    的頭像 發表于 12-20 11:10 ?805次閱讀

    Linux-RT特點及簡單應用

    工具。這些工具可以用來查看和修改任務的調度策略和優先級,以及監視系統中運行的實時任務。 下面一個示例,演示如何在Linux-RT上使用C語言和pthread_create()函數創建實時
    發表于 12-05 07:37

    Linux驅動開發的必備知識

    、內核模塊編程: 掌握內核模塊的編寫、編譯、加載和卸載方法。 了解內核模塊的初始化和清理函數的編寫。 5、設備驅動框架: 熟悉字符設備、塊設備、網絡設備等驅動框架。 能夠根據
    發表于 12-04 07:58

    何在AMD Vitis Unified IDE中使用系統設備樹

    您將在這篇博客中了解系統設備樹 (SDT) 以及如何在 AMD Vitis Unified IDE 中使用 SDT 維護來自 XSA 的硬件元數據。本文還講述了如何對 SDT 進行操作,以便在
    的頭像 發表于 11-18 11:13 ?3247次閱讀
    如<b class='flag-5'>何在</b>AMD <b class='flag-5'>Vitis</b> Unified IDE<b class='flag-5'>中使</b>用系統設備樹

    【書籍評測活動NO.67】成為硬核Linux開發者:《Linux 設備驅動開發(第 2 版)》

    Linux 設備驅動開發(第 2 版)》。第2版系統講解內存管理、IRO管理、加鎖機制等嵌入式系統關鍵內容,透徹分析時鐘源、DMA引擎等核心機制,引入Regmap API等現代驅動開發框架
    發表于 11-17 17:52

    何在VS code中配置Zephyr集成開發環境

    上一篇文章介紹了如何在VS code中使用瑞薩官方插件為RA芯片創建項目與項目調試,相信大家對RA在VS code中的開發有了基礎的了解。
    的頭像 發表于 11-05 14:46 ?1696次閱讀
    如<b class='flag-5'>何在</b>VS code中配置Zephyr集成開發環境

    PYQT 應用程序框架及開發工具

    大家好,本團隊此次分享的內容為開發過程中使用到的PYQT 應用程序框架及開發工具。 pYqt 是一個多平臺的 python 圖形用戶界面應用程序框架,由于其面向對象、 易擴展(可
    發表于 10-29 07:15

    何在應用程序調試期間分析棧和堆使用情況

    ,并在 Unified IDE 中仍可使用。本文涵蓋了如何在 Vitis 中使用分析工具在應用程序調試期間對棧和堆進行監控。
    的頭像 發表于 10-24 16:54 ?1005次閱讀
    如<b class='flag-5'>何在</b>應用程序調試期間分析棧和堆使用情況

    何在AMD Vitis Unified 2024.2中連接到QEMU

    在本篇文章我們將學習如何在 AMD Vitis Unified 2024.2 中連接到 QEMU。 這是本系列的第 2 篇博文。要了解如何設置和使用 QEMU + 協同仿真,請參閱開發者分享|在 AMD Versal 自適應 SoC 上使用
    的頭像 發表于 08-06 17:24 ?1962次閱讀
    如<b class='flag-5'>何在</b>AMD <b class='flag-5'>Vitis</b> Unified 2024.2中連接到QEMU

    何在Unified IDE中創建視覺庫HLS組件

    Vivado IP 流程(Vitis Unified),在這篇 AMD Vitis HLS 系列 3 中,我們將介紹如何使用 Unified IDE 創建 HLS 組件。這里采用“自下而上”的流程,從 HLS
    的頭像 發表于 07-02 10:55 ?1627次閱讀
    如<b class='flag-5'>何在</b>Unified IDE中<b class='flag-5'>創建</b>視覺庫HLS組件

    使用AMD Vitis Unified IDE創建HLS組件

    這篇文章在開發者分享|AMD Vitis HLS 系列 1 - AMD Vivado IP 流程(Vitis 傳統 IDE) 的基礎上撰寫,但使用的是 AMD Vitis Unified IDE,而不是之前傳統版本的
    的頭像 發表于 06-20 10:06 ?2492次閱讀
    使用AMD <b class='flag-5'>Vitis</b> Unified IDE<b class='flag-5'>創建</b>HLS組件

    如何使用AMD Vitis HLS創建HLS IP

    本文逐步演示了如何使用 AMD Vitis HLS 來創建一個 HLS IP,通過 AXI4 接口從存儲器讀取數據、執行簡單的數學運算,然后將數據寫回存儲器。接著會在 AMD Vivado Design Suite 設計
    的頭像 發表于 06-13 09:50 ?2171次閱讀
    如何使用AMD <b class='flag-5'>Vitis</b> HLS<b class='flag-5'>創建</b>HLS IP

    Linux環境再升級:PLIN驅動程序正式發布

    PLIN驅動程序現已正式發布,本文將展示如何安裝PLIN驅動程序,以及如何在Linux環境下進行基本的PLIN通信操作,確保您能夠快速掌握并應用這一新工具。
    的頭像 發表于 04-21 15:29 ?1164次閱讀
    <b class='flag-5'>Linux</b>環境再升級:PLIN<b class='flag-5'>驅動</b>程序正式發布

    何在VS Code中使用瑞薩RA系列MCU

    VS Code(Visual Studio Code)是微軟公司出品,它是一個免費且多功能的代碼編輯器,幾乎支持所有主要的編程語言和框架。特別是最近又新加了Github Copilot功能,讓用戶
    的頭像 發表于 04-16 14:02 ?3770次閱讀
    如<b class='flag-5'>何在</b>VS Code<b class='flag-5'>中使</b>用瑞薩RA系列MCU