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工程

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/9041.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言洛谷题目分享(11)回文质数

目录 1.前言 2.题目:回文质数 1.题目描述 2.输入格式 3.输出格式 4.输入输出样例 5.题解 3.小结 1.前言 哈喽大家好,今儿继续为大家分享一道蛮有价值的一道题,希望大家多多支持喔~ 2.题目:回文质数 1.题目描述 因为 151 …

【用文本生成歌声】Learn2Sing 2.0——歌声转换算法即梅尔频谱详解

一. 频谱图与梅尔谱图的介绍 频谱图:频谱图可以理解为一堆垂直堆叠在一起的快速傅里叶变换结果。 1.1 信号 在进入频谱图模块之前,首先我们需要了解信号是什么。 信号就是某一特定量随时间变化,对于音频来说,这个特定的变化量就…

pytest教程-43-钩子函数-pytest_report_header

领取资料,咨询答疑,请➕wei: June__Go 上一小节我们学习了pytest_runtest_makereport钩子函数的使用方法,本小节我们讲解一下pytest_report_header钩子函数的使用方法。 pytest_report_header 钩子函数允许你在 pytest 的终端报告的头部添…

七、 数据出境安全评估申报需要多长时间?

《评估申报指南(第二版)》未区分数据处理者进行数据出境安全评估线上申报和线下申报整体所需时间。一般情况下,数据出境安全评估的申报时长周期如图所示: 根据《评估申报指南(第二版)》第二条的规定&#…

跨越智能建筑桥梁:西门子PLC无缝对接BACnet楼宇自动化系统化

智能楼宇每一个环节的互联互通都至关重要,而PLC(可编程逻辑控制器)作为自动化领域的基石,其与BACnet协议的融合无疑成为了构建智能楼宇神经系统的关键节点。今天,让我们深入探讨如何利用先进的PLC转BACnet协议网关&…

使用Python实现2048小游戏

使用Python实现2048小游戏源码分享。实现效果如下所示。 实现效果图 游戏开始效果图 游戏结束效果图 部分源码截图 下载链接 基于如下的运行环境。运行需要安装tkinter /Library/Frameworks/Python.framework/Versions/3.7/bin/python/bin/python /Users/nihui/Documents/P…

AI预测体彩排3第3套算法实战化赚米验证第1弹2024年5月5日第1次测试

从今天开始,准备启用第3套算法,来验证下本算法的可行性。因为本算法通过近三十期的内测(内测版没有公开预测结果),发现本算法的预测结果优于其他所有算法的效果。彩票预测只有实战才能检验是否有效,只有真正…

电脑中的两个固态硬盘比一个好,想知道为什么吗

你当前的电脑很有可能有一个NVME SSD作为主驱动器,但可能至少还有一个插槽可以放另一个SSD,而且这样做可能是个好主意。 两个SSD可以提高性能 如果你有两个固态硬盘,你可以从中获得比有一个更好的性能。一种方法是使用RAID 0将两个驱动器组…

使用 PXE+Kickstart 批量网络自动装机

前言: 正常安装系统的话使用u盘一个一个安装会非常慢,所以批量安装的技术就出来了。 一、 概念 PXE (Preboot eXecute Environment,预启动执行环境)是由 Intel 公司开发的技术,可以让计算机通过网络来启动…

Calendar 366 II for Mac v2.15.5激活版:智能日历管理软件

在繁忙的工作和生活中,如何高效管理日程成为了许多人的难题。Calendar 366 II for Mac,作为一款全方位的日历管理软件,以其独特的功能和优秀的用户体验,成为您的日程好帮手。 Calendar 366 II for Mac支持多种视图模式&#xff0c…

【Java基础】设计模式——单例设计模式

单例设计模式(Singleton Design Pattern)是一种创建型设计模式,它确保⼀个类有且只有⼀个实例,并提供一个全局访问点来访问这个唯一实例。 单例模式主要解决的是,⼀个全局使⽤的类频繁的创建和消费,从⽽提…

vivado 低级别 SVF JTAG 命令

低级别 SVF JTAG 命令 注释 : 在 Versal ™ 器件上不支持 SVF 。 低级别 JTAG 命令允许您扫描多个 FPGA JTAG 链。针对链操作所生成的 SVF 命令使用这些低级别命令来访问链中的 FPGA 。 报头数据寄存器 (HDR) 和报头指令寄存器 (HIR) 语法 HDR length […

功率半导体测试挑战及应对方案详解

功率半导体是电子产业链中最核心的一类器件, 能够实现电能转换和电路控制作用。功率半导体包括功率半导体分立器件(含模块)以及功率IC等。其中,功率半导体分立器件按照器件结构可分为二极管、晶闸管和晶体管等。 以MOSFET、IGBT以及SiC MOSFET为代表的功…

【教学类-53-01】20240509“去掉背景的png彩色图片”转“黑色影子图”

作品展示 背景需求: 刚写完蒙德里安涂色学具,准备开课,转眼班级就“百日咳“”隔离3周,o(╥﹏╥)o 我的AI对话大师只剩1个月的有效期,剩下9万6千次也马上就作废了。 最后一个月可以尽量多用掉一些,我从小…

SpringBoot 扩展篇:ConfigFileApplicationListener源码解析

SpringBoot 扩展篇:ConfigFileApplicationListener源码解析 1.概述2. ConfigFileApplicationListener定义3. ConfigFileApplicationListener回调链路3.1 SpringApplication#run3.2 SpringApplication#prepareEnvironment3.3 配置environment 4. 环境准备事件 Config…

第十篇:数字堡垒:操作系统安全深度解析与实战指南

数字堡垒:操作系统安全深度解析与实战指南 1 *引言 1.1 数字世界的守护者 在遥远的比特海中,有一座名为“操作系统”的数字堡垒,它守护着我们的数据宝藏,确保每一次计算的航行都能安全抵达彼岸。然而,这片海域并非风…

2024年最新【SpringBoot2】开发实用篇-测试_springboot2 test(1),2024年最新2024春招BAT面试真题详解

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化! 由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、…

YOLOv5,YOLOv7改进之结合​SOCA

1.SOCA moudle结构图 2,YOLOv5,YOLOv7改进之结合​SOCA 1.配置common.py文件 #SOCA moudle 单幅图像超分辨率 class Covpool(Function):@staticmethoddef forward(ctx, input):x = inputbatchSize = x.data.shape[0]dim = x.data.shape[1]h = x.data.shape[2]w = x.data.sha…

docker Harbor私有仓库部署管理

搭建本地私有仓库,但是本地私有仓库的管理和使用比较麻烦,这个原生的私有仓库并不好用,所以我们采用harbor私有仓库,也叫私服,更加人性化。 一、什么是Harbor Harbor是VWware 公司开源的企业级Docker Registry项…

安卓开发--按键跳转页面,按键按下变色

前面已经介绍了一个空白按键工程的建立以及响应方式,可以参考这里:安卓开发–新建工程,新建虚拟手机,按键事件响应。 安卓开发是页面跳转是基础!!!所以本篇博客介绍利用按键实现页面跳转&#…