On Sun, 1 Sep 2024 16:27:34 -0600 Simon Glass <s...@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 <s...@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 <s...@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 */