Hello Craig, Thank you very much for this patch. This is perfectly readable :) It looks logical to me, however I am not an expert when it comes to SBCs, so I will leave this for Arne to review and merge. Best, -Michael > On 20 May 2024, at 13:17, Craig Setera wrote: > > Updates to u-boot script for Raspberry Pi 4b devices to > properly configure the serial console and to choose the proper boot address > to be used on newer board revisions. With these changes in place, I'm able > to fully boot into a serial console in u-boot. > > The serial console configuration was derived from the Grub configuration, > while the boot address changes were taken from the IPFire Raspberry 4b > documentation page: https://www.ipfire.org/docs/hardware/arm/rpi/four > > Per the conversation in the forums, I don't know why the boot > address changes are required. I was simply trying to automate those > changes such that downloaded builds will work out of the box. > https://community.ipfire.org/t/hang-with-kernel-starting-on-raspberry-pi/11558/37 > > NOTE: The use of the different parameter options to the test > command to minimize the need for deeply nested conditionals. I did > try more bash-shell like syntax, but u-boot didn't seem to like that. > The operators used here were found in the u-boot source. > > Tested-by: Craig Setera > Signed-off-by: Craig Setera > --- > config/u-boot/boot.cmd | 27 ++++++++++++++++++++++++--- > 1 file changed, 24 insertions(+), 3 deletions(-) > > diff --git a/config/u-boot/boot.cmd b/config/u-boot/boot.cmd > index a27996780..eedd5776d 100644 > --- a/config/u-boot/boot.cmd > +++ b/config/u-boot/boot.cmd > @@ -51,7 +51,11 @@ if test "${SERIAL-CONSOLE}" = "ON"; then > if test "${fdtfile}" = "broadcom/bcm2837-rpi-3-b.dtb"; then > setenv console ttyS1,115200n8; > else > - setenv console ttyAMA0,115200n8; > + if test "${fdtfile}" = "broadcom/bcm2711-rpi-4-b.dtb"; then > + setenv console ttyS0,115200n8; > + else > + setenv console ttyAMA0,115200n8; > + fi; > fi; > fi; > else > @@ -95,11 +99,28 @@ else > setenv ramdisk_addr -; > fi; > > +# > +# Handle Raspberry Pi 4 address differences > +# https://www.ipfire.org/docs/hardware/arm/rpi/four > +# > +setenv booti_fdt_addr ${fdt_addr_r}; > +if test "${board}" -eq "rpi" -a ${cpu} -eq "armv8" -a "${fdtfile}" -eq "broadcom/bcm2711-rpi-4-b.dtb"; then > + # Hardware revision 1.4 > + if test ${board_revision} -eq 0xB03114 -o ${board_revision} -eq 0xC03114 -o ${board_revision} -eq 0xD03114; then > + setenv booti_fdt_addr ${fdt_addr}; > + fi > + > + # Hardware revision 1.5 > + if test ${board_revision} -eq 0xB03115 -o ${board_revision} -eq 0xC03115 -o ${board_revision} -eq 0xD03115; then > + setenv booti_fdt_addr ${fdt_addr}; > + fi > +fi; > + > bootz ${kernel_addr_r} ${ramdisk_addr} ${fdt_addr_r}; > -booti ${kernel_addr_r} ${ramdisk_addr} ${fdt_addr_r}; > +booti ${kernel_addr_r} ${ramdisk_addr} ${booti_fdt_addr}; > > bootz ${kernel_addr_r} - ${fdt_addr_r}; > -booti ${kernel_addr_r} - ${fdt_addr_r}; > +booti ${kernel_addr_r} - ${booti_fdt_addr}; > > # Recompile with: > # mkimage -C none -A arm -T script -d /boot/boot.cmd /boot/boot.scr > -- > 2.40.1 > >