From 5383a32c57199c59c465c1d7e9eae6932a6254b7 Mon Sep 17 00:00:00 2001 From: vegano1 Date: Thu, 15 Aug 2024 15:32:37 -0400 Subject: [PATCH 1/3] recipes-bsp/u-boot: conditionally set can clock frequency based on SOM rev. --- .../u-boot/u-boot-distro-boot/boot.cmd.in | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in b/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in index d4e31d24..df9c7da9 100644 --- a/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in +++ b/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in @@ -56,6 +56,18 @@ test -n ${overlays_file} || env set overlays_file "${rootfs_boot_dir}/overlays.t test -n ${overlays_prefix} || env set overlays_prefix "${rootfs_boot_dir}/overlays/" test -n ${vidargs} || env set vidargs "video=DSI-1:1024x600e" +# Determine if the CAN clock speed has to be to be set 20Hz for < revE SOM boards. +# This is done by reading the rev from the SOM eeprom (bus 0, addr 0x50), if its less than rev E +# the 'som_can_20hz' flag is set. When the overlays (dtbo) are applied we check +# the 'som_can_20hz' flag and the specific overlay file and set or skip it. +# SOM serial number format in eeprom: seq num (4b) + version (3b) + rev (1b) +env set som_can_20hz 0 +env set som_can_20hz_overlay "verdin-imx8mm_MCP2518_overlay.dtbo" +env set som_rev_e 34 # rev E ('4' ascii or 34 dec) +env set som_rev_addr 0 && setexpr som_rev_addr ${ramdisk_addr_r} + 0x7 +i2c dev 0 && i2c read 0x50 0x00 0x08 $ramdisk_addr_r +itest.b *${som_rev_addr} < ${som_rev_e} && env set som_can_20hz 1 + # load kernel + dtb(s) + overlays from rootfs test ${boot_devtype} = "mmc" && env set load_cmd 'ext4load ${boot_devtype} ${root_devnum}:${root_part}' test ${boot_devtype} = "usb" && env set load_cmd 'load ${boot_devtype} ${boot_devnum}:${boot_part}' @@ -116,7 +128,7 @@ then else env set fdt_resize 'fdt addr ${fdt_addr_r} && fdt resize 0x20000' env set set_bootcmd_dtb 'env set bootcmd_dtb "echo Loading DeviceTree: \\${rootfs_boot_dir}/\\${fdtfile}; ${load_cmd} \\${fdt_addr_r} \\${rootfs_boot_dir}/\\${fdtfile}"' - env set set_apply_overlays 'env set apply_overlays "for overlay_file in \\${fdt_overlays}; do echo Applying Overlay: \\${rootfs_boot_dir}/\\${overlay_file} && ${load_cmd} \\${loadaddr} \\${overlays_prefix}\\${overlay_file} && fdt apply \\${loadaddr}; env set overlay_file; done; true"' + env set set_apply_overlays 'env set apply_overlays "for overlay_file in \${fdt_overlays}; do env set skip 0; if test \${som_can_20hz} = 1 && test \\${overlay_file} = \${som_can_20hz_overlay}; then env set skip 1; fi; test \\${skip} = 0 && echo Applying Overlay: \\${rootfs_boot_dir}/\\${overlay_file} && ${load_cmd} \\${loadaddr} \\${overlays_prefix}\\${overlay_file} && fdt apply \\${loadaddr}; env set overlay_file; done; true"' env set bootcmd_boot 'echo "Bootargs: \${bootargs}" && @@KERNEL_BOOTCMD@@ ${kernel_addr_r} - ${fdt_addr_r}' fi From 4c8509617307f179d4a3776d6274c368f3c7bbc4 Mon Sep 17 00:00:00 2001 From: vegano1 Date: Sat, 17 Aug 2024 15:36:46 -0400 Subject: [PATCH 2/3] fix logic bug --- .../recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in b/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in index df9c7da9..12cb62eb 100644 --- a/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in +++ b/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in @@ -128,7 +128,7 @@ then else env set fdt_resize 'fdt addr ${fdt_addr_r} && fdt resize 0x20000' env set set_bootcmd_dtb 'env set bootcmd_dtb "echo Loading DeviceTree: \\${rootfs_boot_dir}/\\${fdtfile}; ${load_cmd} \\${fdt_addr_r} \\${rootfs_boot_dir}/\\${fdtfile}"' - env set set_apply_overlays 'env set apply_overlays "for overlay_file in \${fdt_overlays}; do env set skip 0; if test \${som_can_20hz} = 1 && test \\${overlay_file} = \${som_can_20hz_overlay}; then env set skip 1; fi; test \\${skip} = 0 && echo Applying Overlay: \\${rootfs_boot_dir}/\\${overlay_file} && ${load_cmd} \\${loadaddr} \\${overlays_prefix}\\${overlay_file} && fdt apply \\${loadaddr}; env set overlay_file; done; true"' + env set set_apply_overlays 'env set apply_overlays "for overlay_file in \\${fdt_overlays}; do env set skip 0; if test \${som_can_20hz} = 0 && test \\${overlay_file} = \${som_can_20hz_overlay}; then env set skip 1; fi; test \\${skip} = 0 && echo Applying Overlay: \\${rootfs_boot_dir}/\\${overlay_file} && ${load_cmd} \\${loadaddr} \\${overlays_prefix}\\${overlay_file} && fdt apply \\${loadaddr}; env set overlay_file; done; true"' env set bootcmd_boot 'echo "Bootargs: \${bootargs}" && @@KERNEL_BOOTCMD@@ ${kernel_addr_r} - ${fdt_addr_r}' fi From 56c02765e8ea7a3d9060217d2fc3ed377bdd3494 Mon Sep 17 00:00:00 2001 From: vegano1 Date: Tue, 20 Aug 2024 07:54:37 -0400 Subject: [PATCH 3/3] simplify logic --- .../u-boot/u-boot-distro-boot/boot.cmd.in | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in b/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in index 12cb62eb..48f97e27 100644 --- a/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in +++ b/layers/meta-opentrons/recipes-bsp/u-boot/u-boot-distro-boot/boot.cmd.in @@ -56,17 +56,17 @@ test -n ${overlays_file} || env set overlays_file "${rootfs_boot_dir}/overlays.t test -n ${overlays_prefix} || env set overlays_prefix "${rootfs_boot_dir}/overlays/" test -n ${vidargs} || env set vidargs "video=DSI-1:1024x600e" -# Determine if the CAN clock speed has to be to be set 20Hz for < revE SOM boards. -# This is done by reading the rev from the SOM eeprom (bus 0, addr 0x50), if its less than rev E -# the 'som_can_20hz' flag is set. When the overlays (dtbo) are applied we check -# the 'som_can_20hz' flag and the specific overlay file and set or skip it. -# SOM serial number format in eeprom: seq num (4b) + version (3b) + rev (1b) -env set som_can_20hz 0 -env set som_can_20hz_overlay "verdin-imx8mm_MCP2518_overlay.dtbo" +# Determine if the CAN clock speed has to be to be set 20MHz for < revE SOM boards. +# This is done by reading the rev from the SOM eeprom (bus 0, addr 0x50). When +# the rev is >= than rev E (34 dec), the 'overlay_to_skip' var is set to the overlay +# that sets the can clock to 20MHz. When we iterate over the overlays to apply, +# we skip the overlay equal to 'overlay_to_skip' otherwise the overlay is applied. +# SOM serial number format in eeprom: product num (4b) + version (3b) + rev (1b) +env set overlay_to_skip "" env set som_rev_e 34 # rev E ('4' ascii or 34 dec) env set som_rev_addr 0 && setexpr som_rev_addr ${ramdisk_addr_r} + 0x7 i2c dev 0 && i2c read 0x50 0x00 0x08 $ramdisk_addr_r -itest.b *${som_rev_addr} < ${som_rev_e} && env set som_can_20hz 1 +itest.b *${som_rev_addr} >= ${som_rev_e} && env set overlay_to_skip "verdin-imx8mm_MCP2518_overlay.dtbo" # load kernel + dtb(s) + overlays from rootfs test ${boot_devtype} = "mmc" && env set load_cmd 'ext4load ${boot_devtype} ${root_devnum}:${root_part}' @@ -128,7 +128,7 @@ then else env set fdt_resize 'fdt addr ${fdt_addr_r} && fdt resize 0x20000' env set set_bootcmd_dtb 'env set bootcmd_dtb "echo Loading DeviceTree: \\${rootfs_boot_dir}/\\${fdtfile}; ${load_cmd} \\${fdt_addr_r} \\${rootfs_boot_dir}/\\${fdtfile}"' - env set set_apply_overlays 'env set apply_overlays "for overlay_file in \\${fdt_overlays}; do env set skip 0; if test \${som_can_20hz} = 0 && test \\${overlay_file} = \${som_can_20hz_overlay}; then env set skip 1; fi; test \\${skip} = 0 && echo Applying Overlay: \\${rootfs_boot_dir}/\\${overlay_file} && ${load_cmd} \\${loadaddr} \\${overlays_prefix}\\${overlay_file} && fdt apply \\${loadaddr}; env set overlay_file; done; true"' + env set set_apply_overlays 'env set apply_overlays "for overlay_file in \\${fdt_overlays}; do test \\${overlay_file} != \\${overlay_to_skip} && echo Applying Overlay: \\${rootfs_boot_dir}/\\${overlay_file} && ${load_cmd} \\${loadaddr} \\${overlays_prefix}\\${overlay_file} && fdt apply \\${loadaddr}; env set overlay_file; done; true"' env set bootcmd_boot 'echo "Bootargs: \${bootargs}" && @@KERNEL_BOOTCMD@@ ${kernel_addr_r} - ${fdt_addr_r}' fi