Radix cross Linux

The main Radix cross Linux repository contains the build scripts of packages, which have the most complete and common functionality for desktop machines

383 Commits   1 Branch   1 Tag

COMPONENT_TARGETS  = $(HARDWARE_VISIONFIVE2)

NEED_ABS_PATH      = true

COMPONENT_IS_3PP   = true


include ../../../../build-system/constants.mk


SOURCE_REQUIRES    = sources/U-Boot/StarFive

REQUIRES           = boot/kernel/visionfive2/6.1.31-3.8.2

# ======= __END_OF_REQUIRES__ =======


version            = 2021.10-3.8.2
tar_xz_archive     = $(SRC_PACKAGE_PATH)/U-Boot/StarFive/u-boot/u-boot-$(version).tar.xz
SRC_ARCHIVE        = $(tar_xz_archive)
SRC_DIR            = $(TARGET_BUILD_DIR)/u-boot-$(version)
src_done           = $(TARGET_BUILD_DIR)/.source_done

opensbi_version    = 1.2-3.8.2
opensbi_archive    = $(SRC_PACKAGE_PATH)/U-Boot/StarFive/opensbi/opensbi-$(opensbi_version).tar.xz
OPENSBI_SRC_DIR    = $(TARGET_BUILD_DIR)/opensbi-$(opensbi_version)
opensbi_src_done   = $(TARGET_BUILD_DIR)/.opensbi-source-done

tools_version      = 20231107
tools_archive      = $(SRC_PACKAGE_PATH)/U-Boot/StarFive/Tools/tools-$(tools_version).tar.xz
TOOLS_SRC_DIR      = $(TARGET_BUILD_DIR)/tools-$(tools_version)
tools_src_done     = $(TARGET_BUILD_DIR)/.tools-source-done


PATCHES = PATCHES


u_boot             = $(TARGET_BUILD_DIR)/.u_boot_done
u_boot_config      = starfive_visionfive2_defconfig

spl_tool           = $(TARGET_BUILD_DIR)/.spl_tool_done
opensbi            = $(TARGET_BUILD_DIR)/.opensbi_done

u_boot_spl         = $(TARGET_BUILD_DIR)/u-boot-spl.bin
fw_payload         = $(TARGET_BUILD_DIR)/fw_payload.img

#
# Image, zImage from Linux kernel package:
#
kernel_version     = 6.1.31
linux_Image        = $(TARGET_DEST_DIR)/bootfs/Image
linux_zImage       = $(TARGET_DEST_DIR)/bootfs/vmlinuz

#
# uImage, uzImage for U-Boot (see u-boot-2021.10-3.8.2/include/configs/starfive-visionfive2.h):
#
kernel_addr        = 0x40200000
entry_point        = $(kernel_addr)
uImage             = $(TARGET_BUILD_DIR)/uImage
uzImage            = $(TARGET_BUILD_DIR)/uzImage

fdt_addr           = 0x46000000
kernel_comp_addr   = 0x5a000000
ramdisk_addr       = 0x46100000

#
# Boot Scripts:
#
boot_emmc_script    = $(TARGET_BUILD_DIR)/boot.emmc.script
boot_emmc_scr       = $(TARGET_BUILD_DIR)/boot.emmc.scr

boot_sdhc_script    = $(TARGET_BUILD_DIR)/boot.sdhc.script
boot_sdhc_scr       = $(TARGET_BUILD_DIR)/boot.sdhc.scr

boot_nvme_script    = $(TARGET_BUILD_DIR)/boot.nvme.script
boot_nvme_scr       = $(TARGET_BUILD_DIR)/boot.nvme.scr


spi_flash_image         = $(TARGET_BUILD_DIR)/$(HARDWARE).spi-flash.image
install_spi_flash_image = $(TARGET_BUILD_DIR)/.spi_flash_image_done

spi_flash_image_sum         = $(TARGET_BUILD_DIR)/$(HARDWARE).spi-flash.image.md5
install_spi_flash_image_sum = $(TARGET_BUILD_DIR)/.spi_flash_image_sum_done


ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_RISCV64_GLIBC)),)
ARCH = riscv
endif

