41-uboot.sh
105 lines
| 4.0 KiB
| application/x-sh
|
BashLexer
/ bootstrap.d / 41-uboot.sh
Filip Pytloun
|
r56 | # | ||
Jan Wagner
|
r71 | # Build and Setup U-Boot | ||
Filip Pytloun
|
r56 | # | ||
Jan Wagner
|
r67 | # Load utility functions | ||
Filip Pytloun
|
r56 | . ./functions.sh | ||
# Fetch and build U-Boot bootloader | ||||
if [ "$ENABLE_UBOOT" = true ] ; then | ||||
drtyhlpr
|
r142 | # Install c/c++ build environment inside the chroot | ||
chroot_install_cc | ||||
drtyhlpr
|
r139 | # Copy existing U-Boot sources into chroot directory | ||
if [ -n "$UBOOTSRC_DIR" ] && [ -d "$UBOOTSRC_DIR" ] ; then | ||||
# Copy local U-Boot sources | ||||
cp -r "${UBOOTSRC_DIR}" "${R}/tmp" | ||||
else | ||||
drtyhlpr
|
r142 | # Create temporary directory for U-Boot sources | ||
Petter Reinholdtsen
|
r174 | temp_dir=$(as_nobody mktemp -d) | ||
drtyhlpr
|
r142 | |||
drtyhlpr
|
r139 | # Fetch U-Boot sources | ||
Petter Reinholdtsen
|
r174 | as_nobody git -C "${temp_dir}" clone "${UBOOT_URL}" | ||
drtyhlpr
|
r142 | |||
# Copy downloaded U-Boot sources | ||||
mv "${temp_dir}/u-boot" "${R}/tmp/" | ||||
# Set permissions of the U-Boot sources | ||||
chown -R root:root "${R}/tmp/u-boot" | ||||
# Remove temporary directory for U-Boot sources | ||||
rm -fr "${temp_dir}" | ||||
drtyhlpr
|
r139 | fi | ||
Filip Pytloun
|
r56 | |||
# Build and install U-Boot inside chroot | ||||
Unknown
|
r338 | chroot_exec make -j"${KERNEL_THREADS}" -C /tmp/u-boot/ "${UBOOT_CONFIG}" all | ||
Filip Pytloun
|
r56 | |||
# Copy compiled bootloader binary and set config.txt to load it | ||||
Jan Wagner
|
r82 | install_exec "${R}/tmp/u-boot/tools/mkimage" "${R}/usr/sbin/mkimage" | ||
drtyhlpr
|
r94 | install_readonly "${R}/tmp/u-boot/u-boot.bin" "${BOOT_DIR}/u-boot.bin" | ||
printf "\n# boot u-boot kernel\nkernel=u-boot.bin\n" >> "${BOOT_DIR}/config.txt" | ||||
Filip Pytloun
|
r56 | |||
Jan Wagner
|
r71 | # Install and setup U-Boot command file | ||
drtyhlpr
|
r94 | install_readonly files/boot/uboot.mkimage "${BOOT_DIR}/uboot.mkimage" | ||
Unknown
|
r420 | printf "# Set the kernel boot command line\nsetenv bootargs \"earlyprintk ${CMDLINE}\"\n\n$(cat "${BOOT_DIR}"/uboot.mkimage)" > "${BOOT_DIR}/uboot.mkimage" | ||
Jan Wagner
|
r82 | |||
if [ "$ENABLE_INITRAMFS" = true ] ; then | ||||
# Convert generated initramfs for U-Boot using mkimage | ||||
chroot_exec /usr/sbin/mkimage -A "${KERNEL_ARCH}" -T ramdisk -C none -n "initramfs-${KERNEL_VERSION}" -d "/boot/firmware/initramfs-${KERNEL_VERSION}" "/boot/firmware/initramfs-${KERNEL_VERSION}.uboot" | ||||
# Remove original initramfs file | ||||
drtyhlpr
|
r94 | rm -f "${BOOT_DIR}/initramfs-${KERNEL_VERSION}" | ||
Jan Wagner
|
r82 | |||
# Configure U-Boot to load generated initramfs | ||||
Unknown
|
r420 | printf "# Set initramfs file\nsetenv initramfs initramfs-${KERNEL_VERSION}.uboot\n\n$(cat "${BOOT_DIR}"/uboot.mkimage)" > "${BOOT_DIR}/uboot.mkimage" | ||
drtyhlpr
|
r94 | printf "\nbootz \${kernel_addr_r} \${ramdisk_addr_r} \${fdt_addr_r}" >> "${BOOT_DIR}/uboot.mkimage" | ||
Jan Wagner
|
r82 | else # ENABLE_INITRAMFS=false | ||
# Remove initramfs from U-Boot mkfile | ||||
drtyhlpr
|
r94 | sed -i '/.*initramfs.*/d' "${BOOT_DIR}/uboot.mkimage" | ||
Jan Wagner
|
r82 | |||
if [ "$BUILD_KERNEL" = false ] ; then | ||||
# Remove dtbfile from U-Boot mkfile | ||||
drtyhlpr
|
r94 | sed -i '/.*dtbfile.*/d' "${BOOT_DIR}/uboot.mkimage" | ||
printf "\nbootz \${kernel_addr_r}" >> "${BOOT_DIR}/uboot.mkimage" | ||||
Jan Wagner
|
r82 | else | ||
drtyhlpr
|
r94 | printf "\nbootz \${kernel_addr_r} - \${fdt_addr_r}" >> "${BOOT_DIR}/uboot.mkimage" | ||
Jan Wagner
|
r82 | fi | ||
fi | ||||
drtyhlpr
|
r398 | |||
Unknown
|
r420 | if [ "$SET_ARCH" = 64 ] ; then | ||
echo "Setting up config.txt to boot 64bit uboot" | ||||
{ | ||||
printf "\n# 64bit-mode" | ||||
printf "\n# arm_control=0x200 is deprecated https://www.raspberrypi.org/documentation/configuration/config-txt/misc.md" | ||||
printf "\narm_64bit=1" | ||||
} >> "${BOOT_DIR}/config.txt" | ||||
#in 64bit uboot booti is used instead of bootz [like in KERNEL_BIN_IMAGE=zImage (armv7)|| Image(armv8)] | ||||
Unknown
|
r344 | sed -i "s|bootz|booti|g" "${BOOT_DIR}/uboot.mkimage" | ||
fi | ||||
Unknown
|
r522 | |||
# instead of sd, boot from usb device | ||||
Unknown
|
r568 | if [ "$ENABLE_USBBOOT" = true ] ; then | ||
Unknown
|
r522 | sed -i "s|mmc|usb|g" "${BOOT_DIR}/uboot.mkimage" | ||
fi | ||||
Jan Wagner
|
r82 | |||
drtyhlpr
|
r94 | # Set mkfile to use the correct dtb file | ||
Unknown
|
r431 | sed -i "s|bcm2709-rpi-2-b.dtb|${DTB_FILE}|" "${BOOT_DIR}/uboot.mkimage" | ||
Jan Wagner
|
r82 | |||
drtyhlpr
|
r267 | # Set mkfile to use the correct mach id | ||
if [ "$ENABLE_QEMU" = true ] ; then | ||||
sed -i "s/^\(setenv machid \).*/\10x000008e0/" "${BOOT_DIR}/uboot.mkimage" | ||||
fi | ||||
Jan Wagner
|
r82 | # Set mkfile to use kernel image | ||
Unknown
|
r431 | sed -i "s|kernel7.img|${KERNEL_IMAGE}|" "${BOOT_DIR}/uboot.mkimage" | ||
Jan Wagner
|
r82 | |||
# Remove all leading blank lines | ||||
drtyhlpr
|
r94 | sed -i "/./,\$!d" "${BOOT_DIR}/uboot.mkimage" | ||
Filip Pytloun
|
r56 | |||
Jan Wagner
|
r71 | # Generate U-Boot bootloader image | ||
drtyhlpr
|
r94 | chroot_exec /usr/sbin/mkimage -A "${KERNEL_ARCH}" -O linux -T script -C none -a 0x00000000 -e 0x00000000 -n "RPi${RPI_MODEL}" -d /boot/firmware/uboot.mkimage /boot/firmware/boot.scr | ||
Jan Wagner
|
r82 | |||
# Remove U-Boot sources | ||||
rm -fr "${R}/tmp/u-boot" | ||||
Filip Pytloun
|
r56 | fi | ||