petalinux设计——使用petalinux定制linux系统

2023-10-21 23:48

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

设计流程

在这里插入图片描述

以上设计流程不是按部就班的每一步都执行一遍,可以根据使用场景有选择的执行。
一般设计流程

  1. 通过 Vivado 创建硬件平台,得到 hdf 硬件描述文件;
  2. 运行 source <petalinux 安装路径>/settings.sh,设置 Petalinux 运行环境
  3. 通过 petalinux-create -t project 创建 petalinux 工程;
  4. 使用 petalinux-config --get-hw-description, 将 hdf 文件导入到 petalinux 工程当中并配置 petalinux 工程;
  5. 使用 petalinux-config -c kernel 配置 Linux 内核;
  6. 使用 petalinux-config -c rootfs 配置 Linux 根文件系统;
  7. 配置设备树文件;
  8. 使用 petalinux-build 编译整个工程;
  9. 使用 petalinux-package --boot 制作 BOOT.BIN 启动文件;
  10. 制作 SD 启动卡,将 BOOT.BIN 和 image.ub 以及根文件系统部署到 SD 卡中;
  11. 将 SD 卡插入开发板,并将开发板启动模式设置为从 SD 卡启动;
  12. 开发板连接串口线并上电启动,串口上位机打印启动信息, 登录进入 Linux 系统。

使用 Petalinux 定制 Linux 系统

创建 Vivado 硬件平台

在vivado平台搭建好vivado工程,勾选好必要的IP核,QSPI、ENET0、USB0、SD0、SD1、UART0……

最后得到 .hdf 文件

设置 Petalinux 环境变量

终端进入petalinux安装目录,运行目录下的 settings.sh 脚本文件

source settings.sh

需要注意的是该命令只对当前终端有效,重新打开终端后需要重新执行这一步,如下图
在这里插入图片描述

创建 petalinux 工程

用户的home目录下新建一个 work/petalinux 目录,作为 petalinux 的工程目录。在终端中输入如下命令新建 work/petalinux 目录:

cd
mkdir -p work/petalinux/

现在我们创建一个名为“zynq_linux”的 Petalinux 工程,在终端中输入如下命令:

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

template 参数表明创建的 petalinux 工程使用的平台模板,此处的 zynq 表明使用的是 zynq 平台模板的
petalinux 工程,用于 zynq-7000 系列的芯片。 name 参数(此处简写为“-n”)后接的是 petalinux 工程名,
如此处的“zynq_linux”。

配置petalinux工程

cd zynq_linux
petalinux-config --get-hw-description /mnt/hgfs/share/zynq_petalinux.sdk/

即进入到 zynq_linux 文件夹,并配置 petalinux 工程。“petalinux-config --get-hw-description”命令后面的文件夹就是我们复制到 Windosw 系统的 share 共享目录的 zynq_petalinux.sdk 文件夹,如果是通过其他方式如 FTP 传到 Ubuntu 系统中的,只要执行“petalinux-config --get-hw-description zynq_petalinux.sdk 文件夹所在位置”即可。 如果后面修改了 Vivado 工程,重新生成 hdf 文件后,可以重新执行“petalinux-config --get-hw-description zynq_petalinux.sdk 文件夹所在位置”以重新配置 Petalinux 工程。
配置界面如下
在这里插入图片描述
通过键盘上的“↑”和“↓”键来选择要配置的菜单,按下“Enter”键进入子菜单。菜单中高亮的字母就是此菜单的热键,在键盘上按下此高亮字母对应的键可以快速选中对应的菜单。选中子菜单以后按下“Y”键就会将相应的配置选项写入配置文件中,菜单前面变为“< * >”。按下“N”键不编译相应的代码,按下“M”键就会将相应的代码编译为模块,菜单前面变为“< M >”。按两下“Esc”键退出,也就是返回到上一级,按下“?”键查看此菜单的帮助信息,按下“/”键打开搜索框,可以在搜索框输入要搜索的内容。
可配置:fsbl自动生成与否,文件系统类型,系统启动方式,flash内存各模块大小、地址分配等等等等……

配置linux内核

petalinux-config -c kernel

配置linux根文件系统

petalinux-config -c rootfs

配置设备树文件

如 果 需 要 配 置 设 备 树 , 可 以 编 辑 当 前 工 程 目 录 下 的 project-spec/meta-user/recipes-bsp/devicetree/files/system-user.dtsi 文件。
使用 vi 命令打开 system-user.dtsi 文件,如下所示:

vi project-spec/meta-user/recipes-bsp/device-tree/files/system-user.dtsi

编译petalinux工程

petalinux-build

需要等一段时间
该命令将生成设备树 DTB 文件、 fsbl 文件、 U-Boot 文件, Linux 内核和根文件系统映像。 编译完成后,生成的映像将位于工程的 images 目录下。
在这里插入图片描述
其中有一个 WARNING 警告,这是 Petalinux 版本的问题,不影响实际使用,也不会对结果产生影响。

制作 BOOT.BIN 启动文件

petalinux-package --boot --fsbl <fsbl.elf文件路径> --fpga<bit文件路径> --u-boot --force

可以在工程目录的 /images/linux路径下找到BOOT.BIN、image.ub文件
在这里插入图片描述

烧写flash

板卡设为jtag模式
使用sdk软件菜单栏——>Xilinx——>program flash分写烧写BOOT.BIN 和image.ub.bin(把image.ub文件的后缀改为**.bin**)

启动系统

板卡设为qspi启动
pc和板卡连上串口,打开secureCRT(或putty等)串口工具,配置如图,断电重启,系统登录名和密码都默认为:root
在这里插入图片描述

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



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

相关文章

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令