USE_TARGET_DEST_DIR_SYSROOT = no


####### Targets

PKG_GROUP = boot


UBOOT_BIN_PKG_NAME                = u-boot
UBOOT_BIN_PKG_VERSION             = 2022.10
UBOOT_BIN_PKG_ARCH                = $(PKGARCH)
UBOOT_BIN_PKG_DISTRO_NAME         = $(DISTRO_NAME)
UBOOT_BIN_PKG_DISTRO_VERSION      = $(DISTRO_VERSION)
UBOOT_BIN_PKG_GROUP               = $(PKG_GROUP)
###                                |---handy-ruler-------------------------------|
UBOOT_BIN_PKG_SHORT_DESCRIPTION   = StarFive VisionFive U-Boot
UBOOT_BIN_PKG_URL                 = $(BUG_URL)
UBOOT_BIN_PKG_LICENSE             = custom
UBOOT_BIN_PKG_DESCRIPTION_FILE    = $(TARGET_BUILD_DIR)/$(UBOOT_BIN_PKG_NAME)-pkg-description
UBOOT_BIN_PKG_DESCRIPTION_FILE_IN = $(UBOOT_BIN_PKG_NAME)-pkg-description.in
UBOOT_BIN_PKG_INSTALL_SCRIPT      = $(UBOOT_BIN_PKG_NAME)-pkg-install.sh

UBOOT_BIN_PKG      = $(CURDIR)/$(TARGET_BUILD_DIR)/$(UBOOT_BIN_PKG_NAME)-package

build_uboot_pkg    = $(TARGET_BUILD_DIR)/.u_boot_pkg_done

pkg_basename       = $(UBOOT_BIN_PKG_NAME)-$(UBOOT_BIN_PKG_VERSION)-$(UBOOT_BIN_PKG_ARCH)-$(UBOOT_BIN_PKG_DISTRO_NAME)-$(UBOOT_BIN_PKG_DISTRO_VERSION)

pkg_archive        = $(TARGET_BUILD_DIR)/$(PKG_GROUP)/$(pkg_basename).$(pkg_arch_suffix)

pkg_certificate    = $(call cert-name,$(pkg_archive))
pkg_signature      = $(call sign-name,$(pkg_archive))
pkg_description    = $(call desc-name,$(pkg_archive))
products           = $(call pkg-files,$(pkg_archive))

BUILD_TARGETS      = $(u_boot)
BUILD_TARGETS     += $(spl_tool)
BUILD_TARGETS     += $(opensbi)
BUILD_TARGETS     += $(u_boot_spl)
BUILD_TARGETS     += $(fw_payload)
BUILD_TARGETS     += $(uImage)
BUILD_TARGETS     += $(uzImage)
BUILD_TARGETS     += $(boot_emmc_script)
BUILD_TARGETS     += $(boot_sdhc_script)
BUILD_TARGETS     += $(boot_nvme_script)
BUILD_TARGETS     += $(boot_emmc_scr)
BUILD_TARGETS     += $(boot_sdhc_scr)
BUILD_TARGETS     += $(boot_nvme_scr)
BUILD_TARGETS     += $(build_uboot_pkg)
BUILD_TARGETS     += $(install_spi_flash_image)
BUILD_TARGETS     += $(install_spi_flash_image_sum)

PRODUCT_TARGETS    = $(products)

ROOTFS_TARGETS     = $(pkg_archive)


include ../../../../build-system/core.mk


#
# U-Boot options:
#
suppress-host-warnings   = -Wno-stringop-truncation
suppress-target-warnings = -Wno-unused-variable -Wno-int-conversion -Wno-cpp -Wno-implicit-function-declaration

HOST_TOOLS_SETTINGS      = PKG_CONFIG_PATH= PYTHON3=/usr/bin/python3
HOST_TOOLS_SETTINGS     += HOSTLDFLAGS='-L/usr/lib64'
HOST_TOOLS_SETTINGS     += HOSTCFLAGS='-isystem/usr/include $(suppress-host-warnings)'

