Browse Source

boot/beaglev-ddrlnit: new package

This commit adds a package for the DDR initialization code used on the
BeagleV platform.

The typo in the package name is upstream's typo, and we just keep it.

Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
[yann.morin.1998@free.fr:
  - upstream name is beaglev_ddrlnit, not *init (keep their typo)
  - rename package and variables accordingly
  - the referenced commit is no longer the HEAD of said branch
  - add a hash file
]
Signed-off-by: Yann E. MORIN <yann.morin.1998@free.fr>
Thomas Petazzoni 4 years ago
parent
commit
c3dd9ebae0

+ 1 - 0
DEVELOPERS

@@ -2604,6 +2604,7 @@ N:	Thomas Petazzoni <thomas.petazzoni@bootlin.com>
 F:	arch/Config.in.arm
 F:	arch/Config.in.arm
 F:	board/beaglev/
 F:	board/beaglev/
 F:	board/stmicroelectronics/stm32mp157c-dk2/
 F:	board/stmicroelectronics/stm32mp157c-dk2/
+F:	boot/beaglev-ddrlnit/
 F:	boot/boot-wrapper-aarch64/
 F:	boot/boot-wrapper-aarch64/
 F:	boot/grub2/
 F:	boot/grub2/
 F:	boot/gummiboot/
 F:	boot/gummiboot/

+ 1 - 0
boot/Config.in

@@ -6,6 +6,7 @@ source "boot/at91bootstrap3/Config.in"
 source "boot/at91dataflashboot/Config.in"
 source "boot/at91dataflashboot/Config.in"
 source "boot/arm-trusted-firmware/Config.in"
 source "boot/arm-trusted-firmware/Config.in"
 source "boot/barebox/Config.in"
 source "boot/barebox/Config.in"
+source "boot/beaglev-ddrlnit/Config.in"
 source "boot/binaries-marvell/Config.in"
 source "boot/binaries-marvell/Config.in"
 source "boot/boot-wrapper-aarch64/Config.in"
 source "boot/boot-wrapper-aarch64/Config.in"
 source "boot/grub2/Config.in"
 source "boot/grub2/Config.in"

+ 9 - 0
boot/beaglev-ddrlnit/Config.in

@@ -0,0 +1,9 @@
+config BR2_TARGET_BEAGLEV_DDRLNIT
+	bool "beaglev-ddrlnit"
+	depends on BR2_riscv
+	depends on BR2_HOSTARCH = "x86_64" # host-riscv64-elf-toolchain
+	help
+	  This package builds the DDRinit firmware used on the BeagleV
+	  platform.
+
+	  https://github.com/starfive-tech/beagle_ddrlnit

+ 2 - 0
boot/beaglev-ddrlnit/beaglev-ddrlnit.hash

@@ -0,0 +1,2 @@
+# Locally computed
+sha256  dee7f8003ee02d7799d07b598dd5823e10b42f50fae6135b2320a8d7e1fa77bf  beaglev-ddrlnit-15b80de81263996affb2a29332aa681925709983.tar.gz

+ 29 - 0
boot/beaglev-ddrlnit/beaglev-ddrlnit.mk

@@ -0,0 +1,29 @@
+################################################################################
+#
+# beaglev-ddrlnit
+#
+################################################################################
+
+# Commit on the 'starfive' branch
+BEAGLEV_DDRLNIT_VERSION = 15b80de81263996affb2a29332aa681925709983
+BEAGLEV_DDRLNIT_SITE = $(call github,starfive-tech,beagle_ddrlnit,$(BEAGLEV_DDRLNIT_VERSION))
+BEAGLEV_DDRLNIT_INSTALL_TARGET = NO
+BEAGLEV_DDRLNIT_INSTALL_IMAGES = YES
+BEAGLEV_DDRLNIT_DEPENDENCIES = host-riscv64-elf-toolchain
+# unfortunately, no real license file, but several sources files are
+# under GPL-2.0+, making the whole work GPL-2.0+
+BEAGLEV_DDRLNIT_LICENSE = GPL-2.0+
+
+define BEAGLEV_DDRLNIT_BUILD_CMDS
+	$(MAKE) -C $(@D)/build \
+		CROSSCOMPILE=$(HOST_DIR)/bin/riscv64-unknown-elf- \
+		SUFFIX=buildroot \
+		GIT_VERSION=$(BEAGLEV_DDRLNIT_VERSION)
+endef
+
+define BEAGLEV_DDRLNIT_INSTALL_IMAGES_CMDS
+	$(INSTALL) -D -m 0644 $(@D)/build/ddrinit-2133-buildroot.bin.out \
+		$(BINARIES_DIR)/ddrinit-2133-buildroot.bin.out
+endef
+
+$(eval $(generic-package))