Petalinux的使用——定制Linux系统

2024-05-07 02:36

本文主要是介绍Petalinux的使用——定制Linux系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 配置petalinux运行环境
  • petalinux设计流程

配置petalinux运行环境

Petalinux的安装在文章Ubuntu镜像源的更改及其Petalinux的安装中已经介绍,下面介绍petalinux运行环境的配置过程。
进入到petalinux的安装路径下,使用下面的命令对petalinux的运行环境进行配置。

source settings.sh

需要注意的是,这条命令只对当前终端有效,重新开一个终端后需要再执行该命令才可以,执行结果如下图所示。
在这里插入图片描述
如果每次打开终端都要使用petalinux,可以把source petalinux的绝对路径添加到家目录下的.bashrc脚本文件中,.bashrc脚本文件是每次打开终端自动执行的。比如,按照我的安装路径在.bashrc文件中添加下面的代码。

source /opt/pkg/petalinux/settings.sh

添加成功以后保存退出。
在这里插入图片描述
重新打开一个终端窗口,对petalinux的运行环境进行配置的语句一开始就执行了,不过每次启动终端都会花时间执行。
在这里插入图片描述


petalinux设计流程

petalinux设计流程大致为:搭建Vivado工程,导出硬件描述文件(.hdf文件);创建petalinux工程;将.hdf文件导入到petalinux工程;配置petalinux工程(包括内核、u-boot和根文件系统的配置);编译petalinux工程(得到u-boot镜像、内核镜像、rootfs、bitstream、fsbl镜像文件);启动开发板进行验证。
进入到petalinux的安装路径下,在命令行输入petalinux-,按下两次Tab键,就显示了下面6个petalinux命令。
在这里插入图片描述
可以通过–help的命令查看该命令的帮助信息,如下图所示。
在这里插入图片描述
下面提供了创建zynq工程的命令样例。
在这里插入图片描述

petalinux-create -t project -n project_name --template zynq

根据样例输入命令创建工程,如果不使用-p指定工程路径,工程默认创建在当前路径下,如下如所示。
在这里插入图片描述
准备好.hdf文件,该文件需要在Vivado软件中先生成比特流文件,然后导出到硬件,导出的时候需要勾选包括比特流选项。在这里插入图片描述
先进入到刚创建的工程文件夹下,然后使用下面的命令将.hdf文件导入到petalinux工程中。

petalinux-config --get-hw-description .hdf文件所在文件夹的绝对路径
petalinux-config --get-hw-description /home/ubuntu16/zynq/hdf #例子

其运行一会之后就打开了下面配置的图形化界面。
在这里插入图片描述
这里暂时使用默认配置,退出当前窗口,等待其配置完成,完成后打印的信息如下图所示。
在这里插入图片描述
如果关闭该窗口后还想打开该窗口进行补充设置,使用petalinux-config命令即可。
使用下面的命令就可以依次配置u-boot、kernel和rootfs,这里都暂时保持默认设置,不进行配置。

petalinux-config -c u-boot
petalinux-config -c kernel
petalinux-config -c rootfs

u-boot配置成功如下图所示。
在这里插入图片描述
内核配置成功如下图所示。
在这里插入图片描述
根文件系统配置成功。
在这里插入图片描述
以上配置完成后就可以进行编译了,编译的时候可以选择编译整个petalinux工程,也可以单独编译u-boot、kernel、rootfs。编译整个petalinux工程包括u-boot、kernel、rootfs、fsbl、bitstream、设备树等,编译使用的命令如下。

petalinux-build #编译整个petalinux工程
petalinux-build -c u-boot
petalinux-build -c kernel
petalinux-build -c rootfs

可以在虚拟机设置这里根据自己电脑的配置将处理器的数量调大,这样在编译的时候速度会快一些。
在这里插入图片描述
编译成功后打印的信息如下。
在这里插入图片描述
依次打开该工程下的/images/linux文件夹,里面就存放了刚才编译工程所生成的镜像文件,如下图所示。
在这里插入图片描述
在启动开发板之前要制作一个启动镜像文件BOOT.BIN,该文件是fsbl镜像文件、FPGA镜像文件和用户程序镜像文件整合而成的,其使用的命令如下。

