Collecting known-good u-boot output for debugging purposes

Hi,

to better debug issues like Debugging boot failures and as prompted again by @zeha on IRC, it would be helpful to start collecting how u-boot output for each platform is expected to look like. I started with a311d on the big reform:

If you would like to contribute with your platform (my LS1028A is currently in repair), connect your (Pocket) Reform with another computer via UART and run a tty terminal application like tio according to the handbook: Advanced Topics — MNT Reform Operator Handbook, 2nd Edition documentation

Then start up your reform and press some key when it says “Hit any key to stop autoboot”. In the u-boot prompt, run the command printenv and once that is done, boot the system by running boot.

Then put the output into a pastebin so that I can put it into that wiki article or edit the wiki article yourself if you have an account on source.mnt.re.

Thanks!

1 Like

Could anybody help me getting this from a Pocket?

Given the following image, I connected:

  • port 1 to RXD
  • port 2 to TXD
  • port 3 to GND

with my adapter set to 3.3V

Ran tio as manual states, tio /dev/ttyUSB0 -b 115200, it connects to the usb adapter, but when I boot the pocket nothing appears on the serial connection.

1 being leftmost right angle header in the image you shared:

Connect 1 (labeled GND) to ground on your serial adapter
Connect 2 (labeled RX2) to TX on your serial adapter
Connect 3 (labeled TX2) to RX on your serial adapter
And that’s all! Don’t connect power from your serial adapter

1 Like

Thank you very much! That did it.

1 Like

These are my Pocket u-boot messages:

U-Boot SPL 2022.04-gb0e908b1-dirty (May 02 2024 - 19:18:25 +0000)
config to do 4000 1d training.
config to do 400 1d training.
config to do 100 1d training.
config to do 4000 2d training.
Normal Boot
Trying to boot from BOOTROM
image offset 0x0, pagesize 0x200, ivt offset 0x0
NOTICE:  Do not release JR0 to NS as it can be used by HAB
NOTICE:  BL31: v2.8(release):lf-6.1.22-2.0.0-6-g7e3484cc1
NOTICE:  BL31: Built : 15:05:50, Oct 17 2023


U-Boot 2022.04-gb0e908b1-dirty (May 02 2024 - 19:18:25 +0000)

CPU:   i.MX8MP[8] rev1.1 1800 MHz (running at 1200 MHz)
CPU:   Commercial temperature grade (0C to 95C) at 29C
Reset cause: POR
Model: MNT Pocket Reform with i.MX8MP Module
Board: nitrogen8mp
       Watchdog enabled
DRAM:  8 GiB
No USB device found
Core:  142 devices, 26 uclasses, devicetree: separate
MMC:   FSL_SDHC: 0, FSL_SDHC: 2
Loading Environment from MMC...
*** Warning - bad CRC, using default environment

missing node fb_lvds
missing node ldb/lvds-channel@0
missing node ldb/lvds-channel@1
missing node mipi_dsi
missing node lcdif
Display: hdmi:1920x1080M@60 (1920x1080)
[*]-Video Link 2 (1920 x 1080)
        [0] lcd-controller@32fc6000, video
        [1] hdmi@32fd8000, display
In:    serial
Out:   serial
Err:   serial

 BuildInfo:
  - ATF 7e3484c

