From a885dafe4e4d2fae9d05c123ac845a2f8e486316 Mon Sep 17 00:00:00 2001 From: orangepi-xunlong <258384131@qq.com> Date: Tue, 12 Jul 2022 14:29:22 +0800 Subject: [PATCH] Add boot-sun50iw9-current.cmd --- .../bootscripts/boot-sun50iw9-current.cmd | 86 +++++++++++++++++++ .../config/sources/families/sun50iw9.conf | 5 +- 2 files changed, 87 insertions(+), 4 deletions(-) create mode 100644 external/config/bootscripts/boot-sun50iw9-current.cmd diff --git a/external/config/bootscripts/boot-sun50iw9-current.cmd b/external/config/bootscripts/boot-sun50iw9-current.cmd new file mode 100644 index 0000000..d6e7d41 --- /dev/null +++ b/external/config/bootscripts/boot-sun50iw9-current.cmd @@ -0,0 +1,86 @@ +# DO NOT EDIT THIS FILE +# +# Please edit /boot/orangepiEnv.txt to set supported parameters +# + +# default values +setenv load_addr "0x45000000" +setenv overlay_error "false" +setenv rootdev "/dev/mmcblk0p1" +setenv verbosity "1" +setenv rootfstype "ext4" +setenv console "both" +setenv docker_optimizations "on" +setenv bootlogo "false" + +# Print boot source +itest.b *0x10028 == 0x00 && echo "U-boot loaded from SD" +itest.b *0x10028 == 0x02 && echo "U-boot loaded from eMMC or secondary SD" +itest.b *0x10028 == 0x03 && echo "U-boot loaded from SPI" + +echo "Boot script loaded from ${devtype}" + +if test -e ${devtype} ${devnum} ${prefix}orangepiEnv.txt; then + load ${devtype} ${devnum} ${load_addr} ${prefix}orangepiEnv.txt + env import -t ${load_addr} ${filesize} +fi + +if test "${console}" = "display" || test "${console}" = "both"; then setenv consoleargs "console=ttyS0,115200 console=tty1"; fi +if test "${console}" = "serial"; then setenv consoleargs "console=ttyS0,115200"; fi +if test "${bootlogo}" = "true"; then setenv consoleargs "bootsplash.bootfile=bootsplash.orangepi ${consoleargs}"; fi + +# get PARTUUID of first partition on SD/eMMC it was loaded from +# mmc 0 is always mapped to device u-boot (2016.09+) was loaded from +if test "${devtype}" = "mmc"; then part uuid mmc 0:1 partuuid; fi + +setenv bootargs "root=${rootdev} rootwait rootfstype=${rootfstype} ${consoleargs} consoleblank=0 loglevel=${verbosity} ubootpart=${partuuid} usb-storage.quirks=${usbstoragequirks} ${extraargs} ${extraboardargs}" + +if test "${docker_optimizations}" = "on"; then setenv bootargs "${bootargs} cgroup_enable=memory swapaccount=1"; fi + +load ${devtype} ${devnum} ${fdt_addr_r} ${prefix}dtb/${fdtfile} +fdt addr ${fdt_addr_r} +fdt resize 65536 +for overlay_file in ${overlays}; do + if load ${devtype} ${devnum} ${load_addr} ${prefix}dtb/allwinner/overlay/${overlay_prefix}-${overlay_file}.dtbo; then + echo "Applying kernel provided DT overlay ${overlay_prefix}-${overlay_file}.dtbo" + fdt apply ${load_addr} || setenv overlay_error "true" + fi +done +for overlay_file in ${user_overlays}; do + if load ${devtype} ${devnum} ${load_addr} ${prefix}overlay-user/${overlay_file}.dtbo; then + echo "Applying user provided DT overlay ${overlay_file}.dtbo" + fdt apply ${load_addr} || setenv overlay_error "true" + fi +done +if test "${overlay_error}" = "true"; then + echo "Error applying DT overlays, restoring original DT" + load ${devtype} ${devnum} ${fdt_addr_r} ${prefix}dtb/${fdtfile} +else + if load ${devtype} ${devnum} ${load_addr} ${prefix}dtb/allwinner/overlay/${overlay_prefix}-fixup.scr; then + echo "Applying kernel provided DT fixup script (${overlay_prefix}-fixup.scr)" + source ${load_addr} + fi + if test -e ${devtype} ${devnum} ${prefix}fixup.scr; then + load ${devtype} ${devnum} ${load_addr} ${prefix}fixup.scr + echo "Applying user provided fixup script (fixup.scr)" + source ${load_addr} + fi +fi + +if test "${ethernet_phy}" = "rtl8211f"; then + fdt set /soc/ethernet@5020000 allwinner,rx-delay-ps <3100> + fdt set /soc/ethernet@5020000 allwinner,tx-delay-ps <700> +fi + +if test "${ethernet_phy}" = "yt8531c"; then + fdt set /soc/ethernet@5020000 allwinner,rx-delay-ps <0> + fdt set /soc/ethernet@5020000 allwinner,tx-delay-ps <600> +fi + +load ${devtype} ${devnum} ${ramdisk_addr_r} ${prefix}uInitrd +load ${devtype} ${devnum} ${kernel_addr_r} ${prefix}Image + +booti ${kernel_addr_r} ${ramdisk_addr_r} ${fdt_addr_r} + +# Recompile with: +# mkimage -C none -A arm -T script -d /boot/boot.cmd /boot/boot.scr diff --git a/external/config/sources/families/sun50iw9.conf b/external/config/sources/families/sun50iw9.conf index 4100a84..f5ca2e7 100644 --- a/external/config/sources/families/sun50iw9.conf +++ b/external/config/sources/families/sun50iw9.conf @@ -37,12 +37,9 @@ case $BRANCH in UBOOT_TARGET_MAP=';;u-boot-sunxi-with-spl.bin' #BOOTBRANCH='branch:v2021.07-sunxi' BOOTBRANCH='branch:v2021.10-sunxi' - BOOTSCRIPT='boot-sun50i-next.cmd:boot.cmd' + BOOTSCRIPT='boot-sun50iw9-current.cmd:boot.cmd' ASOUND_STATE='asound.state.sun50iw9-current' - #KERNELBRANCH='branch:orange-pi-5.13-sunxi64' - #LINUXCONFIG='linux-5.13-sunxi64' - KERNELBRANCH="branch:orange-pi-5.16-sunxi64" LINUXCONFIG="linux-5.16-sun50iw9-current"