当前位置: 首页 > news >正文

PetaLinux 使用技巧与缓存配置

🚀 PetaLinux 使用技巧与缓存配置

适用场景:

  • Ubuntu 主机
  • Zynq 开发板
  • 可选 Windows 辅助(用 RDP、CLion Remote 插件协作)
    本指南主要聚焦于 Ubuntu 与开发板端的高效协作与缓存配置和启动。

🧠 开发建议

P1: 配置 PetaLinux 缓存,加速编译、防止因网络造成编译慢或失败

通过使用本地 downloadssstate 缓存,避免 Yocto 网络下载导致失败。

P2: 三机连同一网络(Ubuntu / Windows / 开发板)

三者连接到同一个路由器,别在网络上浪费时间。

P3: 使用 RDP + CLion 进行远程交叉编译

  • Windows 中使用 remote-file-systems 插件 访问 Ubuntu。
  • 可直接在 CLion 中浏览与编辑 PetaLinux 工程目录结构。

P4: 启动文件拆分管理

将启动文件拆开

BOOT.BIN, system.dtb, zImage, system.bit, rootfs

📦 PetaLinux 缓存目录结构

$ ls /opt/mycache
downloads  sstate_arm_2020.2

🛠️ 缓存配置脚本 fix_complie.sh

脚本位置示例, z7是petalinux工程目录

$ cd ~/petalinux
$ ls
fix_complie.sh  xsa_7010  xsa_7020  z7

使用方式:

$ ./fix_complie.sh z7
已成功注释掉 CONFIG_YOCTO_NETWORK_SSTATE_FEEDS 配置项。
配置文件已成功更新。
BSP 配置文件中已存在 PREMIRRORS_prepend 内容。
BSP 配置文件已成功更新。

脚本内容如下:

fix_complie.sh
#!/bin/bash# 配置文件路径
CONFIG_FILE="$1/project-spec/configs/config"
BSP_CONF_FILE="$1/project-spec/meta-user/conf/petalinuxbsp.conf"# 新的配置值
NEW_PRE_MIRROR_URL='CONFIG_PRE_MIRROR_URL="file:///opt/mycache/downloads/"'
NEW_SSTATE_FEEDS_URL='CONFIG_YOCTO_LOCAL_SSTATE_FEEDS_URL="/opt/mycache/sstate_arm_2020.2/arm/  "'# 新的 PREMIRRORS_prepend 内容
PREMIRRORS_CONTENT='PREMIRRORS_prepend = " \
git://.*/.* file:///opt/mycache/downloads/ \n\
gitsm://.*/.* file:///opt/mycache/downloads/ \n\
ftp://.*/.* file:///opt/mycache/downloads/ \n\
http://.*/.* file:///opt/mycache/downloads/ \n\
https://.*/.* file:///opt/mycache/downloads/ \n"
DL_DIR="/opt/mycache/downloads"
SSTATE_DIR="/opt/mycache/sstate_arm_2020.2/arm"'# 检查配置文件是否存在
if [ ! -f "$CONFIG_FILE" ]; thenecho "配置文件 $CONFIG_FILE 不存在。"exit 1
fi# 注释掉 CONFIG_YOCTO_NETWORK_SSTATE_FEEDS=y 这一行
if grep -q '^CONFIG_YOCTO_NETWORK_SSTATE_FEEDS=' "$CONFIG_FILE"; thensed -i '/^CONFIG_YOCTO_NETWORK_SSTATE_FEEDS=/ s/^/#/' "$CONFIG_FILE"echo "已成功注释掉 CONFIG_YOCTO_NETWORK_SSTATE_FEEDS 配置项。"
fi# 替换或添加 CONFIG_PRE_MIRROR_URL
if grep -q '^CONFIG_PRE_MIRROR_URL=' "$CONFIG_FILE"; then# 如果存在,使用 sed 替换配置值sed -i 's|^CONFIG_PRE_MIRROR_URL=.*|'"$NEW_PRE_MIRROR_URL"'|' "$CONFIG_FILE"
else# 如果不存在,添加新的配置项echo "$NEW_PRE_MIRROR_URL" >> "$CONFIG_FILE"
fi# 替换或添加 CONFIG_YOCTO_LOCAL_SSTATE_FEEDS_URL
if grep -q '^CONFIG_YOCTO_LOCAL_SSTATE_FEEDS_URL=' "$CONFIG_FILE"; then# 如果存在,使用 sed 替换配置值sed -i 's|^CONFIG_YOCTO_LOCAL_SSTATE_FEEDS_URL=.*|'"$NEW_SSTATE_FEEDS_URL"'|' "$CONFIG_FILE"
else# 如果不存在,添加新的配置项echo "$NEW_SSTATE_FEEDS_URL" >> "$CONFIG_FILE"
fi# 确认替换或添加是否成功
if grep -q "$NEW_PRE_MIRROR_URL" "$CONFIG_FILE" && grep -q "$NEW_SSTATE_FEEDS_URL" "$CONFIG_FILE"; thenecho "配置文件已成功更新。"
elseecho "配置文件更新失败。"exit 1
fi# 检查 BSP 配置文件是否存在
if [ ! -f "$BSP_CONF_FILE" ]; thenecho "BSP 配置文件 $BSP_CONF_FILE 不存在。"exit 1
fi# 添加 PREMIRRORS_prepend 内容到 BSP 配置文件
if ! grep -q '^PREMIRRORS_prepend' "$BSP_CONF_FILE"; thencat << EOF >> "$BSP_CONF_FILE"
$PREMIRRORS_CONTENT
EOFecho "已将 PREMIRRORS_prepend 内容添加到 BSP 配置文件。"
elseecho "BSP 配置文件中已存在 PREMIRRORS_prepend 内容。"
fi# 确认添加是否成功
if grep -q "^PREMIRRORS_prepend" "$BSP_CONF_FILE"; thenecho "BSP 配置文件已成功更新。"
elseecho "BSP 配置文件更新失败。"exit 1
fi