TARGET_TOOLS_SETTINGS    = KCFLAGS='$(suppress-target-warnings)'

#
# OpenSBI options:
#
U_BOOT_PATH = ../u-boot-$(version)

OPENSBI_SETTINGS  = PLATFORM=generic FW_PAYLOAD_PATH=$(U_BOOT_PATH)/u-boot.bin
OPENSBI_SETTINGS += FW_FDT_PATH=$(U_BOOT_PATH)/arch/riscv/dts/starfive_visionfive2.dtb
OPENSBI_SETTINGS += FW_TEXT_START=0x40000000


##
## armv7-m (cortex-m0) toolchain:
##
#M0_TOOLCHAIN_PATH   = /opt/toolchains/arm-NONE-eabi-newlib/1.9.8
#CORTEX_M0_SETTINGS  = M0_CROSS_COMPILE=$(M0_TOOLCHAIN_PATH)/bin/arm-none-eabi- PLAT=rk3399 bl31
#
#suppress-warnings   = -Wno-maybe-uninitialized -Wno-stringop-truncation
#
#HOST_TOOLS_SETTINGS = PYTHON3=/usr/bin/python3 HOSTLDFLAGS='-L/usr/lib64' HOSTCFLAGS='-I/usr/include $(suppress-warnings)'

device_dtb = jh7110-visionfive-v2.dtb

#
# Extra kernel boot arguments:
#
extra  = consoleblank=0
extra += no_console_suspend


####### Dependencies


$(opensbi_src_done): $(opensbi_archive)
	@echo "Expanding $(opensbi_archive)"
	@tar xJf $(opensbi_archive) -C $(TARGET_BUILD_DIR)
	@touch $@

$(tools_src_done): $(tools_archive)
	@echo "Expanding $(tools_archive)"
	@tar xJf $(tools_archive) -C $(TARGET_BUILD_DIR)
	@touch $@

$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP) $(opensbi_src_done) $(tools_src_done)
	$(UNPACK_SRC_ARCHIVE)
	$(APPLY_PATCHES)
	@( cd $(SRC_DIR)/configs ; \
	   echo '# Set BOOTDELAY options:'          >> $(u_boot_config) ; \
	   echo 'CONFIG_BOOTDELAY=3'                >> $(u_boot_config) ; \
	   echo 'CONFIG_AUTOBOOT_KEYED=y'           >> $(u_boot_config) ; \
	   echo 'CONFIG_AUTOBOOT_PROMPT="Hit SPACE in %d seconds to stop autoboot.\n"' >> $(u_boot_config) ; \
	   echo 'CONFIG_AUTOBOOT_STOP_STR=" "'      >> $(u_boot_config) ; \
	 )
	@touch $@

$(spl_tool): $(src_done)
	# ======= Build spl_tool: =======
	@$(MAKE) -C $(TOOLS_SRC_DIR)/spl_tool
	@touch $@

UMAKE := $(HOST_TOOLS_SETTINGS) $(TARGET_TOOLS_SETTINGS) $(MAKE) -C $(SRC_DIR) ARCH=$(ARCH) CROSS_COMPILE='$(CROSS_PREFIX)'

$(u_boot): $(spl_tool)
	# ======= Build U-Boot: =======
	+$(UMAKE) $(u_boot_config)
	+$(UMAKE)
	@touch $@

OMAKE := $(MAKE) -C $(OPENSBI_SRC_DIR) ARCH=$(ARCH) CROSS_COMPILE='$(CROSS_PREFIX)' $(OPENSBI_SETTINGS)

$(opensbi): $(u_boot)
	# ======= Build OpenSBI: =======
	+$(OMAKE)
	@touch $@

$(u_boot_spl): $(spl_tool) $(u_boot)
	# ======= Create U-Boot SPL: =======
	@$(TOOLS_SRC_DIR)/spl_tool/spl_tool -c -f $(SRC_DIR)/spl/u-boot-spl.bin
	@cp -a $(SRC_DIR)/spl/u-boot-spl.bin.normal.out $@

