说明

个人还是比较喜欢灵活去管理各个部分的源码。

有关文章:

ZYNQ:PetaLinux提取Linux和UBoot配置、源码

编译Linux

取得Linux源代码和配置后,可以在其中执行make,编译Linux。

注意,编译前请导入PetaLinux环境变量:

  • 设置和导出ARCH为arm或者arm64;
  • 设置和导出CROSS_COMPILE,比如aarch64-linux-gnu-。

编译(通过,但是diff 有差异):

make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- xilinx_peta_defconfig
# xilinx_peta_defconfig 是 我们前文拷贝 .config 得来的。
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- -j 2

编译后得到vmlinux

打包 image.ub

kerneldtbrootfs.img打包成image.ub

  • kernel:一般就是linux生成的elf文件。
  • dtb:设备树,与驱动有关。
  • rootfs.img:编译完成的文件系统。

所以,image.ub 没有那么神秘,就是一个包。

使用以下命令:

#!/bin/sh
CROSS_COMPILE=arm-linux-gnueabihf- ${CROSS_COMPILE}-objcopy -O binary -R .note -R .comment -S vmlinux linux.bin gzip -9 linux.bin mv -f linux.bin.gz linux.bin #需要修改 .its
mkimage -f fit-image-petalinux-user-image.its image.ub

编译 UBoot

取得UBoot源代码和配置后,需要有工具链的环境,编译:

make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- clean
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- xilinx_peta_defconfig
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- -j 2

