Files
fml13v01/Makefile
2025-01-08 16:18:16 +08:00

549 lines
20 KiB
Makefile

ISA ?= rv64imafdc_zicsr_zifencei_zba_zbb
ABI ?= lp64d
#TARGET_BOARD is JH7110 or NULL
SOC := JH7110
BOARD_FLAGS :=
HWBOARD ?= visionfive2
HWBOARD_FLAG ?= HWBOARD_VISIONFIVE2
srcdir := $(dir $(realpath $(lastword $(MAKEFILE_LIST))))
srcdir := $(srcdir:/=)
confdir := $(srcdir)/conf
wrkdir := $(CURDIR)/work
buildroot_srcdir := $(srcdir)/buildroot
buildroot_initramfs_wrkdir := $(wrkdir)/buildroot_initramfs
# TODO: make RISCV be able to be set to alternate toolchain path
RISCV ?= $(buildroot_initramfs_wrkdir)/host
RVPATH := $(RISCV)/bin:$(PATH)
target := riscv64-buildroot-linux-gnu
CROSS_COMPILE := $(RISCV)/bin/$(target)-
buildroot_initramfs_tar := $(buildroot_initramfs_wrkdir)/images/rootfs.tar
buildroot_initramfs_config := $(confdir)/buildroot_initramfs_config
buildroot_initramfs_sysroot_stamp := $(wrkdir)/.buildroot_initramfs_sysroot
buildroot_initramfs_sysroot := $(wrkdir)/buildroot_initramfs_sysroot
buildroot_rootfs_wrkdir := $(wrkdir)/buildroot_rootfs
buildroot_rootfs_ext := $(buildroot_rootfs_wrkdir)/images/rootfs.ext4
buildroot_rootfs_config := $(confdir)/buildroot_rootfs_config
linux_srcdir := $(srcdir)/linux
linux_wrkdir := $(wrkdir)/linux
ifeq ($(HWBOARD), evb)
linux_defconfig := $(linux_srcdir)/arch/riscv/configs/starfive_jh7110_defconfig
else
linux_defconfig := $(linux_srcdir)/arch/riscv/configs/fml13v01_defconfig
endif
vmlinux := $(linux_wrkdir)/vmlinux
vmlinux_stripped := $(linux_wrkdir)/vmlinux-stripped
vmlinux_bin := $(wrkdir)/vmlinux.bin
module_install_path:=$(wrkdir)/module_install_path
perf_tool_srcdir := $(linux_srcdir)/tools/perf
perf_tool_wrkdir := $(linux_wrkdir)/tools/perf
its_file=$(confdir)/$(HWBOARD)-fit-image.its
uboot_its_file=$(confdir)/$(HWBOARD)-uboot-fit-image.its
vfat_image := $(wrkdir)/starfive-$(HWBOARD)-vfat.part
#ext_image := $(wrkdir) # TODO
initramfs := $(wrkdir)/initramfs.cpio.gz
sbi_srcdir := $(srcdir)/opensbi
sbi_wrkdir := $(wrkdir)/opensbi
sbi_bin := $(wrkdir)/opensbi/platform/generic/firmware/fw_payload.bin
fit := $(wrkdir)/image.fit
uboot_fit := $(wrkdir)/$(HWBOARD)_fw_payload.img
fesvr_srcdir := $(srcdir)/riscv-fesvr
fesvr_wrkdir := $(wrkdir)/riscv-fesvr
libfesvr := $(fesvr_wrkdir)/prefix/lib/libfesvr.so
spike_srcdir := $(srcdir)/riscv-isa-sim
spike_wrkdir := $(wrkdir)/riscv-isa-sim
spike := $(spike_wrkdir)/prefix/bin/spike
qemu_srcdir := $(srcdir)/riscv-qemu
qemu_wrkdir := $(wrkdir)/riscv-qemu
qemu := $(qemu_wrkdir)/prefix/bin/qemu-system-riscv64
uboot_srcdir := $(srcdir)/u-boot
uboot_wrkdir := $(wrkdir)/u-boot
uboot_dtb_file := $(wrkdir)/u-boot/arch/riscv/dts/starfive_$(HWBOARD).dtb
uboot := $(uboot_wrkdir)/u-boot.bin
spl_tool_srcdir := $(srcdir)/soft_3rdpart/spl_tool
spl_tool_wrkdir := $(wrkdir)/spl_tool
spl_bin_normal_out := u-boot-spl.bin.normal.out
uboot_config := starfive_$(HWBOARD)_defconfig
uboot_defconfig := $(uboot_srcdir)/configs/$(uboot_config)
rootfs := $(wrkdir)/rootfs.bin
target_gcc := $(CROSS_COMPILE)gcc
version := $(wrkdir)/version
.PHONY: all check_arg
all: check_arg $(fit) $(vfat_image) $(uboot_fit) $(spl_bin_normal_out)
@echo
@echo "This image has been generated for an ISA of $(ISA) and an ABI of $(ABI)"
@echo "Find the image in work/image.fit, which should be copied to an MSDOS boot partition 1"
@echo
@echo "To completely erase, reformat, and program a disk sdX, run:"
@echo " make DISK=/dev/sdX format-boot-loader"
@echo " ... you will need gdisk and e2fsprogs installed"
@echo " Please note this will not currently format the SDcard ext4 partition"
@echo " This can be done manually if needed"
@echo
check_arg:
ifeq ( , $(filter $(HWBOARD), visionfive2 evb fpga))
$(error board $(HWBOARD) is not supported, BOARD=[visionfive2 | evb | fpga(deflault)])
endif
# TODO: depracated for now
#ifneq ($(RISCV),$(buildroot_initramfs_wrkdir)/host)
#$(target_gcc):
# $(error The RISCV environment variable was set, but is not pointing at a toolchain install tree)
#else
#$(target_gcc): $(buildroot_initramfs_tar)
#endif
.PHONY: visionfive2 evb fpga
visionfive2: HWBOARD := visionfive2
visionfive2: HWBOARD_FLAG := HWBOARD_VISIONFIVE2
visionfive2: uboot_config := starfive_$(HWBOARD)_defconfig
visionfive2: uboot_dtb_file := $(wrkdir)/u-boot/arch/riscv/dts/starfive_$(HWBOARD).dtb
visionfive2: linux_defconfig := $(linux_srcdir)/arch/riscv/configs/starfive_visionfive2_defconfig
visionfive2: uboot_fit := $(wrkdir)/$(HWBOARD)_fw_payload.img
visionfive2: vfat_image := $(wrkdir)/starfive-$(HWBOARD)-vfat.part
visionfive2: its_file=$(confdir)/$(HWBOARD)-fit-image.its
visionfive2: uboot_its_file=$(confdir)/$(HWBOARD)-uboot-fit-image.its
visionfive2: all
evb: HWBOARD := evb
evb: HWBOARD_FLAG := HWBOARD_EVB
evb: uboot_config := starfive_$(HWBOARD)_defconfig
evb: uboot_dtb_file := $(wrkdir)/u-boot/arch/riscv/dts/starfive_$(HWBOARD).dtb
evb: linux_defconfig := $(linux_srcdir)/arch/riscv/configs/starfive_jh7110_defconfig
evb: uboot_fit := $(wrkdir)/$(HWBOARD)_fw_payload.img
evb: vfat_image := $(wrkdir)/starfive-$(HWBOARD)-vfat.part
evb: its_file=$(confdir)/$(HWBOARD)-fit-image.its
evb: uboot_its_file=$(confdir)/$(HWBOARD)-uboot-fit-image.its
evb: all
fpga: HWBOARD := fpga
fpga: all
fpga: HWBOARD_FLAG := HWBOARD_FPGA
$(version):
cd $(linux_srcdir) && \
sh $(confdir)/version > $(version)
chmod 777 $(version)
$(buildroot_initramfs_wrkdir)/.config: $(buildroot_srcdir)
# rm -rf $(dir $@)
mkdir -p $(dir $@)
cp $(buildroot_initramfs_config) $@
$(MAKE) -C $< RISCV=$(RISCV) O=$(buildroot_initramfs_wrkdir) olddefconfig
# buildroot_initramfs provides gcc
$(buildroot_initramfs_tar): $(buildroot_srcdir) $(buildroot_initramfs_wrkdir)/.config $(buildroot_initramfs_config)
$(MAKE) -C $< RISCV=$(RISCV) O=$(buildroot_initramfs_wrkdir)
.PHONY: buildroot_initramfs-menuconfig
buildroot_initramfs-menuconfig: $(buildroot_initramfs_wrkdir)/.config $(buildroot_srcdir)
$(MAKE) -C $(dir $<) O=$(buildroot_initramfs_wrkdir) menuconfig
$(MAKE) -C $(dir $<) O=$(buildroot_initramfs_wrkdir) savedefconfig
cp $(dir $<)defconfig $(buildroot_initramfs_config)
# use buildroot_initramfs toolchain
# TODO: fix path and conf/buildroot_rootfs_config
$(buildroot_rootfs_wrkdir)/.config: $(buildroot_srcdir) $(buildroot_initramfs_tar)
# rm -rf $(dir $@)
mkdir -p $(dir $@)
cp $(buildroot_rootfs_config) $@
$(MAKE) -C $< RISCV=$(RISCV) PATH=$(RVPATH) O=$(buildroot_rootfs_wrkdir) olddefconfig
$(buildroot_rootfs_ext): $(buildroot_srcdir) $(buildroot_rootfs_wrkdir)/.config $(target_gcc) $(buildroot_rootfs_config) $(version)
mkdir -p $(buildroot_rootfs_wrkdir)/target/lib
cp -r $(module_install_path)/lib/modules $(buildroot_rootfs_wrkdir)/target/lib/
mkdir -p $(buildroot_rootfs_wrkdir)/target/usr/bin
cp $(perf_tool_wrkdir)/perf $(buildroot_rootfs_wrkdir)/target/usr/bin/
cp $(version) $(buildroot_rootfs_wrkdir)/target/usr/bin/version
$(MAKE) -C $< RISCV=$(RISCV) PATH=$(RVPATH) O=$(buildroot_rootfs_wrkdir)
.PHONY: buildroot_rootfs
buildroot_rootfs: $(buildroot_rootfs_ext)
.PHONY: buildroot_rootfs-menuconfig
buildroot_rootfs-menuconfig: $(buildroot_rootfs_wrkdir)/.config $(buildroot_srcdir)
$(MAKE) -C $(dir $<) O=$(buildroot_rootfs_wrkdir) menuconfig
$(MAKE) -C $(dir $<) O=$(buildroot_rootfs_wrkdir) savedefconfig
cp $(dir $<)defconfig conf/buildroot_rootfs_config
$(buildroot_initramfs_sysroot_stamp): $(buildroot_initramfs_tar)
mkdir -p $(buildroot_initramfs_sysroot)
tar -xpf $< -C $(buildroot_initramfs_sysroot) --exclude ./dev --exclude ./usr/share/locale
touch $@
$(linux_wrkdir)/.config: $(linux_defconfig) $(linux_srcdir)
mkdir -p $(dir $@)
cp -p $< $@
$(MAKE) -C $(linux_srcdir) O=$(linux_wrkdir) CROSS_COMPILE=$(CROSS_COMPILE) ARCH=riscv olddefconfig
$(uboot_wrkdir)/.config: $(uboot_defconfig)
mkdir -p $(dir $@)
cp -p $< $@
$(MAKE) -C $(uboot_srcdir) O=$(uboot_wrkdir) CROSS_COMPILE=$(CROSS_COMPILE) ARCH=riscv olddefconfig
$(vmlinux): $(linux_srcdir) $(linux_wrkdir)/.config $(target_gcc)
$(MAKE) -C $< O=$(linux_wrkdir) \
ARCH=riscv \
CROSS_COMPILE=$(CROSS_COMPILE) \
PATH=$(RVPATH) \
vmlinux \
all \
modules
$(MAKE) -C $< O=$(linux_wrkdir) \
ARCH=riscv \
CROSS_COMPILE=$(CROSS_COMPILE) \
PATH=$(RVPATH) \
INSTALL_MOD_PATH=$(module_install_path) \
modules_install
vpudriver-build: $(vmlinux)
$(MAKE) -C $(buildroot_initramfs_wrkdir) O=$(buildroot_initramfs_wrkdir) \
INSTALL_MOD_PATH=$(module_install_path) wave511driver
$(MAKE) -C $(buildroot_initramfs_wrkdir) O=$(buildroot_initramfs_wrkdir) \
INSTALL_MOD_PATH=$(module_install_path) wave420ldriver
$(MAKE) -C $(buildroot_initramfs_wrkdir) O=$(buildroot_initramfs_wrkdir) \
INSTALL_MOD_PATH=$(module_install_path) codaj12driver
$(perf_tool_wrkdir)/perf: $(linux_srcdir) $(vmlinux)
mkdir -p $(perf_tool_wrkdir)
$(MAKE) -C $(perf_tool_srcdir) O=$(perf_tool_wrkdir)/ \
ARCH=riscv \
CROSS_COMPILE=$(CROSS_COMPILE) \
WERROR=0 NO_GTK2=1 NO_LIBPERL=1 \
NO_LIBBIONIC=1 NO_LIBELF=1 NO_LIBTRACEEVENT=1
.PHONY: perf
perf: $(perf_tool_wrkdir)/perf
.PHONY: initrd
initrd: $(initramfs)
$(initramfs).d: $(buildroot_initramfs_sysroot)
$(linux_srcdir)/usr/gen_initramfs_list.sh -l $(confdir)/initramfs.txt $(buildroot_initramfs_sysroot) > $@
$(initramfs): $(buildroot_initramfs_sysroot) $(vmlinux) vpudriver-build $(version) $(perf_tool_wrkdir)/perf
cp -r $(module_install_path)/lib/modules $(buildroot_initramfs_sysroot)/lib/
cp $(perf_tool_wrkdir)/perf $(buildroot_initramfs_sysroot)/usr/bin/
cp $(version) $(buildroot_initramfs_sysroot)/usr/bin/version && \
cd $(linux_wrkdir) && \
$(linux_srcdir)/usr/gen_initramfs_list.sh \
-o $@ -u $(shell id -u) -g $(shell id -g) \
$(confdir)/initramfs.txt \
$(buildroot_initramfs_sysroot)
$(vmlinux_stripped): $(vmlinux)
PATH=$(RVPATH) $(target)-strip -o $@ $<
$(vmlinux_bin): $(vmlinux)
PATH=$(RVPATH) $(target)-objcopy -O binary $< $@
.PHONY: linux-menuconfig
linux-menuconfig: $(linux_wrkdir)/.config
$(MAKE) -C $(linux_srcdir) O=$(dir $<) ARCH=riscv CROSS_COMPILE=$(CROSS_COMPILE) menuconfig
$(MAKE) -C $(linux_srcdir) O=$(dir $<) ARCH=riscv CROSS_COMPILE=$(CROSS_COMPILE) savedefconfig
cp $(dir $<)defconfig $(linux_defconfig)
# Note: opensbi generic platform default FW_TEXT_START is 0x80000000
# For JH7110, need to specify the FW_TEXT_START to 0x40000000
# Otherwise, the fw_payload.bin downloading via jtag will not run.
# not affect the evb_fw_payload.img for its file has FW_TEXT_START
$(sbi_bin): $(uboot) $(vmlinux)
rm -rf $(sbi_wrkdir)
mkdir -p $(sbi_wrkdir)
cd $(sbi_wrkdir) && O=$(sbi_wrkdir) CFLAGS="-mabi=$(ABI) -march=$(ISA)" ${MAKE} -C $(sbi_srcdir) CROSS_COMPILE=$(CROSS_COMPILE) \
PLATFORM=generic FW_PAYLOAD_PATH=$(uboot) FW_FDT_PATH=$(uboot_dtb_file) FW_TEXT_START=0x40000000
$(fit): $(sbi_bin) $(vmlinux_bin) $(uboot) $(its_file) ${initramfs}
$(uboot_wrkdir)/tools/mkimage -f $(its_file) -A riscv -O linux -T flat_dt $@
@if [ -f fsz.sh ]; then ./fsz.sh $(sbi_bin); fi
$(libfesvr): $(fesvr_srcdir)
rm -rf $(fesvr_wrkdir)
mkdir -p $(fesvr_wrkdir)
mkdir -p $(dir $@)
cd $(fesvr_wrkdir) && $</configure \
--prefix=$(dir $(abspath $(dir $@)))
$(MAKE) -C $(fesvr_wrkdir)
$(MAKE) -C $(fesvr_wrkdir) install
touch -c $@
$(spike): $(spike_srcdir) $(libfesvr)
rm -rf $(spike_wrkdir)
mkdir -p $(spike_wrkdir)
mkdir -p $(dir $@)
cd $(spike_wrkdir) && PATH=$(RVPATH) $</configure \
--prefix=$(dir $(abspath $(dir $@))) \
--with-fesvr=$(dir $(abspath $(dir $(libfesvr))))
$(MAKE) PATH=$(RVPATH) -C $(spike_wrkdir)
$(MAKE) -C $(spike_wrkdir) install
touch -c $@
$(qemu): $(qemu_srcdir)
rm -rf $(qemu_wrkdir)
mkdir -p $(qemu_wrkdir)
mkdir -p $(dir $@)
which pkg-config
# pkg-config from buildroot blows up qemu configure
cd $(qemu_wrkdir) && $</configure \
--prefix=$(dir $(abspath $(dir $@))) \
--target-list=riscv64-softmmu
$(MAKE) -C $(qemu_wrkdir)
$(MAKE) -C $(qemu_wrkdir) install
touch -c $@
.PHONY: uboot-menuconfig
uboot-menuconfig: $(uboot_wrkdir)/.config
$(MAKE) -C $(uboot_srcdir) O=$(dir $<) CROSS_COMPILE=$(CROSS_COMPILE) ARCH=riscv menuconfig
$(MAKE) -C $(uboot_srcdir) O=$(dir $<) CROSS_COMPILE=$(CROSS_COMPILE) ARCH=riscv savedefconfig
cp $(dir $<)defconfig $(uboot_defconfig)
$(uboot): $(uboot_srcdir) $(target_gcc)
rm -rf $(uboot_wrkdir)
mkdir -p $(uboot_wrkdir)
mkdir -p $(dir $@)
$(MAKE) -C $(uboot_srcdir) O=$(uboot_wrkdir) $(uboot_config)
$(MAKE) -C $(uboot_srcdir) O=$(uboot_wrkdir) CROSS_COMPILE=$(CROSS_COMPILE)
$(spl_tool_wrkdir)/spl_tool: $(spl_tool_srcdir)
rm -rf $(spl_tool_wrkdir)
cp -ar $< $(spl_tool_wrkdir)
$(MAKE) -C $(spl_tool_wrkdir)
.PHONY: spl_tool
spl_tool: $(spl_tool_wrkdir)/spl_tool
$(spl_bin_normal_out): $(uboot) $(spl_tool_wrkdir)/spl_tool
$(spl_tool_wrkdir)/spl_tool -c -f $(uboot_wrkdir)/spl/u-boot-spl.bin
cp $(uboot_wrkdir)/spl/$(spl_bin_normal_out) $(wrkdir)
$(uboot_fit): $(sbi_bin) $(uboot_its_file) $(uboot)
$(uboot_wrkdir)/tools/mkimage -f $(uboot_its_file) -A riscv -O u-boot -T firmware $(uboot_fit)
$(rootfs): $(buildroot_rootfs_ext)
cp $< $@
$(buildroot_initramfs_sysroot): $(buildroot_initramfs_sysroot_stamp)
.PHONY: buildroot_initramfs_sysroot vmlinux fit uboot_fit
buildroot_initramfs_sysroot: $(buildroot_initramfs_sysroot)
vmlinux: $(vmlinux)
fit: $(fit)
uboot_fit: $(uboot_fit)
.PHONY: clean
clean:
rm -rf work/u-boot
rm -rf work/opensbi
rm -f work/*-vfat.part
rm -f work/image.fit
rm -f work/*_fw_payload.img
rm -f work/initramfs.cpio.gz
rm -f work/linux/vmlinux*
rm -f work/u-boot-spl.bin.normal.out
rm -f work/version
rm -rf $(spl_tool_wrkdir)
rm -rf $(perf_tool_wrkdir)
.PHONY: distclean
distclean:
rm -rf -- $(wrkdir) $(toolchain_dest)
.PHONY: sim
sim: $(spike) $(sbi_bin)
$(spike) --isa=$(ISA) -p4 $(sbi_bin)
.PHONY: qemu
qemu: $(qemu) $(sbi_bin) $(vmlinux) $(initramfs)
$(qemu) -nographic -machine virt -bios $(sbi_bin) -kernel $(vmlinux) -initrd $(initramfs) \
-netdev user,id=net0 -device virtio-net-device,netdev=net0
.PHONY: qemu-rootfs
qemu-rootfs: $(qemu) $(sbi_bin) $(vmlinux) $(initramfs) $(rootfs)
$(qemu) -nographic -machine virt -bios $(sbi_bin) -kernel $(vmlinux) -initrd $(initramfs) \
-drive file=$(rootfs),format=raw,id=hd0 -device virtio-blk-device,drive=hd0 \
-netdev user,id=net0 -device virtio-net-device,netdev=net0
.PHONY: uboot
uboot: $(uboot)
# Relevant partition type codes with GUID
SPL = 2E54B353-1271-4842-806F-E436D6AF6985
VFAT = EBD0A0A2-B9E5-4433-87C0-68B6B72699C7
LINUX = 0FC63DAF-8483-4772-8E79-3D69D8477DE4
UBOOT = 5B193300-FC78-40CD-8002-E86C45580B47
UBOOTENV = a09354ac-cd63-11e8-9aff-70b3d592f0fa
UBOOTDTB = 070dd1a8-cd64-11e8-aa3d-70b3d592f0fa
UBOOTFIT = 04ffcafa-cd65-11e8-b974-70b3d592f0fa
# Note: The following are the sector number used to partition
# The default sector size is 512 Bytes
# The partition start should be align on 2048-sector boundaries
# expand the vfat size to 300+M for the vpu/jpu or other debug
SPL_START = 4096
SPL_END = 8191
UBOOT_START = 8192
UBOOT_END = 16383
UBOOT_SIZE = $(shell expr $(UBOOT_END) - $(UBOOT_START) + 1)
VFAT_START = 16384
VFAT_END = 614399
VFAT_SIZE = $(shell expr $(VFAT_END) - $(VFAT_START) + 1)
ROOT_START = 614400
$(vfat_image): $(fit) $(confdir)/jh7110_uEnv.txt $(confdir)/vf2_uEnv.txt $(confdir)/vf2_nvme_uEnv.txt
@if [ `du --apparent-size --block-size=512 $(uboot) | cut -f 1` -ge $(UBOOT_SIZE) ]; then \
echo "Uboot is too large for partition!!\nReduce uboot or increase partition size"; \
exit 1; fi
dd if=/dev/zero of=$(vfat_image) bs=512 count=$(VFAT_SIZE)
/sbin/mkfs.vfat $(vfat_image)
PATH=$(RVPATH) MTOOLS_SKIP_CHECK=1 mcopy -i $(vfat_image) $(fit) ::starfiveu.fit
PATH=$(RVPATH) MTOOLS_SKIP_CHECK=1 mcopy -i $(vfat_image) $(confdir)/jh7110_uEnv.txt ::jh7110_uEnv.txt
PATH=$(RVPATH) MTOOLS_SKIP_CHECK=1 mcopy -i $(vfat_image) $(confdir)/vf2_uEnv.txt ::vf2_uEnv.txt
PATH=$(RVPATH) MTOOLS_SKIP_CHECK=1 mcopy -i $(vfat_image) $(confdir)/vf2_nvme_uEnv.txt ::vf2_nvme_uEnv.txt
.PHONY: format-boot-loader
format-boot-loader: $(sbi_bin) $(uboot) $(fit) $(vfat_image) $(spl_bin_normal_out)
@test -b $(DISK) || (echo "$(DISK): is not a block device"; exit 1)
sudo /sbin/sgdisk --clear \
--new=1:$(SPL_START):$(SPL_END) --change-name=1:"spl" --typecode=1:$(SPL) \
--new=2:$(UBOOT_START):$(UBOOT_END) --change-name=2:"uboot" --typecode=2:$(UBOOT) \
--new=3:$(VFAT_START):$(VFAT_END) --change-name=3:"image" --typecode=3:$(VFAT) \
--new=4:$(ROOT_START):0 --change-name=4:"root" --typecode=4:$(LINUX) \
$(DISK)
-/sbin/partprobe
@sleep 1
ifeq ($(DISK)p1,$(wildcard $(DISK)p1))
@$(eval PART1 := $(DISK)p1)
@$(eval PART2 := $(DISK)p2)
@$(eval PART3 := $(DISK)p3)
@$(eval PART4 := $(DISK)p4)
else ifeq ($(DISK)s1,$(wildcard $(DISK)s1))
@$(eval PART1 := $(DISK)s1)
@$(eval PART2 := $(DISK)s2)
@$(eval PART3 := $(DISK)s3)
@$(eval PART4 := $(DISK)s4)
else ifeq ($(DISK)1,$(wildcard $(DISK)1))
@$(eval PART1 := $(DISK)1)
@$(eval PART2 := $(DISK)2)
@$(eval PART3 := $(DISK)3)
@$(eval PART4 := $(DISK)4)
else
@echo Error: Could not find bootloader partition for $(DISK)
@exit 1
endif
sudo dd if=$(spl_bin_normal_out) of=$(PART1) bs=4096
sudo dd if=$(uboot_fit) of=$(PART2) bs=4096
sudo dd if=$(vfat_image) of=$(PART3) bs=4096
sync; sleep 1;
#starfive image
format-rootfs-image: format-boot-loader
@echo "Done setting up basic initramfs boot. We will now try to install"
@echo "a Debian snapshot to the Linux partition, which requires sudo"
@echo "you can safely cancel here"
sudo /sbin/mke2fs -t ext4 $(PART4)
-mkdir -p tmp-mnt
-mkdir -p tmp-rootfs
-sudo mount $(PART4) tmp-mnt && \
sudo mount -o loop $(buildroot_rootfs_ext) tmp-rootfs&& \
sudo cp -fr tmp-rootfs/* tmp-mnt/
sync; sleep 1;
sudo umount tmp-mnt
sudo umount tmp-rootfs
rmdir tmp-mnt
rmdir tmp-rootfs
.PHONY: sdimg img
sdimg: $(buildroot_rootfs_ext)
@./genimage.sh
img: sdimg $(spl_tool_wrkdir)/spl_tool
$(spl_tool_wrkdir)/spl_tool -i -f $(wrkdir)/sdcard.img
#usb config
format-usb-disk: $(sbi_bin) $(uboot) $(fit) $(vfat_image)
@test -b $(DISK) || (echo "$(DISK): is not a block device"; exit 1)
/sbin/sgdisk --clear \
--new=1:0:+256M --change-name=1:"Vfat Boot" --typecode=1:$(VFAT) \
--new=2:0:+1G --change-name=2:uboot --typecode=2:$(UBOOT) -g\
$(DISK)
-/sbin/partprobe
@sleep 1
ifeq ($(DISK)p1,$(wildcard $(DISK)p1))
@$(eval PART1 := $(DISK)p1)
@$(eval PART2 := $(DISK)p2)
else ifeq ($(DISK)s1,$(wildcard $(DISK)s1))
@$(eval PART1 := $(DISK)s1)
@$(eval PART2 := $(DISK)s2)
else ifeq ($(DISK)1,$(wildcard $(DISK)1))
@$(eval PART1 := $(DISK)1)
@$(eval PART2 := $(DISK)2)
else
@echo Error: Could not find bootloader partition for $(DISK)
@exit 1
endif
dd if=$(uboot) of=$(PART2) bs=4096
dd if=$(vfat_image) of=$(PART1) bs=4096
DEB_IMAGE := debian_nvdla_20190506.tar.xz
DEB_URL := https://github.com/sifive/freedom-u-sdk/releases/download/nvdla-demo-0.1
DEMO_IMAGE := sifive-debian-demo-mar7.tar.xz
DEMO_URL := https://github.com/tmagik/freedom-u-sdk/releases/download/hifiveu-2.0-alpha.1/
#nvdla image
format-nvdla-image: format-boot-loader
@echo "Done setting up basic initramfs boot. We will now try to install"
@echo "a Debian snapshot to the Linux partition, which requires sudo"
@echo "you can safely cancel here"
@test -e $(wrkdir)/$(DEB_IMAGE) || (wget -P $(wrkdir) $(DEB_URL)/$(DEB_IMAGE))
/sbin/mke2fs -t ext4 $(PART4)
-mkdir -p tmp-mnt
-mount $(PART4) tmp-mnt && \
echo "please wait until checkpoint reaches 489k" && \
tar Jxf $(wrkdir)/$(DEB_IMAGE) -C tmp-mnt --checkpoint=1000
umount tmp-mnt
#demo image
format-demo-image: format-boot-loader
@echo "Done setting up basic initramfs boot. We will now try to install"
@echo "a Debian snapshot to the Linux partition, which requires sudo"
@echo "you can safely cancel here"
/sbin/mke2fs -t ext4 $(PART4)
-mkdir tmp-mnt
-sudo mount $(PART4) tmp-mnt && cd tmp-mnt && \
sudo wget $(DEMO_URL)$(DEMO_IMAGE) && \
sudo tar -Jxvf $(DEMO_IMAGE)
sudo umount tmp-mnt
-include $(initramfs).d