missing node fb_lvds
missing node ldb/lvds-channel@0
missing node ldb/lvds-channel@1
missing node mipi_dsi
missing node lcdif
Net:   Could not get PHY for FEC1: mask 0x90
Could not get PHY for FEC1: mask 0x90
Micrel ksz9031
eth0: ethernet@30bf0000 [PRIME]
Hit any key to stop autoboot:  0 
=> printenv 
arch=arm
baudrate=115200
board=nitrogen8mp
board_carrier=-enc
board_name=nitrogen8mp
board_rv=_r20
boot_a_script=setenv disk ${devnum}; setenv dtype ${devtype}; setenv bootpart ${distro_bootpart}; load ${devtype} ${devnum}:${distro_bootpart} ${scriptaddr} ${prefix}${script}; source ${scriptaddr}
boot_efi_binary=load ${devtype} ${devnum}:${distro_bootpart} ${kernel_addr_r} efi/boot/bootaa64.efi; if fdt addr ${fdt_addr_r}; then bootefi ${kernel_addr_r} ${fdt_addr_r};else bootefi ${kernel_addr_r} ${fdtcontroladdr};fi
boot_efi_bootmgr=if fdt addr ${fdt_addr_r}; then bootefi bootmgr ${fdt_addr_r};else bootefi bootmgr;fi
boot_extlinux=sysboot ${devtype} ${devnum}:${distro_bootpart} any ${scriptaddr} ${prefix}${boot_syslinux_conf}
boot_net_usb_start=usb start
boot_prefixes=/boot/ /
boot_script_dhcp=boot.scr.uimg
boot_scripts=boot.scr.uimg boot.scr
boot_syslinux_conf=extlinux/extlinux.conf
boot_targets=mmc0 mmc2 usb0 
bootargs=ro no_console_suspend pci=pcie_bus_perf nvme_core.default_ps_max_latency_us=0 console=tty1 fbcon=rotate:3 cma=256MB
bootcmd=run distro_bootcmd
bootcmd_mmc0=devnum=0; run mmc_boot
bootcmd_mmc2=devnum=2; run mmc_boot
bootcmd_usb0=devnum=0; run usb_boot
bootdelay=2
cmd_hdmi=fdt set fb_hdmi status okay;fdt set fb_hdmi mode_str 1920x1080M@60;
cmd_lvds=fdt set fb_lvds status disabled;fdt set ldb/lvds-channel@0 status disabled;
cmd_lvds2=fdt set ldb/lvds-channel@1 status disabled;
cmd_mipi=fdt set mipi_dsi status disabled;fdt set lcdif status disabled;
console=ttymxc1
cpu=armv8
distro_bootcmd=for target in ${boot_targets}; do run bootcmd_${target}; done
efi_dtb_prefixes=/ /dtb/ /dtb/current/
env_dev=2
env_part=1
eth2addr=00:19:b8:00:00:02
ethact=ethernet@30bf0000
ethaddr=00:19:b8:0f:40:be
ethprime=eth0
fastboot_raw_partition_bootloader=0x0 0x1ff0 mmcpart 1
fastboot_raw_partition_bootloader-env=0x1ff0 0x10 mmcpart 1
fb_hdmi_name=1920x1080M@60
fdt_addr=0x43000000
fdt_addr_r=0x43000000
fdt_high=0xffffffffffffffff
fdtcontroladdr=f4bf08c0
fuse1=1 3
fuse1_val=10002000
fuse_mac1a=9 1
fuse_mac1a_val=00000019
fuse_mac1b=9 0
imx_cpu=8MP[8]
initrd_high=0xffffffffffffffff
kernel_addr_r=0x40480000
load_efi_dtb=load ${devtype} ${devnum}:${distro_bootpart} ${fdt_addr_r} ${prefix}${efi_fdtfile}
loadaddr=0x40480000
m4boot=load ${devtype} ${devnum}:1 ${m4loadaddr} ${m4image}; dcache flush; bootaux ${m4loadaddr}
m4image=m4_fw.bin
m4loadaddr=0x007E0000
mcore_bootargs=clk-imx8mp.mcore_booted
mmc_boot=if mmc dev ${devnum}; then devtype=mmc; run scan_dev_for_boot_part; fi
net_upgradeu=dhcp 40020000 net_upgradeu.scr && source 40020000
netargs=setenv bootargs console=${console},115200 root=/dev/nfs rw ip=dhcp nfsroot=${tftpserverip}:${nfsroot},v3,tcp
netboot=run netargs; if test -z "${fdt_file}" -a -n "${soc}"; then setenv fdt_file ${soc}-${board}${boardver}.dtb; fi; if test ${ip_dyn} = yes; then setenv get_cmd dhcp; else setenv get_cmd tftp; fi; ${get_cmd} ${loadaddr} ${tftpserverip}:Image; if ${get_cmd} ${fdt_addr} ${tftpserverip}:${fdt_file}; then booti ${loadaddr} - ${fdt_addr}; else echo WARN: Cannot load the DT; fi;
otg_upgradeu=run usbnetwork; tftp 40020000 net_upgradeu.scr && source 40020000
pxefile_addr_r=0x40480000
ramdisk_addr_r=0x43800000
scan_dev_for_boot=echo Scanning ${devtype} ${devnum}:${distro_bootpart}...; for prefix in ${boot_prefixes}; do run scan_dev_for_extlinux; run scan_dev_for_scripts; done;run scan_dev_for_efi;
scan_dev_for_boot_part=part list ${devtype} ${devnum} -bootable devplist; env exists devplist || setenv devplist 1; for distro_bootpart in ${devplist}; do if fstype ${devtype} ${devnum}:${distro_bootpart} bootfstype; then run scan_dev_for_boot; fi; done; setenv devplist
scan_dev_for_efi=setenv efi_fdtfile ${fdtfile}; for prefix in ${efi_dtb_prefixes}; do if test -e ${devtype} ${devnum}:${distro_bootpart} ${prefix}${efi_fdtfile}; then run load_efi_dtb; fi;done;run boot_efi_bootmgr;if test -e ${devtype} ${devnum}:${distro_bootpart} efi/boot/bootaa64.efi; then echo Found EFI removable media binary efi/boot/bootaa64.efi; run boot_efi_binary; echo EFI LOAD FAILED: continuing...; fi; setenv efi_fdtfile
scan_dev_for_extlinux=if test -e ${devtype} ${devnum}:${distro_bootpart} ${prefix}${boot_syslinux_conf}; then echo Found ${prefix}${boot_syslinux_conf}; run boot_extlinux; echo SCRIPT FAILED: continuing...; fi
scan_dev_for_scripts=for script in ${boot_scripts}; do if test -e ${devtype} ${devnum}:${distro_bootpart} ${prefix}${script}; then echo Found U-Boot script ${prefix}${script}; run boot_a_script; echo script exited: continuing...; fi; done
scriptaddr=0x40480000
serial#=0019b80f40be
soc=imx8m
uboot_defconfig=nitrogen8mp_8g
uboot_release=2022.04-gb0e908b1-dirty
upgradeu=setenv boot_scripts upgrade.scr; boot;echo Upgrade failed!; setenv boot_scripts boot.scr
usb_boot=usb start; if usb dev ${devnum}; then devtype=usb; run scan_dev_for_boot_part; fi
usbnet_devaddr=00:19:b8:00:00:02
usbnet_hostaddr=00:19:b8:00:00:01
usbnetwork=setenv ethact usb_ether; setenv ipaddr 10.0.0.2; setenv netmask 255.255.255.0; setenv serverip 10.0.0.1;
vendor=boundary
vidconsole=vidconsole

Environment size: 5071/8188 bytes
=> boot
MMC: no card present
mmc_init: -123, time 2
switch to partitions #0, OK
mmc2(part 0) is current device
Scanning mmc 2:1...
Found U-Boot script /boot.scr
5486 bytes read in 2 ms (2.6 MiB/s)
## Executing script at 40480000
28473856 bytes read in 161 ms (168.7 MiB/s)
53182 bytes read in 4 ms (12.7 MiB/s)
33223770 bytes read in 186 ms (170.3 MiB/s)
Booting Debian 6.10.3-mnt-reform-arm64 from mmc 2:1...
Moving Image from 0x40480000 to 0x40600000, end=42200000
## Flattened Device Tree blob at 43000000
   Booting using the fdt blob at 0x43000000
   Using Device Tree in place at 0000000043000000, end 000000004300ffbd

Starting kernel ...


Debian GNU/Linux trixie/sid reform ttymxc1

reform login: 
1 Like

Thank you @amospalla

Could you also, when it says “Hit any key to stop autoboot”, press a key so that you are dropped to the u-boot console? And in there, execute first printenv and then boot as detailed in my initial post. And then share the output. Thank you!

1 Like

Yeah, sorry, forgot that part :laughing: , I updated my previous message to include the printenv.