🔧 U-Boot 启动文件拆解技巧

通过编写 boot.cmd.default 来拆分启动项(使用 mkimage 工具生成 boot.scr):

mkimage -c none -A arm -T script -d boot.cmd.default boot.scr

📄 启动脚本 boot.cmd.default 如下

boot.cmd.default

# mkimage -c none -A arm -T script -d boot.cmd.default boot.scr
#
################
ming_mmc_devnum=1for boot_target in ${boot_targets};
doif test "${boot_target}" = "jtag" ; thenbootm 0x00200000 0x04000000 0x00100000exit;fiif test "${boot_target}" = "mmc0" || test "${boot_target}" = "mmc1" ; thenecho " AAAAAAAAAAAAAWPF  Booting from SD (zImage)...${boot_target}--${devtype} -${devnum}-${distro_bootpart} "if test -e ${devtype} ${devnum}:${distro_bootpart} /zImage; thenfatload ${devtype} ${devnum}:${distro_bootpart} 0x00200000 zImage;;fiif test -e ${devtype} ${devnum}:${distro_bootpart} /system.dtb; thenfatload ${devtype} ${devnum}:${distro_bootpart} 0x00100000 system.dtb;fiif test -e ${devtype} ${devnum}:${distro_bootpart} /rootfs.cpio.gz.u-boot; thenfatload ${devtype} ${devnum}:${distro_bootpart} 0x04000000 rootfs.cpio.gz.u-boot;bootm 0x00200000 0x04000000 0x00100000exit;fiif test -e ${devtype} ${devnum}:${distro_bootpart} /system.bit; thenfatload ${devtype} ${devnum}:${distro_bootpart} 0x00800000 system.bit;fpga loadb 0 ${fileaddr} ${filesize}fibootz  0x00200000 - 0x00100000exit;fiif test "${boot_target}" = "xspi0" || test "${boot_target}" = "qspi" || test "${boot_target}" = "qspi0"; thenecho "BBBBBBBBBBBBBBBBBKYLV1  Booting from QSPI (zImage)...${boot_target}--${devtype} -${ming_mmc_devnum}-${distro_bootpart} "if test -z "${bootargs}"; thensetenv bootargs 'console=ttyPS0,115200 root=/dev/mmcblk1p2 rw rootwait rootfstype=ext4 earlyprintk'fiif test -e ${devtype} ${ming_mmc_devnum}:${distro_bootpart} /zImage; thenfatload ${devtype} ${ming_mmc_devnum}:${distro_bootpart} 0x00200000 zImage;;fiif test -e ${devtype} ${ming_mmc_devnum}:${distro_bootpart} /system.dtb; thenfatload ${devtype} ${ming_mmc_devnum}:${distro_bootpart} 0x00100000 system.dtb;fiif test -e ${devtype} ${ming_mmc_devnum}:${distro_bootpart} /rootfs.cpio.gz.u-boot; thenfatload ${devtype} ${ming_mmc_devnum}:${distro_bootpart} 0x04000000 rootfs.cpio.gz.u-boot;bootm 0x00200000 0x04000000 0x00100000exit;fiif test -e ${devtype} ${ming_mmc_devnum}:${distro_bootpart} /system.bit; thenfatload ${devtype} ${ming_mmc_devnum}:${distro_bootpart} 0x00800000 system.bit;fpga loadb 0 ${fileaddr} ${filesize}fibootz  0x00200000 - 0x00100000exit;fiif test "${boot_target}" = "nand" || test "${boot_target}" = "nand0"; thennand infoif test "image.ub" = "image.ub"; thennand read 0x10000000 0x1000000 0x6400000;bootm 0x10000000;exit;fiif test "image.ub" = "uImage"; thennand read 0x00200000 0x1000000 0x3200000;nand read 0x04000000 0x4600000  0x3200000;bootm 0x00200000 0x04000000 0x00100000exit;fifi
done

