2019-11-25 18:54:05 +00:00
|
|
|
## SPDX-License-Identifier: MIT OR Apache-2.0
|
2019-09-25 13:25:40 +00:00
|
|
|
##
|
2020-01-01 23:41:03 +00:00
|
|
|
## Copyright (c) 2018-2020 Andre Richter <andre.o.richter@gmail.com>
|
2019-09-25 13:25:40 +00:00
|
|
|
|
|
|
|
# Default to the RPi3
|
2020-04-12 20:22:29 +00:00
|
|
|
BSP ?= rpi3
|
2019-09-25 13:25:40 +00:00
|
|
|
|
|
|
|
# BSP-specific arguments
|
2019-10-21 19:19:11 +00:00
|
|
|
ifeq ($(BSP),rpi3)
|
2020-04-12 20:22:29 +00:00
|
|
|
TARGET = aarch64-unknown-none-softfloat
|
2020-04-16 20:46:11 +00:00
|
|
|
KERNEL_BIN = kernel8.img
|
2020-04-12 20:22:29 +00:00
|
|
|
QEMU_BINARY = qemu-system-aarch64
|
|
|
|
QEMU_MACHINE_TYPE = raspi3
|
|
|
|
QEMU_RELEASE_ARGS = -serial stdio -display none
|
|
|
|
LINKER_FILE = src/bsp/raspberrypi/link.ld
|
|
|
|
RUSTC_MISC_ARGS = -C target-cpu=cortex-a53
|
2019-10-29 21:32:49 +00:00
|
|
|
else ifeq ($(BSP),rpi4)
|
2020-04-12 20:22:29 +00:00
|
|
|
TARGET = aarch64-unknown-none-softfloat
|
2020-04-16 20:46:11 +00:00
|
|
|
KERNEL_BIN = kernel8.img
|
2020-04-12 20:22:29 +00:00
|
|
|
QEMU_BINARY = qemu-system-aarch64
|
|
|
|
QEMU_MACHINE_TYPE =
|
|
|
|
QEMU_RELEASE_ARGS = -serial stdio -display none
|
|
|
|
LINKER_FILE = src/bsp/raspberrypi/link.ld
|
|
|
|
RUSTC_MISC_ARGS = -C target-cpu=cortex-a72
|
2019-09-25 13:25:40 +00:00
|
|
|
endif
|
|
|
|
|
2020-04-14 21:16:35 +00:00
|
|
|
# Export for build.rs
|
|
|
|
export LINKER_FILE
|
2020-04-07 21:17:48 +00:00
|
|
|
|
2020-01-14 19:45:41 +00:00
|
|
|
RUSTFLAGS = -C link-arg=-T$(LINKER_FILE) $(RUSTC_MISC_ARGS)
|
2019-11-13 07:40:23 +00:00
|
|
|
RUSTFLAGS_PEDANTIC = $(RUSTFLAGS) -D warnings -D missing_docs
|
|
|
|
|
2020-04-07 21:17:48 +00:00
|
|
|
COMPILER_ARGS = --target=$(TARGET) \
|
2020-04-12 20:22:29 +00:00
|
|
|
--features bsp_$(BSP) \
|
|
|
|
--release
|
2019-09-25 13:25:40 +00:00
|
|
|
|
2020-04-11 10:22:52 +00:00
|
|
|
RUSTC_CMD = cargo rustc $(COMPILER_ARGS)
|
2020-04-09 19:25:56 +00:00
|
|
|
DOC_CMD = cargo doc $(COMPILER_ARGS)
|
2020-04-11 10:22:52 +00:00
|
|
|
CLIPPY_CMD = cargo clippy $(COMPILER_ARGS)
|
2020-04-15 21:00:21 +00:00
|
|
|
CHECK_CMD = cargo check $(COMPILER_ARGS)
|
2020-04-12 09:54:13 +00:00
|
|
|
OBJCOPY_CMD = rust-objcopy \
|
2020-04-12 20:22:29 +00:00
|
|
|
--strip-all \
|
|
|
|
-O binary
|
2019-09-25 13:25:40 +00:00
|
|
|
|
2020-04-11 10:22:52 +00:00
|
|
|
KERNEL_ELF = target/$(TARGET)/release/kernel
|
|
|
|
|
2020-01-14 19:45:41 +00:00
|
|
|
DOCKER_IMAGE = rustembedded/osdev-utils
|
2020-04-11 10:22:52 +00:00
|
|
|
DOCKER_CMD = docker run -it --rm -v $(shell pwd):/work/tutorial -w /work/tutorial
|
|
|
|
|
|
|
|
DOCKER_QEMU = $(DOCKER_CMD) $(DOCKER_IMAGE)
|
|
|
|
|
2020-04-12 20:22:29 +00:00
|
|
|
EXEC_QEMU = $(QEMU_BINARY) -M $(QEMU_MACHINE_TYPE)
|
2019-09-25 13:25:40 +00:00
|
|
|
|
2020-04-16 20:46:11 +00:00
|
|
|
.PHONY: all $(KERNEL_ELF) $(KERNEL_BIN) doc qemu clippy clean readelf objdump nm check
|
2019-09-25 13:25:40 +00:00
|
|
|
|
2020-04-16 20:46:11 +00:00
|
|
|
all: $(KERNEL_BIN)
|
|
|
|
|
|
|
|
$(KERNEL_ELF):
|
2020-04-07 21:17:48 +00:00
|
|
|
RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(RUSTC_CMD)
|
2020-04-16 20:46:11 +00:00
|
|
|
|
|
|
|
$(KERNEL_BIN): $(KERNEL_ELF)
|
|
|
|
@$(OBJCOPY_CMD) $(KERNEL_ELF) $(KERNEL_BIN)
|
2019-09-25 13:25:40 +00:00
|
|
|
|
|
|
|
doc:
|
2020-04-09 19:25:56 +00:00
|
|
|
$(DOC_CMD) --document-private-items --open
|
2019-09-25 13:25:40 +00:00
|
|
|
|
2019-10-29 21:32:49 +00:00
|
|
|
ifeq ($(QEMU_MACHINE_TYPE),)
|
|
|
|
qemu:
|
|
|
|
@echo "This board is not yet supported for QEMU."
|
|
|
|
else
|
2020-04-16 20:46:11 +00:00
|
|
|
qemu: $(KERNEL_BIN)
|
|
|
|
@$(DOCKER_QEMU) $(EXEC_QEMU) $(QEMU_RELEASE_ARGS) -kernel $(KERNEL_BIN)
|
2019-10-29 21:32:49 +00:00
|
|
|
endif
|
2019-09-25 13:25:40 +00:00
|
|
|
|
|
|
|
clippy:
|
2020-04-07 21:17:48 +00:00
|
|
|
RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(CLIPPY_CMD)
|
2019-09-25 13:25:40 +00:00
|
|
|
|
|
|
|
clean:
|
2020-04-16 20:46:11 +00:00
|
|
|
rm -rf target $(KERNEL_BIN)
|
2019-09-25 13:25:40 +00:00
|
|
|
|
2020-04-16 20:46:11 +00:00
|
|
|
readelf: $(KERNEL_ELF)
|
2020-07-21 15:47:43 +00:00
|
|
|
readelf --headers $(KERNEL_ELF)
|
2019-09-25 13:25:40 +00:00
|
|
|
|
2020-04-16 20:46:11 +00:00
|
|
|
objdump: $(KERNEL_ELF)
|
2020-04-15 21:38:44 +00:00
|
|
|
rust-objdump --arch-name aarch64 --disassemble --demangle --no-show-raw-insn \
|
|
|
|
--print-imm-hex $(KERNEL_ELF)
|
2019-09-25 13:25:40 +00:00
|
|
|
|
2020-04-16 20:46:11 +00:00
|
|
|
nm: $(KERNEL_ELF)
|
2020-04-12 20:22:29 +00:00
|
|
|
rust-nm --demangle --print-size $(KERNEL_ELF) | sort
|
2020-04-15 21:00:21 +00:00
|
|
|
|
|
|
|
# For rust-analyzer
|
|
|
|
check:
|
|
|
|
@RUSTFLAGS="$(RUSTFLAGS)" $(CHECK_CMD) --message-format=json
|