Add Radxa E24C; vendor kernel and vendor u-boot only for now

- vendor stuff boots, mostly works
- edge started, using Kwiboo's tree, but not enabled
  - u-boot mostly works, but needs rework against v2026.01
  - revisit after 6.19
    - rk3528 pcie already landed
  - the RTL8367RB switch vs the GMAC might need more work
This commit is contained in:
Ricardo Pardini 2025-12-07 15:43:02 +01:00 committed by Rolf Leggewie
parent 7460168a98
commit 45753ae6d9

View File

@ -0,0 +1,112 @@
# Rockchip RK3528 SoC GMAC1 RTL8367RB NVMe
BOARD_NAME="Radxa E24C"
BOARDFAMILY="rockchip-rk3588"
BOARD_MAINTAINER="rpardini"
BOOTCONFIG="radxa-e24c-spi-rk3528_defconfig" # vendor uboot defconfig; Radxa's name
KERNEL_TARGET="vendor" # edge (6.18) is not ready yet: ,edge
BOOT_FDT_FILE="rockchip/rk3528-radxa-e24c-spi.dtb" # for non-eMMC boards, with SPI NOR: "SF: Detected mx25u12835f with page size 256 Bytes, erase size 4 KiB, total 16 MiB"
#BOOT_FDT_FILE="rockchip/rk3528-radxa-e24c.dtb" # for eMMC boards
BOOT_SCENARIO="spl-blobs"
BOOT_SOC="rk3528"
IMAGE_PARTITION_TABLE="gpt"
# Schematics: https://dl.radxa.com/e/e24c/docs/radxa_e24c_v1200_schematic.pdf
# Mainline U-Boot, only for non-vendor BRANCH
function post_family_config__e24c_use_mainline_uboot() {
if [[ "${BRANCH}" == "vendor" ]]; then
return 0
fi
declare -g BOOTCONFIG="radxa-e24c-rk3528_defconfig" # mainline uboot defconfig; Kwiboo's name
display_alert "$BOARD" "Using Kwiboo's U-Boot for $BOARD / $BRANCH" "info"
declare -g BOOTDELAY=1
# This is Kwiboo's work branch, based on 2025.07 at ebd699c97de0576d9f8703b8afc5e71f98ff18d2
declare -g BOOTSOURCE="https://github.com/Kwiboo/u-boot-rockchip.git"
declare -g BOOTBRANCH="branch:rk3528" # at commit:ebd699c97de0576d9f8703b8afc5e71f98ff18d2
declare -g BOOTPATCHDIR="kwiboo-rk3528-no-patches"
declare -g BOOTDIR="u-boot-${BOARD}"
declare -g UBOOT_TARGET_MAP="BL31=${RKBIN_DIR}/${BL31_BLOB} ROCKCHIP_TPL=${RKBIN_DIR}/${DDR_BLOB};;u-boot-rockchip.bin u-boot-rockchip-spi.bin"
unset uboot_custom_postprocess write_uboot_platform write_uboot_platform_mtd # disable stuff from rockchip64_common; we're using binman here which does all the work already
# Just use the binman-provided u-boot-rockchip.bin, which is ready-to-go
function write_uboot_platform() {
dd "if=$1/u-boot-rockchip.bin" "of=$2" bs=32k seek=1 conv=notrunc status=none
}
function write_uboot_platform_mtd() {
flashcp -v -p "$1/u-boot-rockchip-spi.bin" /dev/mtd0
}
}
# Mainline U-Boot, only for non-vendor BRANCH
# "rockchip-common: boot SD card first, then NVMe, then mmc"
# On radxa-e24c, mmc0 is the eMMC, mmc1 is the SD card slot
function pre_config_uboot_target__cm3588_patch_rockchip_common_boot_order() {
if [[ "${BRANCH}" == "vendor" ]]; then
return 0
fi
declare -a rockchip_uboot_targets=("mmc1" "nvme" "mmc0" "scsi" "usb" "pxe" "dhcp" "spi") # for future make-this-generic delight
display_alert "u-boot for ${BOARD}/${BRANCH}" "u-boot: adjust boot order to '${rockchip_uboot_targets[*]}'" "info"
sed -i -e "s/#define BOOT_TARGETS.*/#define BOOT_TARGETS \"${rockchip_uboot_targets[*]}\"/" include/configs/rockchip-common.h
regular_git diff -u include/configs/rockchip-common.h || true
}
# Mainline U-Boot, only for non-vendor BRANCH
function post_config_uboot_target__extra_configs_for_e24c_uboot() {
if [[ "${BRANCH}" == "vendor" ]]; then
return 0
fi
display_alert "u-boot for ${BOARD}/${BRANCH}" "u-boot: enable preboot & flash user LED in preboot" "info"
run_host_command_logged scripts/config --enable CONFIG_USE_PREBOOT
run_host_command_logged scripts/config --set-str CONFIG_PREBOOT "'led SYS on; sleep 0.1; led SYS off; led LAN1 on; sleep 0.1; led LAN1 off; led LAN2 on; sleep 0.1; led LAN2 off; led LAN3 on; sleep 0.1; led LAN3 off; '" # double quotes required due to run_host_command_logged's quirks
display_alert "u-boot for ${BOARD}/${BRANCH}" "u-boot: enable EFI debugging commands" "info"
run_host_command_logged scripts/config --enable CMD_EFIDEBUG
run_host_command_logged scripts/config --enable CMD_NVEDIT_EFI
display_alert "u-boot for ${BOARD}/${BRANCH}" "u-boot: enable more filesystems support" "info"
run_host_command_logged scripts/config --enable CONFIG_CMD_BTRFS
display_alert "u-boot for ${BOARD}/${BRANCH}" "u-boot: enable more compression support" "info"
run_host_command_logged scripts/config --enable CONFIG_LZO
run_host_command_logged scripts/config --enable CONFIG_BZIP2
run_host_command_logged scripts/config --enable CONFIG_ZSTD
display_alert "u-boot for ${BOARD}/${BRANCH}" "u-boot: enable gpio LED support" "info"
run_host_command_logged scripts/config --enable CONFIG_LED
run_host_command_logged scripts/config --enable CONFIG_LED_GPIO
display_alert "u-boot for ${BOARD}/${BRANCH}" "u-boot: enable networking cmds" "info"
run_host_command_logged scripts/config --enable CONFIG_CMD_NFS
run_host_command_logged scripts/config --enable CONFIG_CMD_WGET
run_host_command_logged scripts/config --enable CONFIG_CMD_DNS
run_host_command_logged scripts/config --enable CONFIG_PROT_TCP
run_host_command_logged scripts/config --enable CONFIG_PROT_TCP_SACK
# UMS, RockUSB, gadget stuff
display_alert "u-boot for ${BOARD}/${BRANCH}" "u-boot: enable UMS/RockUSB gadget" "info"
declare -a enable_configs=("CONFIG_CMD_USB_MASS_STORAGE" "CONFIG_USB_GADGET" "USB_GADGET_DOWNLOAD" "CONFIG_USB_FUNCTION_ROCKUSB" "CONFIG_USB_FUNCTION_ACM" "CONFIG_CMD_ROCKUSB" "CONFIG_CMD_USB_MASS_STORAGE")
for config in "${enable_configs[@]}"; do
run_host_command_logged scripts/config --enable "${config}"
done
# Auto-enabled by the above, force off...
run_host_command_logged scripts/config --disable USB_FUNCTION_FASTBOOT
return 0
}
# When not using vendor, set use ttyS0 as default console in bootscript
function post_family_config__e24c_set_serial_console_for_edge() {
if [[ "${BRANCH}" == vendor ]]; then
display_alert "$BOARD" "Using vendor kernel; keeping default console settings" "info"
else
display_alert "$BOARD" "Setting default console to serial ttyS0 for mainline kernel bootscript" "info"
declare -g BOOTSCRIPT="boot-rockchip64-ttyS0.cmd:boot.cmd"
declare -g SERIALCON="ttyS0"
fi
}