Petalinux

Petalinux 命令

参考《UG 1157 PetaLinux Command Line Reference Guide》

c 复制代码
//创建petalinux工程
petalinux-create -t project --template zynq -n <name> 

//配置工程
cd 上一步的工程
petalinux-config --get-hw-description ../xsa_folder/

//配置Linux内核
petalinux-config -c kernel

//配置Linux根文件系统
petalinux-config -c rootfs

//编译
petalinux-build

//制作BOOT.Bin
petalinux-package --boot --fsbl --fpga --u-boot --force

//挂载NFS
mount -t nfs -o nolock 192.168.0.1:/home/moerjie/work /mnt

Petalinux 设置本地编译

Xilinx下载中心

首先在下载中心下载 petalinux 对应版本的"arm sstate-cache"和"download"包。

将下载好的文件解压到 /opt/pkg/tools/ 文件路径下,使用 petalinux-config 配置工程。配置过程可见《领航者 ZYNQ 之嵌入式 Linux 开发指南 V 3.2》6.4 节。

与正点原子教程不同的地方

正点原子的修改 project-spec/meta-user/conf/petalinuxbsp. Conf 的代码如下:

复制代码
PREMIRRORS_prepend = " \
git://.*/.* file:///mnt/hgfs/share18/downloads/downloads \n \
gitsm://.*/.* file:///mnt/hgfs/share18/downloads/downloads \n \
ftp://.*/.* file:///mnt/hgfs/share18/downloads/downloads \n \
http://.*/.* file:///mnt/hgfs/share18/downloads/downloads \n \
https://.*/.* file:///mnt/hgfs/share18/downloads/downloads \n"

但是 2023.2 版本的 petalinux 不支持这个语法,需改为:

复制代码
PERMIRRORS:prepend = "\
git://.*/.* file:///opt/downloads \n \
gitsm://.*/.* file:///opt/downloads \n \
ftp://.*/.* file:///opt/downloads \n \
http://.*/.* file:///opt/downloads \n \
https://.*/.* file:///opt/downloads \n"

pre-mirror: file:///opt/downloads
sstate: /opt/sstate/arm/

挂载 PL 端的 IP 到设备树

将创建好的 petalinux 工程编译一遍后,在 ./components/plnx_workspace/device-tree/device-tree 路径下会生成 pl.dtsi 文件,将内部的设备树相关的配置复制粘贴到 ./project-spec/meta-user/recipes-bsp/device-tree/files 中的 system-user.dtsi 中,编译后在系统中加入新的设备。

Petalinux 支持的 axisfifo 的驱动版本是 4.1,但是 vivado 2023.2 中的 axis fifo 的版本为 4.3,因此要将 compatible 中的 "xlnx,axi-fifo-mm-s-4.3" 改为 "xlnx,axi-fifo-mm-s-4.1"

Axis fifo 必须将中断信号连接到 zynq processing system 才能正确挂载到设备树。

使用 dtc -I dtb -O dts 反编译在 ./images/linux/ 路径下的 system.dtb 文件,即可看到挂载的新设备。

相关推荐
s09071363 天前
FPGA中同步与异步复位
fpga开发·verilog·xilinx·zynq
杨景辉5 天前
Zynq7020 petalinux 基础篇(1)- 工程搭建
zynq
s09071366 天前
ZYNQ 中 AXI BRAM 的使用详细的说明。
fpga开发·zynq
s09071367 天前
Xilinx FPGA 中ADC 数据下变频+ CIC 滤波
算法·fpga开发·fpga·zynq
s09071369 天前
使用xilinx的fir IP核实现LFM信号匹配滤波的详细过程及原理
fpga开发·xilinx·fir·zynq·脉冲压缩
s090713610 天前
ZYNQ7000关于JTAG电路设计注意事项
fpga开发·zynq·硬件设计设计
s090713610 天前
ZYNQ几种boot模式下sdk文件区别
fpga开发·sdk·zynq
s090713610 天前
Xilinx 7系列FPGA的FFT IP核简介
fpga开发·zynq·fft
brave and determined1 个月前
可编程逻辑器件学习(day22):“让ARM穿上FPGA的马甲“:赛灵思Zynq的命名哲学与技术革命
arm开发·嵌入式硬件·fpga开发·zynq·fpga设计·嵌入式设计·fpga开发流程
碰大点2 个月前
第8章 zynq uboot更新系统镜像并引导启动和个人心得
驱动开发·fpga开发·uboot·zynq