$(fw_payload): $(opensbi)
	# ======= Create fw_payload image: =======
	@( cd $(TOOLS_SRC_DIR)/uboot_its ; \
	   cp ../../opensbi-$(opensbi_version)/build/platform/generic/firmware/fw_payload.bin ./ ; \
	   ../../u-boot-$(version)/tools/mkimage -f visionfive2-uboot-fit-image.its \
                                                 -A $(ARCH) -O u-boot -T firmware visionfive2_fw_payload.img ; \
	 )
	@cp -a $(TOOLS_SRC_DIR)/uboot_its/visionfive2_fw_payload.img $@

$(uImage): $(u_boot_spl) $(fw_payload)
	$(CURDIR)/$(SRC_DIR)/tools/mkimage \
	   -A $(ARCH) -O linux -T kernel -C none -a $(kernel_addr) -e $(entry_point) \
	   -n $(kernel_version) -d $(linux_Image) $@

$(uzImage): $(u_boot_spl) $(fw_payload)
	$(CURDIR)/$(SRC_DIR)/tools/mkimage \
	   -A $(ARCH) -O linux -T kernel -C lzma -a $(kernel_addr) -e $(entry_point) \
	   -n $(kernel_version) -d $(linux_zImage) $@

#
# NOTE:
# ====
#   eMMC is always  mmc 0 in u-boot and mmcblk0 in kernel
#   sdhc is always  mmc 1 in u-boot and mmcblk1 in kernel
#   nvme is always nvme 0 in u-boot and nvme0n1 in kernel
#

$(boot_emmc_script): $(uImage) $(uzImage)
	@( echo ""                                                                > $(boot_emmc_script) && \
	   echo "mmc dev 0"                                                      >> $(boot_emmc_script) && \
	   echo "mmcinfo"                                                        >> $(boot_emmc_script) && \
	   echo "ext4load mmc 0:2 \$${kernel_comp_addr_r} /boot/uzImage"         >> $(boot_emmc_script) && \
	   echo "ext4load mmc 0:2 \$${fdt_addr_r} /boot/starfive/$(device_dtb)"  >> $(boot_emmc_script) && \
	   echo "setenv bootargs 'earlycon=sbi console=ttyS0,115200n8 console=tty1 ro root=/dev/mmcblk0p2 rootwait rootfstype=ext4 $(extra)'" >> $(boot_emmc_script) && \
	   echo "bootm \$${kernel_comp_addr_r} - \$${fdt_addr_r}"                >> $(boot_emmc_script) \
	 )

$(boot_emmc_scr): $(boot_emmc_script)
	$(CURDIR)/$(SRC_DIR)/tools/mkimage -A $(ARCH) -T script -C none -n "Boot Script" -d $< $@

$(boot_sdhc_script): $(uImage) $(uzImage)
	@( echo ""                                                                > $(boot_sdhc_script) && \
	   echo "mmc dev 1"                                                      >> $(boot_sdhc_script) && \
	   echo "mmcinfo"                                                        >> $(boot_sdhc_script) && \
	   echo "ext4load mmc 1:2 \$${kernel_comp_addr_r} /boot/uzImage"         >> $(boot_sdhc_script) && \
	   echo "ext4load mmc 1:2 \$${fdt_addr_r} /boot/starfive/$(device_dtb)"  >> $(boot_sdhc_script) && \
	   echo "setenv bootargs 'earlycon=sbi console=ttyS0,115200n8 console=tty1 ro root=/dev/mmcblk1p2 rootwait rootfstype=ext4 $(extra)'" >> $(boot_sdhc_script) && \
	   echo "bootm \$${kernel_comp_addr_r} - \$${fdt_addr_r}"                >> $(boot_sdhc_script) \
	 )

$(boot_sdhc_scr): $(boot_sdhc_script)
	$(CURDIR)/$(SRC_DIR)/tools/mkimage -A $(ARCH) -T script -C none -n "Boot Script" -d $< $@