得到u-boot(实际上就是u-boot.elf

打包 BOOT.BIN

1、需要4个文件:u-boot.elfzynq_fsbl.elfbootgen.bifsystem.bit

  • u-boot.elf :就是uboot编译生成的
  • bootgen.bif :可以自己手写。
  • zynq_fsbl.elf :Vivado创建PS以后,在SDK中创建File-New-Application Project-Zynq FSBL以后Build Project生成的。
  • system.bit :FPGA工程师生成的二进制流,用于PL端烧写的(可以没有)

2、修改bif文件,或者自己搞一个。

#cat build/bootgen.bif
//arch = zynq; split = false; format = BIN
the_ROM_image:
{
[bootloader] /tmp/tmp.SXFL3UZOJ7/zynq_fsbl.elf
/tmp/tmp.SXFL3UZOJ7/system.bit
/tmp/tmp.SXFL3UZOJ7/u-boot.elf
}

3、使用下列命令创建BOOT.BIN

bootgen -arch zynq -image bootgen.bif -o BOOT.BIN -w on

$ bootgen -help

****** Xilinx Bootgen v2018.3
**** Build date : Nov 15 2018-19:22:29
** Copyright 1986-2018 Xilinx, Inc. All Rights Reserved. ------------------------------------------------------------------------------+
COMMAND LINE OPTIONS |
-------------------------------+----------------------------------------------+
-arch [options] | Xilinx Architecture |
| options: [zynq, zynqmp, fpga] |
-------------------------------+----------------------------------------------+
-image <filename> | Input Boot Image File (.bif) |
-------------------------------+----------------------------------------------+
-o <filename> | Output filename in MCS/BIN format |
-------------------------------+----------------------------------------------+
-w [options] | Overwrite mode |
| options: [on, off] |
-------------------------------+----------------------------------------------+
-encrypt [options] | AES Key storage in chip (Zynq only) |
| options: [bbram, efuse] |
-------------------------------+----------------------------------------------+
-p <string> | Part name |
-------------------------------+----------------------------------------------+
-efuseppkbits <filename> | Generate PPK hash for e-fuse |
-------------------------------+----------------------------------------------+
-generate_hashes | Generate SHA hashes (PKCS#1v1.5) |
-------------------------------+----------------------------------------------+
-spksignature <filename> | Generate SPK signature file |
-------------------------------+----------------------------------------------+
-fill <hex-byte> | Fill byte for padding |
-------------------------------+----------------------------------------------+
-split [options] | Split partitions to diff files |
| options: [bin, mcs] |
-------------------------------+----------------------------------------------+
-padimageheader [options] | Pad header tables |
| options: [0, 1] |
-------------------------------+----------------------------------------------+
-process_bitstream [options] | Outputs bitstream in bin/mcs format |
| options: [bin, mcs] |
-------------------------------+----------------------------------------------+
-generate_keys [options] | Generate authentication keys |
| options: [pem, rsa, obfuscatedkey] |
-------------------------------+----------------------------------------------+
-dual_qspi_mode [options] | Generate 2 output files for Dual QSPI |
| options: [parallel, stacked <size>] |
-------------------------------+----------------------------------------------+
-log [options] | Generate log file |
| options: [error, warning, info, debug, trace]|
-------------------------------+----------------------------------------------+
-zynqmpes1 | Generate boot image for (1.0)ES1 |
-------------------------------+----------------------------------------------|
-nonbooting | Generate an intermediate boot image |
-------------------------------+----------------------------------------------|
-encryption_dump | Generate encryption log file |
-------------------------------+----------------------------------------------+
-h | -help | Print the help summary |
-------------------------------+----------------------------------------------+
-bif_help | Print the BIF help summary |
-------------------------------+----------------------------------------------+
Note : For more info on bootgen options, use the command |
bootgen -help <option> |
Example : bootgen -help efuseppkbits |
------------------------------------------------------------------------------+

bootgen 打包脚本

#/* @file         package_BOOT.BIN.sh
#* @brief 打包BOOT.BIN
#* @author Schips
#* @date 2020-10-31 09:04:43
#* @version v1.0
#* @copyright Copyright By Schips, All Rights Reserved
#*
#**********************************************************
#*
#* @par 修改日志:
#* <table>
#* <tr><th>Date <th>Version <th>Author <th>Description
#* <tr><td>2020-10-31 <td>1.0 <td>Schips <td>创建初始版本
#* </table>
#*
#**********************************************************
#*/ #!/bin/sh BIF=/tmp/.bif
help () {
echo "Error : need \$fsbl.elf \$system.bit \$u-boot.elf BOOT.BIN"
echo " eg :"
echo " $0 fsbl.elf system.bit u-boot.elf BOOT.BIN"
exit 1
} if [ -z "$1" ]; then
help
fi
if [ -z "$2" ]; then
help
fi
if [ -z "$3" ]; then
help
fi
if [ -z "$4" ]; then
help
fi FSBL=$1
PL_BIT=$2
UBOOT=$3
BOOT_BIN=$4 TMP_FSBL=/tmp/fsbl.elf
TMP_PL_BIT=/tmp/system.bit
TMP_UBOOT=/tmp/u-boot.elf cp -v $FSBL $TMP_FSBL
cp -v $PL_BIT $TMP_PL_BIT
cp -v $UBOOT $TMP_UBOOT require () {
command -v $1 >/dev/null 2>&1 || { echo >&2 "Aborted : Require \"$1\" but not found."; exit 1; }
} # 文件内容追加
append_line_into_file ()
{
if [[ $# -lt 2 ]]; then
return
fi
FILE=$1
LINE=$2
echo $LINE >> $FILE
} make_bif () {
rm ${BIF} -rf
echo "Making BIF for bootgen : \n\n"
append_line_into_file ${BIF} "//arch = zynq; split = false; format = BIN"
append_line_into_file ${BIF} "the_ROM_image:"
append_line_into_file ${BIF} "{"
append_line_into_file ${BIF} " [bootloader] $TMP_UBOOT"
append_line_into_file ${BIF} " $TMP_PL_BIT"
append_line_into_file ${BIF} " $TMP_UBOOT"
append_line_into_file ${BIF} "}"
echo "\n\n"
cat ${BIF}
} make_boot_bin () {
echo "Making BOOT.BIN: \n\n"
bootgen -arch zynq -image $BIF -o $BOOT_BIN -w on
ls $BOOT_BIN -l
} require bootgen
make_bif
make_boot_bin
exit $? https://xilinx-wiki.atlassian.net/wiki/spaces/A/pages/18842056/FPGA+Manager+ZCU102
http://www.uisrc.com/forum.php?mod=viewthread&tid=2334 #cat build/bootgen.bif the_ROM_image:
{
[bootloader] /tmp/tmp.SXFL3UZOJ7/zynq_fsbl.elf
/tmp/tmp.SXFL3UZOJ7/system.bit
/tmp/tmp.SXFL3UZOJ7/u-boot.elf
}

patelinux-package 打包 BOOT.BIN

使用bootgen好像有问题,总是提示u-boot文件出现问题:

[ERROR]  : Multiple executable program sections in /tmp/u-boot.elf

因此,还是推荐使用这个方法,但是这个方法需要在petalinux工程中进行。

petalinux-package --boot --fsbl ./images/linux/zynq_fsbl.elf --fpga ./images/linux/system.bit --u-boot --force && cp images/linux/BOOT.BIN /tftpboot/BOOT.BIN_for_emmc

编译uboot、Linux

编译uboot、kernel方法很常见,这里介绍我自己使用的方法。

思路:先把通用的配置保存起来,编译uboot、kernel的时候只需要读取配置就可以了

配置

##
# Copyright By Schips, All Rights Reserved
#
# File Name: init.sh
# Created : 2020-07-21 09:12:10
#
##
#!/bin/sh XLNX_SDK_CONFIG=~/.sdk_xlnx_config cd `dirname $0`
SDKTOP=`cd ../../ && pwd`
TC=${SDKTOP}/toolchain
if [ ! -d "$TC" ]; then
TC=`cd ${SDKTOP}/../toolchain&& pwd`
fi add_to_config () {
echo "$1" >> $XLNX_SDK_CONFIG
} echo "Initializing [$XLNX_SDK_CONFIG]" rm $XLNX_SDK_CONFIG 2>/dev/null
add_to_config "## For All"
add_to_config "export ARCH=arm"
add_to_config "export ARM_GCC_PATH=${TC}/petalinux_2018.3/gcc-arm-linux-gnueabi/bin"
add_to_config "export BUILD_CORE=4"
add_to_config ""
add_to_config "## app, kernel"
add_to_config "export APP_CROSS ?= arm-linux-gnueabihf-"
add_to_config "export KERNEL_CROSS ?= arm-linux-gnueabihf-"
add_to_config "export KERNEL_CFGDIR ?= arch/arm/configs"
add_to_config "export KERNEL_CONFIG ?= xilinx_zynq7000_peta_defconfig"
add_to_config ""
add_to_config "## Uboot"
add_to_config "export UBOOT_CROSS ?= arm-linux-gnueabihf-"
add_to_config "export UBOOT_CFGDIR ?= configs"
add_to_config "#export UBOOT_CROSS?= arm-none-eabi-"
add_to_config "export UBOOT_CONFIG ?= xilinx_zynq7000_peta_defconfig" echo "============================="
cat $XLNX_SDK_CONFIG
echo "============================="
echo "Initalized [$XLNX_SDK_CONFIG]"

uboot

#==============================================
##
# Copyright By Schips, All Rights Reserved
#
# File Name: build_uboot.sh
# Created : 2020-07-13 10:49:24
#
##
#!/bin/sh
BASE=`pwd`
XLNX_SDK_CONFIG=~/.sdk_xlnx_config get_config_from_sdk_config ()
{
ret=`cat $XLNX_SDK_CONFIG | grep -v "#" | grep -E '\=|\?\=' | grep "$1" | grep "export" | awk -F= '{print $2}'`
echo $ret
} ARM_GCC_PATH=`get_config_from_sdk_config ARM_GCC_PATH`
export PATH=$PATH:$ARM_GCC_PATH echo "Building [$BASE]" BUILD_ARCH=`get_config_from_sdk_config ARCH`
BUILD_CROSS=`get_config_from_sdk_config UBOOT_CROSS`
CONFIG=`get_config_from_sdk_config UBOOT_CONFIG`
CORE=`get_config_from_sdk_config BUILD_CORE` rebuild () {
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS clean
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS $CONFIG
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS -j $CORE
} rebuild
echo "Built [$BASE]"

kernel

与uboot类似,配置项有一些小差异而已。

##
# Copyright By Schips, All Rights Reserved
#
# File Name: build_kernel.sh
# Created : 2020-08-06 14:19:04
#
##
#!/bin/sh
BASE=`pwd`
XLNX_SDK_CONFIG=~/.sdk_xlnx_config
date_time=`date +%0m%0d-%0k:%0M` get_config_from_sdk_config ()
{
ret=`cat $XLNX_SDK_CONFIG | grep -v "#" | grep -E '\=|\?\=' | grep "$1" | grep "export" | awk -F= '{print $2}'`
echo $ret
} ARM_GCC_PATH=`get_config_from_sdk_config ARM_GCC_PATH`
export PATH=$PATH:$ARM_GCC_PATH BUILD_ARCH=`get_config_from_sdk_config ARCH`
BUILD_CROSS=`get_config_from_sdk_config KERNEL_CROSS`
CONFIG=`get_config_from_sdk_config KERNEL_CONFIG`
CORE=`get_config_from_sdk_config BUILD_CORE`
SRCCONFIGDIR=`get_config_from_sdk_config KERNEL_CFGDIR` help () {
echo "Use following cmd : "
echo " help : For help"
echo " config : Memuconfig based on present config"
echo " deconfig : Reset config as [$CONFIG]"
echo " build : Build based on present config"
echo " clean : Clean object built"
echo " rebuild : Reset config, clean and build"
echo " dtbs : Build dtbs"
} if [ -z "$1" ]; then
help
exit 1
fi config() {
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS menuconfig echo "Do you want to save this config as [${CONFIG}] ?"
echo " [yy/n], default [n] in 5 seconds."
read -t 5 answer if [ "$answer" == "yy" ]; then
echo "Saving .config as default"
cp -v ${SRCCONFIGDIR}/${CONFIG} .${CONFIG}_backup_${date_time}
cp -v .config ${SRCCONFIGDIR}/xilinx_zynq7000_peta_defconfig
echo "Saved .config as default"
fi
} deconfig () {
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS clean
cp .config .config_backup_${date_time} -v 2>/dev/null
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS $CONFIG
echo "Configed with [$CONFIG]"
} rebuild () {
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS clean
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS $CONFIG
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS -j $CORE
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS dtbs -j $CORE
} build () {
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS -j $CORE
} dtbs () {
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS -j $CORE dtbs
} clean () {
make ARCH=${BUILD_ARCH} CROSS_COMPILE=$BUILD_CROSS clean
} command -v $1 >/dev/null 2>&1 || { help && exit 1; }
echo "Doing [$1]"
$1
echo "Done with [$1]"

ZYNQ:使用PetaLinux打包 BOOT.BIN、image.ub的更多相关文章

  1. MPSOC之5——开发流程BOOT.BIN

    需要把若干文件打成大包,烧写到flash或者sd卡中,才能启动运行. 1.petalinux打包 petalinux-packet打包时,需要petalinux的工程,限制太死了,不用. 2 wind ...

  2. 如何解包,编辑,重新打包boot images

    HOWTO: Unpack, Edit, and Repack Boot Images http://forum.xda-developers.com/showthread.php?t=443994 ...

  3. 一键解包/打包boot.img/recovery.img工具(高通/MTK双版 支持android 5.1以上)

    下载地址: 链接: https://pan.baidu.com/s/1hsA2oWc 密码: skdx

  4. 嵌入式开发之zynqMp ---Zynq UltraScale+ MPSoC 图像编码板zcu102

    1.1 xilinx zynqMp 架构 1.1.1 16nm 级别工艺 Zynq UltraScale+  MPSoC架构 Xilinx新一代Zynq针对控制.图像和网络应用推出了差异化的产品系,这 ...

  5. zynq linux驱动之PL-PS中断【转】

    转自:https://blog.csdn.net/h244259402/article/details/83993524 PC:Windows 10 虚拟机:ubuntu 16.04 vivado:2 ...

  6. ZYNQ Linux 移植:包含petalinux移植和手动移植debian9

    参考: https://electronut.in/workflow-for-using-linux-on-xilinx-zynq/ https://blog.csdn.net/m0_37545528 ...

  7. Boot Petalinux Project Using a remote system

    通过jtag实现在远程服务器端下载petalinux image到连接在本地PC的开发板上的方法. 具体连接方式为 比如Host的系统为Windows,Remote system为运载在远程服务器上的 ...

  8. ZYNQ跑系统 系列(二) petalinux方式移植linux

    三.搭建petalinux工程 0.定位目录    先在shell中找一个准备存放工程的地方,(我的是home/hlf/PRO),命令行cd home/hlf/PRO 1.定位编译链    根据安装p ...

  9. Android : 修改内核源码 and 编译、打包成新的boot.img

    一.Android内核源码的下载: 1.Google GIT地址: $ git clone https://android.googlesource.com/kernel/common.git $ g ...

  10. zynq基础-->linux下软件应用

    操作系统:Ubuntu 16.04 LTS 应用软件:Vivado 2016.2  + petalinux 2016.2 参考官方应用手册:ug1144-petalinux-tools-referen ...

随机推荐

  1. Golang validate验证器

    目录 自定义验证规 单条验证 多条批量验证 其它验证包: gookit/validate 手册地址: https://godoc.org/gopkg.in/go-playground/validato ...

  2. P3193 [HNOI2008] GT考试 题解

    之前学矩阵乘的时候做的题,当时因为不会\(kmp\)搜索一稀里糊涂过去了,现在填个坑. 头图 是\(Logos\)! P3193 [HNOI2008] GT考试 题链:洛谷 题库 题目大意: 求有多少 ...

  3. URP(Universal Render Pipeline)渲染管线在使用中的一些分享

    本篇文章整理了URP管线使用中的一些简单的心得记述 1.使用ScriptableRendererFeature自定义渲染特性 在内建(Build-in)管线中可以使用CommandBuffer并添加到 ...

  4. 80x86汇编—指令系统

    文章目录 MOV 非法传送 XCHG XLAT 堆栈指令 push 和 pop 标志寄存器指令 重点理解CF与OF与SF实际应用中的关系 运算指令 控制转移类指令(重点) 条件转移指令 顺序是按照我们 ...

  5. C语言:将文件中所得到的单词表保存到一个顺序表中--使用动态分配数组。

    在很多时候我们想要在程序中存储想要的信息,但是又不知道该信息的大小或者说不知道需要多长的数组来存放.动态分配空间这个很好的解决了这个问题,动态分配不仅只可以用在链表中分配节点空间,其实更多时候用来分配 ...

  6. 【漏洞通报】WEB VIDEO PLATFORM疑似存在未授权访问漏洞

    漏洞描述 WEB VIDEO PLATFORM是一个基于GB28181-2016标准实现的开箱即用的网络视频平台,负责实现核心信令与设备管理后台部分,支持NAT穿透,支持海康.大华.宇视等品牌的IPC ...

  7. JVM Sandbox入门详解

    一. 概述 在日常开发中,经常会接触到面向AOP编程的思想,我们通常会使用Spring AOP来做统一的权限认证.异常捕获返回.日志记录等工作.之所以使用Spring AOP来实现上述功能,是因为这些 ...

  8. 安利一个好用的IDEA插件 object-helper-plugin

    更多精彩博文请关注:听到微笑的博客 一. 插件背景 object-helper 插件是一个日常开发工具集插件,提供丰富的功能,最开始是基于 GenerateO2O 插件开发而来,它提供了对象之间值拷贝 ...

  9. 最好的在线PDF转换工具服务

    工作中有时候会碰到需要转换PDF文件的情况,现在网上就要很多免费的在线工具,可以进行PDF文件的转换,下面就来介绍一些可以直接在浏览器中将文档.电子表格.和图片转换为PDF或者互相转换的服务工具. ​ ...

  10. nginx获取后端真实IP,添加后端服务器响应时间并记录日志

    nginx获取后端真实IP,添加后端服务器响应时间并记录日志 1.日志定义 log_format nginx '$remote_addr - $remote_user [$time_local] &q ...