petalinux-package --boot --fsbl fsbl_path --fpga fpga_path --u-boot uboot_path --force

其中,–boot表示要生成BOOT.BIN文件,–fsbl用于指定fsbl文件(上图中的zynq_fsbl.elf文件)的路径,–fpga用于指定fpga文件(上图中的system.bit文件)的路径,–u-boot用于指定u-boot文件(上图中的u-boot.elf文件)的路径。
如果进到上面所在的文件夹/images/linux下,使用下面的程序就可以打包。

petalinux-package --boot --fsbl ./zynq_fsbl.elf --fpga ./system.bit --u-boot ./u-boot.elf --force

命令执行成功后就在当前目录下生成了BOOT.BIN镜像文件。
在这里插入图片描述
不同于SDK实验中只拷贝BOOT.BIN文件就可以启动开发板,如下图所示,终端打印信息提示无法读取image.ub文件。
在这里插入图片描述
image.ub文件是kernel、设备树和rootfs整合而成的文件,该文件在编译之后也生成了,开发板启动也需要image.ub文件,将两个文件拷贝到SD卡,然后再启动开发板。
在这里插入图片描述
有了这两个文件,开发板就成功启动了,启动成功后的用户名和密码都是root。
在这里插入图片描述
需要说明的是,有些Vivado工程定制的镜像文件无法启动开发板,我使用helloworld的SDK工程创建的就无法启动,后面改用呼吸灯breath_led的工程定制的就可以启动,但是自己定制的这个Linux系统网络接口有点问题,和Ubuntu互相ping不通,所以直接使用了厂家提供的镜像文件。
在这里插入图片描述


下面是使用厂家提供的Vivado工程定制Linux系统的过程,该工程中的框图如下。
在这里插入图片描述
使用该工程SDK文件夹下的.hdf文件,将其先拷贝到Ubuntu中。
在这里插入图片描述
先设置petalinux环境变量,在该目录下创建工程。

source settings.sh
petalinux-create -t project -n zynq7020 --template zynq

创建成功后进到创建的工程目录下。
在这里插入图片描述
执行下面的命令从存放hdf的文件夹中获取文件进行相关配置。

petalinux-config --get-hw-description /home/ubuntu16/zynq/hdf

执行过程中弹出的图形配置窗口保持默认设置即可,执行过程如下图所示。
在这里插入图片描述
依次执行下面三条命令分别对u-boot、kernel和rootfs进行配置,配置过程中弹出的图形窗口仍然使用默认配置。

petalinux-config -c u-boot
petalinux-config -c kernel
petalinux-config -c rootfs

u-boot配置成功后接着配置kernel。
在这里插入图片描述
kernel配置成功之后再配置rootfs。
在这里插入图片描述rootfs配置成功后的结果如下图所示。
在这里插入图片描述
以上配置完成后执行下面的命令进行编译。

petalinux-build

编译成功之后打印的信息如下。
在这里插入图片描述
然后进到/images/linux目录下,执行下面的命令将三个文件合成一个BOOT.BIN文件。

petalinux-package --boot --fsbl ./zynq_fsbl.elf --fpga ./system.bit --u-boot ./u-boot.elf --force

然后就在该目录下生成了BOOT.BIN文件,如下图所示。
在这里插入图片描述
将BOOT.BIN文件和image.ub文件拷贝到SD卡中,成功启动了开发板,如下图所示。
在这里插入图片描述
开发板中的网口直接连接路由器,启动会快一些,但是如果和电脑相连,也能够启动成功,这样启动后也方便我们自己设置IP地址。
在这里插入图片描述
设置eth0的IP,使其和Ubuntu中的IP在同一网段内,这样就能够互相ping通了。
在这里插入图片描述
网络通了之后就可以通过nfs挂载或者使用网络传输文件到开发板进行测试了。
在这里插入图片描述
这里的elf文件在SDK中新建工程的时候,需要将操作系统的平台选择为linux,如下图所示。
在这里插入图片描述
否则在执行文件的时候会显示这是非法指令。
在这里插入图片描述


参考文章:
ZYNQ学习之路13.创建PetaLinux工程

这篇关于Petalinux的使用——定制Linux系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/966089

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三