$(boot_nvme_script): $(uImage) $(uzImage)
	@( echo ""                                                                 > $(boot_nvme_script) && \
	   echo "nvme device 0"                                                   >> $(boot_nvme_script) && \
	   echo "nvme info"                                                       >> $(boot_nvme_script) && \
	   echo "ext4load nvme 0:2 \$${kernel_comp_addr_r} /boot/uzImage"         >> $(boot_nvme_script) && \
	   echo "ext4load nvme 0:2 \$${fdt_addr_r} /boot/starfive/$(device_dtb)"  >> $(boot_nvme_script) && \
	   echo "setenv bootargs 'earlycon=sbi console=ttyS0,115200n8 console=tty1 ro root=/dev/nvme0n1p2 rootwait rootfstype=ext4 $(extra)'" >> $(boot_nvme_script) && \
	   echo "bootm \$${kernel_comp_addr_r} - \$${fdt_addr_r}"                 >> $(boot_nvme_script) \
	 )

$(boot_nvme_scr): $(boot_nvme_script)
	$(CURDIR)/$(SRC_DIR)/tools/mkimage -A $(ARCH) -T script -C none -n "Boot Script" -d $< $@

$(build_uboot_pkg): $(boot_emmc_scr) $(boot_sdhc_scr) $(boot_nvme_scr)
	@mkdir -p $(TARGET_DEST_DIR)/bootfs/u-boot
	@mkdir -p $(UBOOT_BIN_PKG)/boot/u-boot
	# ======= install U-Boot images =======
	@cp -a $(u_boot_spl) $(fw_payload)  $(UBOOT_BIN_PKG)/boot/u-boot
	# ======= install signed kernel and script images =======
	@cp -a $(uImage) $(uzImage) $(boot_emmc_scr) $(boot_sdhc_scr) $(boot_nvme_scr)  $(UBOOT_BIN_PKG)/boot
	@( cd $(UBOOT_BIN_PKG)/boot ; \
	   ln -sf boot.sdhc.scr boot.scr ; \
	 )
	# ======= copy U-Boot images and binaries into devenv =======
	@cp -a $(uImage) $(uzImage) $(boot_emmc_scr) $(boot_sdhc_scr) $(boot_nvme_scr)  $(TARGET_DEST_DIR)/bootfs
	@cp -a $(u_boot_spl) $(fw_payload)  $(TARGET_DEST_DIR)/bootfs/u-boot
	# ======= install Documentation =======
	@mkdir -p $(UBOOT_BIN_PKG)/usr/doc/u-boot-$(UBOOT_BIN_PKG_VERSION)
	@cp -a $(SRC_DIR)/Licenses $(SRC_DIR)/MAINTAINERS $(SRC_DIR)/README \
	       $(UBOOT_BIN_PKG)/usr/doc/u-boot-$(UBOOT_BIN_PKG_VERSION)
	@touch $@

#
# In jh7110-visionfive-v2.dtsi defined:
#
#    Offset |    Length | Size  | Part Name | Description
# ----------+-----------+-------+-----------+-----------------
#       0x0     0x40000    256k   spl         SPL
#   0xf0000     0x10000     64k   uboot-env   U-Boot environment variables
#  0x100000    0x300000   3072k   uboot       fw_payload.img (OpenSBI + U-Boot)
#  0xf00000    0x100000   1024k   data        Reseved
#

$(spi_flash_image): $(build_uboot_pkg)
	# ======= Create SPI flash image: =======
	@$(DD) if=/dev/zero bs=1k count=16384 | tr '\000' '\377' > $@
	# ------- Clean U-Boot environment: -------
	@$(DD) if=/dev/zero of=$@ bs=1k count=64 seek=960 conv=notrunc
	# ------- Write u-boot-spl and fw_payload into flash image: -------
	@$(DD) if=$(u_boot_spl) of=$@ bs=1k           conv=notrunc
	@$(DD) if=$(fw_payload) of=$@ bs=1k seek=1024 conv=notrunc
	@cp -a $(spi_flash_image) $(UBOOT_BIN_PKG)/boot/u-boot/spi-flash.image
	@( cd $(UBOOT_BIN_PKG)/boot/u-boot/ ; \
	   md5sum -b spi-flash.image > spi-flash.image.md5 ; \
	 )
	@touch $@