拷贝sd卡的文件到qspi和emmc

如果不再用sd卡,则将sd卡里的文件拷贝到到qspi和emmc里

将 BOOT.BIN 拷贝到qspi

copy_boot_to_qspi.sh
#!/bin/sh
echo "##############################################"
echo "########## COPY BOOT TO Flash QSPI #########"
echo "##############################################"
echo ""
boot=/media/sd-mmcblk0p1/BOOT.BIN
if [ ! -f ${boot} ]; thenecho "ERROR: ${boot} file does not exist!"exit 1
fi
echo "Erase partition /dev/mtd0"
flash_erase /dev/mtd0 0 0
flashcp ${boot} /dev/mtd0
echo "##########         Complete         ##########"
echo "##############################################"

将emmc分区

emmc的分区和sd卡一样,一个fat一个ext4

emmc_partition.sh
#!/bin/sheMMC_DEVICE="/dev/mmcblk1"umount "${eMMC_DEVICE}p1" 2>/dev/null
umount "${eMMC_DEVICE}p2" 2>/dev/nullif [ ! -b "$eMMC_DEVICE" ]; thenecho "$eMMC_DEVICE not found!"exit 1
fifdisk "$eMMC_DEVICE" <<EOF
o
n
p
1+100M
n
p
2w
EOFblockdev --rereadpt "${eMMC_DEVICE}"mkfs.vfat -F 32 "${eMMC_DEVICE}p1"
mkfs.ext4 "${eMMC_DEVICE}p2"fdisk -l "$eMMC_DEVICE"

将sd卡所有文件拷贝到emmc

copy_sd_to_emmc.sh
#!/bin/sh
cp -a  /media/sd-mmcblk0p1/*   /media/sd-mmcblk1p1
cp -a  /media/sd-mmcblk0p2/*   /media/sd-mmcblk1p2
http://www.dtcms.com/a/293572.html

相关文章:

  • 从零搭建 OpenCV 项目(新手向)-- 第二天 OpenCV图像预处理(一)
  • 第四章 Freertos物联网实战DHT11温湿度模块
  • 嵌入式学习-(李宏毅)机器学习(1)-day28
  • 本地电脑映射端口到外网访问的开启方法和注意事项,内网服务提供跨网使用简单操作实现
  • 神经网络和机器学习的一些基本概念
  • 某种物联网SIM卡流量查询方法
  • BQ4050RSMR DIOTEC高精度锂电池保护与电量监测芯片 集成保护+计量+通信
  • 2025年Zigbee技术白皮书:全球物联网无线通信的关键创新
  • 【Linux | 网络】应用层(HTTPS)
  • 如何在 Ubuntu 20.04 Linux 上安装 TeamSpeak 客户端
  • SparkSQL 聚合函数 MAX 对 NULL 值的处理
  • AWS Lambda IoT数据处理异常深度分析:从告警到根因的完整排查之路
  • Notepad++工具操作技巧
  • BitDistiller:通过自蒸馏释放 Sub-4-Bit 大语言模型的潜力
  • React Native + Expo 入坑指南:从核心概念到实战演练
  • Android 测试全指南:单元测试与UI测试框架详解
  • 《使用Qt Quick从零构建AI螺丝瑕疵检测系统》——3. QML入门:像搭积木一样构建UI
  • 论文笔记:Tuning Language Models by Proxy
  • 图机器学习(16)——图数据与自然语言处理
  • qiankun 和 Element UI 影响 el-cascader 宽度问题
  • 计算机毕设分享-基于SpringBoot的房屋租赁系统(开题报告+源码+Lun文+开发文档+数据库设计文档)
  • win11安装erlang和rabbitmq
  • 基于 XGBoost 与 SHAP 的医疗自动化办公与可视化系统(上)
  • Kafka——Kafka中的位移提交
  • ITIL 4:云计算与微服务对组织架构的影响
  • Elasticsearch(ES)介绍和安装
  • 20250704-基于强化学习在云计算环境中的虚拟机资源调度研究
  • ElasticSearch基础数据管理详解
  • CSS3文本阴影特效全攻略
  • Paimon的部分更新以及DeleteVector实现