2019-11-25 18:54:05 +00:00
|
|
|
## SPDX-License-Identifier: MIT OR Apache-2.0
|
2019-11-04 21:59:31 +00:00
|
|
|
##
|
|
|
|
## Copyright (c) 2018-2019 Andre Richter <andre.o.richter@gmail.com>
|
|
|
|
|
|
|
|
# Default to the RPi3
|
|
|
|
ifndef BSP
|
|
|
|
BSP = rpi3
|
|
|
|
endif
|
|
|
|
|
|
|
|
# BSP-specific arguments
|
|
|
|
ifeq ($(BSP),rpi3)
|
|
|
|
TARGET = aarch64-unknown-none-softfloat
|
|
|
|
OUTPUT = kernel8.img
|
|
|
|
QEMU_BINARY = qemu-system-aarch64
|
|
|
|
QEMU_MACHINE_TYPE = raspi3
|
|
|
|
QEMU_MISC_ARGS = -serial stdio
|
|
|
|
OPENOCD_ARG = -f /openocd/tcl/interface/ftdi/olimex-arm-usb-tiny-h.cfg -f /openocd/rpi3.cfg
|
|
|
|
JTAG_BOOT_IMAGE = jtag_boot_rpi3.img
|
|
|
|
LINKER_FILE = src/bsp/rpi/link.ld
|
|
|
|
RUSTC_MISC_ARGS = -C target-cpu=cortex-a53
|
|
|
|
else ifeq ($(BSP),rpi4)
|
|
|
|
TARGET = aarch64-unknown-none-softfloat
|
|
|
|
OUTPUT = kernel8.img
|
|
|
|
# QEMU_BINARY = qemu-system-aarch64
|
|
|
|
# QEMU_MACHINE_TYPE =
|
|
|
|
# QEMU_MISC_ARGS = -serial stdio
|
|
|
|
OPENOCD_ARG = -f /openocd/tcl/interface/ftdi/olimex-arm-usb-tiny-h.cfg -f /openocd/rpi4.cfg
|
|
|
|
JTAG_BOOT_IMAGE = jtag_boot_rpi4.img
|
|
|
|
LINKER_FILE = src/bsp/rpi/link.ld
|
|
|
|
RUSTC_MISC_ARGS = -C target-cpu=cortex-a72
|
|
|
|
endif
|
|
|
|
|
2019-11-13 07:40:23 +00:00
|
|
|
RUSTFLAGS = -C link-arg=-T$(LINKER_FILE) $(RUSTC_MISC_ARGS)
|
|
|
|
RUSTFLAGS_PEDANTIC = $(RUSTFLAGS) -D warnings -D missing_docs
|
|
|
|
|
2019-11-04 21:59:31 +00:00
|
|
|
SOURCES = $(wildcard **/*.rs) $(wildcard **/*.S) $(wildcard **/*.ld)
|
|
|
|
|
|
|
|
XRUSTC_CMD = cargo xrustc \
|
|
|
|
--target=$(TARGET) \
|
|
|
|
--features bsp_$(BSP) \
|
2019-11-13 07:40:23 +00:00
|
|
|
--release
|
2019-11-04 21:59:31 +00:00
|
|
|
|
|
|
|
CARGO_OUTPUT = target/$(TARGET)/release/kernel
|
|
|
|
|
|
|
|
OBJCOPY_CMD = cargo objcopy \
|
|
|
|
-- \
|
|
|
|
--strip-all \
|
|
|
|
-O binary
|
|
|
|
|
|
|
|
CONTAINER_UTILS = rustembedded/osdev-utils
|
|
|
|
|
|
|
|
DOCKER_CMD = docker run -it --rm
|
|
|
|
DOCKER_ARG_CURDIR = -v $(shell pwd):/work -w /work
|
|
|
|
DOCKER_ARG_TTY = --privileged -v /dev:/dev
|
|
|
|
DOCKER_ARG_JTAG = -v $(shell pwd)/../X1_JTAG_boot:/jtag
|
|
|
|
DOCKER_ARG_NET = --network host
|
|
|
|
|
2019-11-13 07:40:23 +00:00
|
|
|
DOCKER_EXEC_QEMU = $(QEMU_BINARY) -M $(QEMU_MACHINE_TYPE) $(QEMU_MISC_ARGS) -kernel
|
2019-11-04 21:59:31 +00:00
|
|
|
DOCKER_EXEC_RASPBOOT = raspbootcom
|
|
|
|
DOCKER_EXEC_RASPBOOT_DEV = /dev/ttyUSB0
|
|
|
|
# DOCKER_EXEC_RASPBOOT_DEV = /dev/ttyACM0
|
|
|
|
|
2019-11-13 07:40:23 +00:00
|
|
|
.PHONY: all doc qemu chainboot jtagboot openocd gdb gdb-opt0 clippy clean readelf objdump nm
|
2019-11-04 21:59:31 +00:00
|
|
|
|
|
|
|
all: clean $(OUTPUT)
|
|
|
|
|
|
|
|
$(CARGO_OUTPUT): $(SOURCES)
|
2019-11-13 07:40:23 +00:00
|
|
|
RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(XRUSTC_CMD)
|
2019-11-04 21:59:31 +00:00
|
|
|
|
|
|
|
$(OUTPUT): $(CARGO_OUTPUT)
|
|
|
|
cp $< .
|
|
|
|
$(OBJCOPY_CMD) $< $(OUTPUT)
|
|
|
|
|
|
|
|
doc:
|
|
|
|
cargo xdoc --target=$(TARGET) --features bsp_$(BSP) --document-private-items
|
|
|
|
xdg-open target/$(TARGET)/doc/kernel/index.html
|
|
|
|
|
|
|
|
ifeq ($(QEMU_MACHINE_TYPE),)
|
|
|
|
qemu:
|
|
|
|
@echo "This board is not yet supported for QEMU."
|
|
|
|
else
|
|
|
|
qemu: all
|
|
|
|
$(DOCKER_CMD) $(DOCKER_ARG_CURDIR) $(CONTAINER_UTILS) \
|
2019-11-13 07:40:23 +00:00
|
|
|
$(DOCKER_EXEC_QEMU) $(OUTPUT)
|
2019-11-04 21:59:31 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
chainboot: all
|
|
|
|
$(DOCKER_CMD) $(DOCKER_ARG_CURDIR) $(DOCKER_ARG_TTY) \
|
|
|
|
$(CONTAINER_UTILS) $(DOCKER_EXEC_RASPBOOT) $(DOCKER_EXEC_RASPBOOT_DEV) \
|
|
|
|
$(OUTPUT)
|
|
|
|
|
|
|
|
jtagboot:
|
|
|
|
$(DOCKER_CMD) $(DOCKER_ARG_TTY) $(DOCKER_ARG_JTAG) $(CONTAINER_UTILS) \
|
|
|
|
$(DOCKER_EXEC_RASPBOOT) $(DOCKER_EXEC_RASPBOOT_DEV) \
|
|
|
|
/jtag/$(JTAG_BOOT_IMAGE)
|
|
|
|
|
|
|
|
openocd:
|
|
|
|
$(DOCKER_CMD) $(DOCKER_ARG_TTY) $(DOCKER_ARG_NET) $(CONTAINER_UTILS) \
|
|
|
|
openocd $(OPENOCD_ARG)
|
|
|
|
|
|
|
|
define gen_gdb
|
2019-11-13 07:40:23 +00:00
|
|
|
RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(XRUSTC_CMD) $1
|
2019-11-04 21:59:31 +00:00
|
|
|
cp $(CARGO_OUTPUT) kernel_for_jtag
|
|
|
|
$(DOCKER_CMD) $(DOCKER_ARG_CURDIR) $(DOCKER_ARG_NET) $(CONTAINER_UTILS) \
|
|
|
|
gdb-multiarch -q kernel_for_jtag
|
|
|
|
endef
|
|
|
|
|
|
|
|
gdb: clean $(SOURCES)
|
|
|
|
$(call gen_gdb,-C debuginfo=2)
|
|
|
|
|
|
|
|
gdb-opt0: clean $(SOURCES)
|
|
|
|
$(call gen_gdb,-C debuginfo=2 -C opt-level=0)
|
|
|
|
|
|
|
|
clippy:
|
|
|
|
cargo xclippy --target=$(TARGET) --features bsp_$(BSP)
|
|
|
|
|
|
|
|
clean:
|
2019-11-13 07:40:23 +00:00
|
|
|
rm -rf target
|
2019-11-04 21:59:31 +00:00
|
|
|
|
|
|
|
readelf:
|
|
|
|
readelf -a kernel
|
|
|
|
|
|
|
|
objdump:
|
|
|
|
cargo objdump --target $(TARGET) -- -disassemble -print-imm-hex kernel
|
|
|
|
|
|
|
|
nm:
|
|
|
|
cargo nm --target $(TARGET) -- kernel | sort
|