$(install_spi_flash_image): $(spi_flash_image)
	@$(BUILDSYSTEM)/install_targets         \
	   --destination=$(PRODUCTS_DEST_DIR)   \
	   --toolchain=$(TOOLCHAIN)             \
	   --hardware=$(HARDWARE)               \
	   --flavour=$(FLAVOUR)                 \
	   $^
	@touch $@

$(spi_flash_image_sum): $(spi_flash_image)
	@( cd $(TARGET_BUILD_DIR) ; \
	   md5sum -b $(HARDWARE).spi-flash.image > $(HARDWARE).spi-flash.image.md5 ; \
	 )
	@touch $@

$(install_spi_flash_image_sum): $(spi_flash_image_sum)
	@$(BUILDSYSTEM)/install_targets         \
	   --destination=$(PRODUCTS_DEST_DIR)   \
	   --toolchain=$(TOOLCHAIN)             \
	   --hardware=$(HARDWARE)               \
	   --flavour=$(FLAVOUR)                 \
	   $^
	@touch $@

$(UBOOT_BIN_PKG_DESCRIPTION_FILE): $(UBOOT_BIN_PKG_DESCRIPTION_FILE_IN)
	@cat $< | $(SED) -e "s/@VERSION@/$(UBOOT_BIN_PKG_VERSION)/g" | \
	          $(SED) -e "s/@HARDWARE_SPEC@/$(HW_SPEC)/g"> $@

$(pkg_certificate) : $(pkg_archive) ;
$(pkg_signature)   : $(pkg_archive) ;
$(pkg_description) : $(pkg_archive) ;

$(pkg_archive): $(install_boot_records) $(UBOOT_BIN_PKG_DESCRIPTION_FILE) $(UBOOT_BIN_PKG_INSTALL_SCRIPT)
	@cp $(UBOOT_BIN_PKG_DESCRIPTION_FILE) $(UBOOT_BIN_PKG)/.DESCRIPTION
	@cp $(UBOOT_BIN_PKG_INSTALL_SCRIPT) $(UBOOT_BIN_PKG)/.INSTALL
	@chmod a+x $(UBOOT_BIN_PKG)/.INSTALL
	@$(BUILD_PKG_REQUIRES) $(UBOOT_BIN_PKG)/.REQUIRES
	@echo "pkgname=$(UBOOT_BIN_PKG_NAME)"                            >  $(UBOOT_BIN_PKG)/.PKGINFO ; \
	 echo "pkgver=$(UBOOT_BIN_PKG_VERSION)"                          >> $(UBOOT_BIN_PKG)/.PKGINFO ; \
	 echo "arch=$(UBOOT_BIN_PKG_ARCH)"                               >> $(UBOOT_BIN_PKG)/.PKGINFO ; \
	 echo "distroname=$(UBOOT_BIN_PKG_DISTRO_NAME)"                  >> $(UBOOT_BIN_PKG)/.PKGINFO ; \
	 echo "distrover=$(UBOOT_BIN_PKG_DISTRO_VERSION)"                >> $(UBOOT_BIN_PKG)/.PKGINFO ; \
	 echo "group=$(UBOOT_BIN_PKG_GROUP)"                             >> $(UBOOT_BIN_PKG)/.PKGINFO ; \
	 echo "short_description=\"$(UBOOT_BIN_PKG_SHORT_DESCRIPTION)\"" >> $(UBOOT_BIN_PKG)/.PKGINFO ; \
	 echo "url=$(UBOOT_BIN_PKG_URL)"                                 >> $(UBOOT_BIN_PKG)/.PKGINFO ; \
	 echo "license=$(UBOOT_BIN_PKG_LICENSE)"                         >> $(UBOOT_BIN_PKG)/.PKGINFO
	@$(PSEUDO) sh -c "cd $(UBOOT_BIN_PKG) && \
	                  chown -R root:root . && \
	                  $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."