sunxi: Move to text environment

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.

Series-changes: 2
- Keep bootcmd_sunxi_compat if OLD_SUNXI_KERNEL_COMPAT is enabled

Series-to: u-boot
Series-cc: sunxi, trini
Series-version: 2
Series-links: 418453
Cover-letter:
bootstd: sunxi: Migrate to standard boot
This series attempts to migrate all sunxi boards to use standard boot,
along with a text environment.
END
This commit is contained in:
Simon Glass
2024-07-30 17:26:16 -06:00
parent 1e6da4a507
commit 802f8d87f3
2 changed files with 152 additions and 165 deletions

152
board/sunxi/sunxi.env Normal file
View File

@@ -0,0 +1,152 @@
// SPDX-License-Identifier: GPL-2.0+
/*
* Common sunxi environment
*
* Copyright 2024 Google LLC
* Written by Simon Glass <sjg@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
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
#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};
fi;
setenv bootargs console=${console} root=${root} ${extraargs};
ext2load mmc 0 43000000 script.bin &&
ext2load mmc 0 48000000 uImage &&
bootm 48000000
#endif

View File

@@ -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 */