[PATCH v3 8/8] sunxi: Move to text environment
Andre Przywara
andre.przywara at arm.com
Thu Oct 3 02:45:26 CEST 2024
On Sun, 1 Sep 2024 16:27:34 -0600
Simon Glass <sjg at chromium.org> wrote:
Hi Simon,
> Convert these boards to use a text environment.
>
> For the boards check, the only differences are extra spaces after the
> semicolons in 'dfu_alt_info_ram' and 'partitions', both of which are
> permitted.
>
> Add in the special boot command for old kernels, dropping the
> unnecessary and confusing hex prefixes.
>
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
>
> (no changes since v2)
>
> Changes in v2:
> - Keep bootcmd_sunxi_compat if OLD_SUNXI_KERNEL_COMPAT is enabled
>
> board/sunxi/sunxi.env | 152 ++++++++++++++++++++++++++++++
> include/configs/sunxi-common.h | 165 ---------------------------------
> 2 files changed, 152 insertions(+), 165 deletions(-)
> create mode 100644 board/sunxi/sunxi.env
>
> diff --git a/board/sunxi/sunxi.env b/board/sunxi/sunxi.env
> new file mode 100644
> index 00000000000..6f28e720081
> --- /dev/null
> +++ b/board/sunxi/sunxi.env
> @@ -0,0 +1,152 @@
> +// SPDX-License-Identifier: GPL-2.0+
> +/*
> + * Common sunxi environment
> + *
> + * Copyright 2024 Google LLC
> + * Written by Simon Glass <sjg at chromium.org>
> + /
> +
> +/****************************************************************************
> + * environment variables holding default load addresses *
> + ****************************************************************************/
> +/*
> + * We cannot use expressions here, because expressions won't be evaluated in
> + * autoconf.mk.
> + */
> +#ifdef CONFIG_ARM64
> +/*
> + * Boards seem to come with at least 512MB of DRAM.
> + * The kernel should go at 512K, which is the default text offset (that will
> + * be adjusted at runtime if needed).
> + * There is no compression for arm64 kernels (yet), so leave some space
> + * for really big kernels, say 256MB for now.
> + * Scripts, PXE and DTBs should go afterwards, leaving the rest for the initrd.
> + */
> +#define BOOTM_SIZE 0xa000000
> +#define KERNEL_ADDR_R SDRAM_OFFSET(0080000)
> +#define KERNEL_COMP_ADDR_R SDRAM_OFFSET(4000000)
> +#define KERNEL_COMP_SIZE 0xb000000
> +#define FDT_ADDR_R SDRAM_OFFSET(FA00000)
> +#define SCRIPT_ADDR_R SDRAM_OFFSET(FC00000)
> +#define PXEFILE_ADDR_R SDRAM_OFFSET(FD00000)
> +#define FDTOVERLAY_ADDR_R SDRAM_OFFSET(FE00000)
> +#define RAMDISK_ADDR_R SDRAM_OFFSET(FF00000)
> +
> +#elif (CONFIG_SUNXI_MINIMUM_DRAM_MB >= 256)
> +/*
> + * 160M RAM (256M minimum minus 64MB heap + 32MB for u-boot, stack, fb, etc.
> + * 32M uncompressed kernel, 16M compressed kernel, 1M fdt,
> + * 1M script, 1M pxe, 1M dt overlay and the ramdisk at the end.
> + */
> +#define BOOTM_SIZE 0xa000000
> +#define KERNEL_ADDR_R SDRAM_OFFSET(2000000)
> +#define FDT_ADDR_R SDRAM_OFFSET(3000000)
> +#define SCRIPT_ADDR_R SDRAM_OFFSET(3100000)
> +#define PXEFILE_ADDR_R SDRAM_OFFSET(3200000)
> +#define FDTOVERLAY_ADDR_R SDRAM_OFFSET(3300000)
> +#define RAMDISK_ADDR_R SDRAM_OFFSET(3400000)
> +
> +#elif (CONFIG_SUNXI_MINIMUM_DRAM_MB >= 64)
> +/*
> + * 64M RAM minus 2MB heap + 16MB for u-boot, stack, fb, etc.
> + * 16M uncompressed kernel, 8M compressed kernel, 1M fdt,
> + * 1M script, 1M pxe, 1M dt overlay and the ramdisk at the end.
> + */
> +#define BOOTM_SIZE 0x2e00000
> +#define KERNEL_ADDR_R SDRAM_OFFSET(1000000)
> +#define FDT_ADDR_R SDRAM_OFFSET(1800000)
> +#define SCRIPT_ADDR_R SDRAM_OFFSET(1900000)
> +#define PXEFILE_ADDR_R SDRAM_OFFSET(1A00000)
> +#define FDTOVERLAY_ADDR_R SDRAM_OFFSET(1B00000)
> +#define RAMDISK_ADDR_R SDRAM_OFFSET(1C00000)
> +
> +#elif (CONFIG_SUNXI_MINIMUM_DRAM_MB >= 32)
> +/*
> + * 32M RAM minus 2.5MB for u-boot, heap, stack, etc.
> + * 16M uncompressed kernel, 7M compressed kernel, 128K fdt, 64K script,
> + * 128K DT overlay, 128K PXE and the ramdisk in the rest (max. 5MB)
> + */
> +#define BOOTM_SIZE 0x1700000
> +#define KERNEL_ADDR_R SDRAM_OFFSET(1000000)
> +#define FDT_ADDR_R SDRAM_OFFSET(1d50000)
> +#define SCRIPT_ADDR_R SDRAM_OFFSET(1d40000)
> +#define PXEFILE_ADDR_R SDRAM_OFFSET(1d00000)
> +#define FDTOVERLAY_ADDR_R SDRAM_OFFSET(1d20000)
> +#define RAMDISK_ADDR_R SDRAM_OFFSET(1800000)
> +
> +#else
> +#error Need at least 32MB of DRAM. Please adjust load addresses.
> +#endif
> +
> +#define UUID_GPT_ESP ""
> +
> +#ifdef CONFIG_ARM64
> +#define UUID_GPT_SYSTEM b921b045-1df0-41c3-af44-4c6f280d3fae
> +#else
> +#define UUID_GPT_SYSTEM 69dad710-2ce4-4e3c-b16c-21a1d49abed3
> +#endif
Do we really need those definitions? In the header file those were
later used in the actual (lower case) variable assignment, but here the
UUIDs are assigned directly (below)?
> +
> +stdin=serial
> +#ifdef CONFIG_USB_KEYBOARD
> +stdin+=,usbkbd
> +#endif
> +
> +stdout=serial
> +stderr=serial
> +#ifdef CONFIG_VIDEO
> +stdout+=,vidconsole
> +stderr+=,vidconsole
> +#endif
> +
> +bootm_size=BOOTM_SIZE
> +kernel_addr_r=KERNEL_ADDR_R
> +fdt_addr_r=FDT_ADDR_R
> +scriptaddr=SCRIPT_ADDR_R
> +pxefile_addr_r=PXEFILE_ADDR_R
> +fdtoverlay_addr_r=FDTOVERLAY_ADDR_R
> +ramdisk_addr_r=RAMDISK_ADDR_R
> +
> +#ifdef CONFIG_ARM64
> +kernel_comp_addr_r=KERNEL_COMP_ADDR_R
> +kernel_comp_size=KERNEL_COMP_SIZE
> +#endif
> +
> +dfu_alt_info_ram=
> + kernel ram KERNEL_ADDR_R 0x1000000;
> + fdt ram FDT_ADDR_R 0x100000;
> + ramdisk ram RAMDISK_ADDR_R 0x4000000
> +
> +#ifdef CONFIG_ARM64
> +fdtfile=allwinner/DEFAULT_DEVICE_TREE.dtb
I am confused, shouldn't that be CONFIG_DEFAULT_DEVICE_TREE? Or is
there more magic involved? And it looks like something is prepending
the directory name already:
(comparing the env between current master and after these patches)
-fdtcontroladdr=fbf0b090
-fdtfile=allwinner/sun50i-h618-orangepi-zero3.dtb
+fdtcontroladdr=fbf0aa30
+fdtfile=allwinner/allwinner/sun50i-h618-orangepi-zero3.dtb
(Or is this a problem with the switch to dts/upstream for the H616 I
have in my tree already?)
> +#else
> +fdtfile=DEFAULT_DEVICE_TREE.dtb
> +#endif
> +
> +console=ttyS0,115200
> +
> +uuid_gpt_esp=c12a7328-f81f-11d2-ba4b-00a0c93ec93b
> +#ifdef CONFIG_ARM64
> +uuid_gpt_system=b921b045-1df0-41c3-af44-4c6f280d3fae
> +#else
> +uuid_gpt_system=69dad710-2ce4-4e3c-b16c-21a1d49abed3
> +#endif
> +
> +partitions=
> + name=loader1,start=8k,size=32k,uuid=${uuid_gpt_loader1};
> + name=loader2,size=984k,uuid=${uuid_gpt_loader2};
> + name=esp,size=128M,bootable,uuid=${uuid_gpt_esp};
> + name=system,size=-,uuid=${uuid_gpt_system};
> +
> +/* support booting a very old kernel */
> +#ifdef CONFIG_OLD_SUNXI_KERNEL_COMPAT
> +bootcmd_sunxi_compat=
> + setenv root /dev/mmcblk0p3 rootwait;
> + if ext2load mmc 0 44000000 uEnv.txt; then
> + "echo Loaded environment from uEnv.txt;
> + "env import -t 44000000 ${filesize};
is the indentation and the initial quotation for those two lines a
leftover from the old file?
The rest seems to be the same as before, effectively.
Other than those nits I like the new way much better, didn't know we
could now do this.
Cheers,
Andre
> + fi;
> + setenv bootargs console=${console} root=${root} ${extraargs};
> + ext2load mmc 0 43000000 script.bin &&
> + ext2load mmc 0 48000000 uImage &&
> + bootm 48000000
> +#endif
> diff --git a/include/configs/sunxi-common.h b/include/configs/sunxi-common.h
> index 666553ccadb..ceea26494ad 100644
> --- a/include/configs/sunxi-common.h
> +++ b/include/configs/sunxi-common.h
> @@ -61,169 +61,4 @@
> #define PHYS_SDRAM_0 CFG_SYS_SDRAM_BASE
> #define PHYS_SDRAM_0_SIZE 0x80000000 /* 2 GiB */
>
> -/****************************************************************************
> - * environment variables holding default load addresses *
> - ****************************************************************************/
> -/*
> - * We cannot use expressions here, because expressions won't be evaluated in
> - * autoconf.mk.
> - */
> -#ifdef CONFIG_ARM64
> -/*
> - * Boards seem to come with at least 512MB of DRAM.
> - * The kernel should go at 512K, which is the default text offset (that will
> - * be adjusted at runtime if needed).
> - * There is no compression for arm64 kernels (yet), so leave some space
> - * for really big kernels, say 256MB for now.
> - * Scripts, PXE and DTBs should go afterwards, leaving the rest for the initrd.
> - */
> -#define BOOTM_SIZE __stringify(0xa000000)
> -#define KERNEL_ADDR_R __stringify(SDRAM_OFFSET(0080000))
> -#define KERNEL_COMP_ADDR_R __stringify(SDRAM_OFFSET(4000000))
> -#define KERNEL_COMP_SIZE __stringify(0xb000000)
> -#define FDT_ADDR_R __stringify(SDRAM_OFFSET(FA00000))
> -#define SCRIPT_ADDR_R __stringify(SDRAM_OFFSET(FC00000))
> -#define PXEFILE_ADDR_R __stringify(SDRAM_OFFSET(FD00000))
> -#define FDTOVERLAY_ADDR_R __stringify(SDRAM_OFFSET(FE00000))
> -#define RAMDISK_ADDR_R __stringify(SDRAM_OFFSET(FF00000))
> -
> -#elif (CONFIG_SUNXI_MINIMUM_DRAM_MB >= 256)
> -/*
> - * 160M RAM (256M minimum minus 64MB heap + 32MB for u-boot, stack, fb, etc.
> - * 32M uncompressed kernel, 16M compressed kernel, 1M fdt,
> - * 1M script, 1M pxe, 1M dt overlay and the ramdisk at the end.
> - */
> -#define BOOTM_SIZE __stringify(0xa000000)
> -#define KERNEL_ADDR_R __stringify(SDRAM_OFFSET(2000000))
> -#define FDT_ADDR_R __stringify(SDRAM_OFFSET(3000000))
> -#define SCRIPT_ADDR_R __stringify(SDRAM_OFFSET(3100000))
> -#define PXEFILE_ADDR_R __stringify(SDRAM_OFFSET(3200000))
> -#define FDTOVERLAY_ADDR_R __stringify(SDRAM_OFFSET(3300000))
> -#define RAMDISK_ADDR_R __stringify(SDRAM_OFFSET(3400000))
> -
> -#elif (CONFIG_SUNXI_MINIMUM_DRAM_MB >= 64)
> -/*
> - * 64M RAM minus 2MB heap + 16MB for u-boot, stack, fb, etc.
> - * 16M uncompressed kernel, 8M compressed kernel, 1M fdt,
> - * 1M script, 1M pxe, 1M dt overlay and the ramdisk at the end.
> - */
> -#define BOOTM_SIZE __stringify(0x2e00000)
> -#define KERNEL_ADDR_R __stringify(SDRAM_OFFSET(1000000))
> -#define FDT_ADDR_R __stringify(SDRAM_OFFSET(1800000))
> -#define SCRIPT_ADDR_R __stringify(SDRAM_OFFSET(1900000))
> -#define PXEFILE_ADDR_R __stringify(SDRAM_OFFSET(1A00000))
> -#define FDTOVERLAY_ADDR_R __stringify(SDRAM_OFFSET(1B00000))
> -#define RAMDISK_ADDR_R __stringify(SDRAM_OFFSET(1C00000))
> -
> -#elif (CONFIG_SUNXI_MINIMUM_DRAM_MB >= 32)
> -/*
> - * 32M RAM minus 2.5MB for u-boot, heap, stack, etc.
> - * 16M uncompressed kernel, 7M compressed kernel, 128K fdt, 64K script,
> - * 128K DT overlay, 128K PXE and the ramdisk in the rest (max. 5MB)
> - */
> -#define BOOTM_SIZE __stringify(0x1700000)
> -#define KERNEL_ADDR_R __stringify(SDRAM_OFFSET(1000000))
> -#define FDT_ADDR_R __stringify(SDRAM_OFFSET(1d50000))
> -#define SCRIPT_ADDR_R __stringify(SDRAM_OFFSET(1d40000))
> -#define PXEFILE_ADDR_R __stringify(SDRAM_OFFSET(1d00000))
> -#define FDTOVERLAY_ADDR_R __stringify(SDRAM_OFFSET(1d20000))
> -#define RAMDISK_ADDR_R __stringify(SDRAM_OFFSET(1800000))
> -
> -#else
> -#error Need at least 32MB of DRAM. Please adjust load addresses.
> -#endif
> -
> -#define MEM_LAYOUT_ENV_SETTINGS \
> - "bootm_size=" BOOTM_SIZE "\0" \
> - "kernel_addr_r=" KERNEL_ADDR_R "\0" \
> - "fdt_addr_r=" FDT_ADDR_R "\0" \
> - "scriptaddr=" SCRIPT_ADDR_R "\0" \
> - "pxefile_addr_r=" PXEFILE_ADDR_R "\0" \
> - "fdtoverlay_addr_r=" FDTOVERLAY_ADDR_R "\0" \
> - "ramdisk_addr_r=" RAMDISK_ADDR_R "\0"
> -
> -#ifdef CONFIG_ARM64
> -#define MEM_LAYOUT_ENV_EXTRA_SETTINGS \
> - "kernel_comp_addr_r=" KERNEL_COMP_ADDR_R "\0" \
> - "kernel_comp_size=" KERNEL_COMP_SIZE "\0"
> -#else
> -#define MEM_LAYOUT_ENV_EXTRA_SETTINGS ""
> -#endif
> -
> -#define DFU_ALT_INFO_RAM \
> - "dfu_alt_info_ram=" \
> - "kernel ram " KERNEL_ADDR_R " 0x1000000;" \
> - "fdt ram " FDT_ADDR_R " 0x100000;" \
> - "ramdisk ram " RAMDISK_ADDR_R " 0x4000000\0"
> -
> -#ifdef CONFIG_OLD_SUNXI_KERNEL_COMPAT
> -#define BOOTCMD_SUNXI_COMPAT \
> - "bootcmd_sunxi_compat=" \
> - "setenv root /dev/mmcblk0p3 rootwait; " \
> - "if ext2load mmc 0 0x44000000 uEnv.txt; then " \
> - "echo Loaded environment from uEnv.txt; " \
> - "env import -t 0x44000000 ${filesize}; " \
> - "fi; " \
> - "setenv bootargs console=${console} root=${root} ${extraargs}; " \
> - "ext2load mmc 0 0x43000000 script.bin && " \
> - "ext2load mmc 0 0x48000000 uImage && " \
> - "bootm 0x48000000\0"
> -#else
> -#define BOOTCMD_SUNXI_COMPAT
> -#endif
> -
> -#ifdef CONFIG_USB_KEYBOARD
> -#define CONSOLE_STDIN_SETTINGS \
> - "stdin=serial,usbkbd\0"
> -#else
> -#define CONSOLE_STDIN_SETTINGS \
> - "stdin=serial\0"
> -#endif
> -
> -#ifdef CONFIG_VIDEO
> -#define CONSOLE_STDOUT_SETTINGS \
> - "stdout=serial,vidconsole\0" \
> - "stderr=serial,vidconsole\0"
> -#else
> -#define CONSOLE_STDOUT_SETTINGS \
> - "stdout=serial\0" \
> - "stderr=serial\0"
> -#endif
> -
> -#define PARTS_DEFAULT \
> - "name=loader1,start=8k,size=32k,uuid=${uuid_gpt_loader1};" \
> - "name=loader2,size=984k,uuid=${uuid_gpt_loader2};" \
> - "name=esp,size=128M,bootable,uuid=${uuid_gpt_esp};" \
> - "name=system,size=-,uuid=${uuid_gpt_system};"
> -
> -#define UUID_GPT_ESP "c12a7328-f81f-11d2-ba4b-00a0c93ec93b"
> -
> -#ifdef CONFIG_ARM64
> -#define UUID_GPT_SYSTEM "b921b045-1df0-41c3-af44-4c6f280d3fae"
> -#else
> -#define UUID_GPT_SYSTEM "69dad710-2ce4-4e3c-b16c-21a1d49abed3"
> -#endif
> -
> -#define CONSOLE_ENV_SETTINGS \
> - CONSOLE_STDIN_SETTINGS \
> - CONSOLE_STDOUT_SETTINGS
> -
> -#ifdef CONFIG_ARM64
> -#define FDTFILE "allwinner/" CONFIG_DEFAULT_DEVICE_TREE ".dtb"
> -#else
> -#define FDTFILE CONFIG_DEFAULT_DEVICE_TREE ".dtb"
> -#endif
> -
> -#define CFG_EXTRA_ENV_SETTINGS \
> - CONSOLE_ENV_SETTINGS \
> - MEM_LAYOUT_ENV_SETTINGS \
> - MEM_LAYOUT_ENV_EXTRA_SETTINGS \
> - DFU_ALT_INFO_RAM \
> - "fdtfile=" FDTFILE "\0" \
> - "console=ttyS0,115200\0" \
> - "uuid_gpt_esp=" UUID_GPT_ESP "\0" \
> - "uuid_gpt_system=" UUID_GPT_SYSTEM "\0" \
> - "partitions=" PARTS_DEFAULT "\0" \
> - BOOTCMD_SUNXI_COMPAT
> -
> #endif /* _SUNXI_COMMON_CONFIG_H */
More information about the U-Boot
mailing list