2016-07-08 16:29:55 -07:00
|
|
|
RISCV ?= $(CURDIR)/toolchain
|
|
|
|
PATH := $(RISCV)/bin:$(PATH)
|
2016-06-17 11:38:33 -07:00
|
|
|
|
|
|
|
srcdir := $(dir $(realpath $(lastword $(MAKEFILE_LIST))))
|
|
|
|
srcdir := $(srcdir:/=)
|
|
|
|
confdir := $(srcdir)/conf
|
|
|
|
wrkdir := $(CURDIR)/work
|
|
|
|
|
2016-07-08 17:58:13 -07:00
|
|
|
toolchain_srcdir := $(srcdir)/riscv-gnu-toolchain
|
|
|
|
toolchain_wrkdir := $(wrkdir)/riscv-gnu-toolchain
|
|
|
|
toolchain_dest := $(CURDIR)/toolchain
|
|
|
|
|
2016-06-17 11:38:33 -07:00
|
|
|
buildroot_srcdir := $(srcdir)/buildroot
|
|
|
|
buildroot_wrkdir := $(wrkdir)/buildroot
|
|
|
|
buildroot_tar := $(buildroot_wrkdir)/images/rootfs.tar
|
|
|
|
|
|
|
|
sysroot_stamp := $(wrkdir)/.sysroot
|
|
|
|
sysroot := $(wrkdir)/sysroot
|
|
|
|
|
|
|
|
linux_srcdir := $(srcdir)/linux
|
|
|
|
linux_wrkdir := $(wrkdir)/linux
|
|
|
|
linux_defconfig := $(confdir)/linux_defconfig
|
|
|
|
|
|
|
|
vmlinux := $(linux_wrkdir)/vmlinux
|
|
|
|
vmlinux_stripped := $(linux_wrkdir)/vmlinux-stripped
|
|
|
|
|
|
|
|
pk_srcdir := $(srcdir)/riscv-pk
|
|
|
|
pk_wrkdir := $(wrkdir)/riscv-pk
|
|
|
|
bbl := $(pk_wrkdir)/bbl
|
|
|
|
bin := $(wrkdir)/bbl.bin
|
2016-07-07 17:16:54 -07:00
|
|
|
hex := $(wrkdir)/bbl.hex
|
2016-06-17 11:38:33 -07:00
|
|
|
|
|
|
|
target := riscv64-unknown-linux-gnu
|
|
|
|
|
|
|
|
.PHONY: all
|
2016-07-07 17:16:54 -07:00
|
|
|
all: $(hex)
|
2016-07-08 16:29:55 -07:00
|
|
|
@echo
|
|
|
|
@echo Find the SD-card image in work/bbl.bin
|
|
|
|
@echo Program it with: dd if=work/bbl.bin of=/dev/sd-your-card bs=1M
|
|
|
|
@echo
|
2016-06-17 11:38:33 -07:00
|
|
|
|
2016-07-08 17:58:13 -07:00
|
|
|
$(toolchain_dest)/bin/$(target)-gcc: $(toolchain_srcdir)
|
|
|
|
mkdir -p $(toolchain_wrkdir)
|
|
|
|
cd $(toolchain_wrkdir); $(toolchain_srcdir)/configure --prefix=$(toolchain_dest)
|
|
|
|
$(MAKE) -C $(toolchain_wrkdir) linux
|
2016-07-08 16:29:55 -07:00
|
|
|
|
|
|
|
$(buildroot_tar): $(buildroot_srcdir) $(RISCV)/bin/$(target)-gcc
|
2016-07-08 17:58:13 -07:00
|
|
|
$(MAKE) -C $< RISCV=$(RISCV) PATH=$(PATH) O=$(buildroot_wrkdir) riscv64_defconfig
|
|
|
|
$(MAKE) -C $< RISCV=$(RISCV) PATH=$(PATH) O=$(buildroot_wrkdir)
|
2016-06-17 11:38:33 -07:00
|
|
|
|
|
|
|
.PHONY: buildroot-menuconfig
|
|
|
|
buildroot-menuconfig: $(buildroot_srcdir)
|
|
|
|
$(MAKE) -C $< O=$(buildroot_wrkdir) menuconfig
|
|
|
|
|
|
|
|
$(sysroot_stamp): $(buildroot_tar)
|
|
|
|
mkdir -p $(sysroot)
|
2016-11-28 19:42:51 -08:00
|
|
|
tar -xpf $< -C $(sysroot) --exclude ./dev --exclude ./usr/share/locale
|
2016-06-17 11:38:33 -07:00
|
|
|
touch $@
|
|
|
|
|
2017-04-06 10:22:55 -07:00
|
|
|
$(linux_wrkdir)/.config: $(linux_defconfig) $(linux_srcdir)
|
2016-06-17 11:38:33 -07:00
|
|
|
mkdir -p $(dir $@)
|
|
|
|
cp -p $< $@
|
|
|
|
$(MAKE) -C $(linux_srcdir) O=$(linux_wrkdir) ARCH=riscv olddefconfig
|
|
|
|
|
|
|
|
$(vmlinux): $(linux_srcdir) $(linux_wrkdir)/.config $(sysroot_stamp)
|
|
|
|
$(MAKE) -C $< O=$(linux_wrkdir) \
|
|
|
|
CONFIG_INITRAMFS_SOURCE="$(confdir)/initramfs.txt $(sysroot)" \
|
|
|
|
CONFIG_INITRAMFS_ROOT_UID=$(shell id -u) \
|
|
|
|
CONFIG_INITRAMFS_ROOT_GID=$(shell id -g) \
|
|
|
|
ARCH=riscv \
|
|
|
|
vmlinux
|
|
|
|
|
|
|
|
$(vmlinux_stripped): $(vmlinux)
|
|
|
|
$(target)-strip -o $@ $<
|
|
|
|
|
|
|
|
.PHONY: linux-menuconfig
|
|
|
|
linux-menuconfig: $(linux_wrkdir)/.config
|
|
|
|
$(MAKE) -C $(linux_srcdir) O=$(dir $<) ARCH=riscv menuconfig savedefconfig
|
|
|
|
|
|
|
|
$(bbl): $(pk_srcdir) $(vmlinux_stripped)
|
|
|
|
rm -rf $(pk_wrkdir)
|
|
|
|
mkdir -p $(pk_wrkdir)
|
|
|
|
cd $(pk_wrkdir) && $</configure \
|
|
|
|
--host=$(target) \
|
|
|
|
--with-payload=$(vmlinux_stripped)
|
2017-04-06 10:50:35 -07:00
|
|
|
CFLAGS="-mabi=lp64 -march=rv64imac -DDISABLED_HART_MASK=1" $(MAKE) -C $(pk_wrkdir)
|
2016-06-17 11:38:33 -07:00
|
|
|
|
|
|
|
$(bin): $(bbl)
|
|
|
|
$(target)-objcopy -S -O binary --change-addresses -0x80000000 $< $@
|
|
|
|
|
2016-07-07 17:16:54 -07:00
|
|
|
$(hex): $(bin)
|
|
|
|
xxd -c1 -p $< > $@
|
|
|
|
|
2016-06-17 11:38:33 -07:00
|
|
|
.PHONY: sysroot vmlinux bbl
|
|
|
|
sysroot: $(sysroot)
|
|
|
|
vmlinux: $(vmlinux)
|
|
|
|
bbl: $(bbl)
|
|
|
|
|
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
2016-07-08 17:58:13 -07:00
|
|
|
rm -rf -- $(wrkdir) $(toolchain_dest)
|