|
|
@ -2,7 +2,7 @@
|
|
|
|
##
|
|
|
|
##
|
|
|
|
## Copyright (c) 2018-2022 Andre Richter <andre.o.richter@gmail.com>
|
|
|
|
## Copyright (c) 2018-2022 Andre Richter <andre.o.richter@gmail.com>
|
|
|
|
|
|
|
|
|
|
|
|
include ../common/color.mk
|
|
|
|
include ../common/format.mk
|
|
|
|
include ../common/docker.mk
|
|
|
|
include ../common/docker.mk
|
|
|
|
|
|
|
|
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
@ -65,10 +65,23 @@ export LD_SCRIPT_PATH
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
## Generic configuration values
|
|
|
|
## Targets and Prerequisites
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
KERNEL_LINKER_SCRIPT = link.ld
|
|
|
|
KERNEL_LINKER_SCRIPT = link.ld
|
|
|
|
KERNEL_ELF = target/$(TARGET)/release/kernel
|
|
|
|
|
|
|
|
|
|
|
|
TT_TOOL_PATH = translation_table_tool
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LAST_BUILD_CONFIG = target/$(BSP).build_config
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
KERNEL_ELF_RAW = target/$(TARGET)/release/kernel
|
|
|
|
|
|
|
|
# This parses cargo's dep-info file.
|
|
|
|
|
|
|
|
# https://doc.rust-lang.org/cargo/guide/build-cache.html#dep-info-files
|
|
|
|
|
|
|
|
KERNEL_ELF_RAW_DEPS = $(filter-out %: ,$(file < $(KERNEL_ELF_RAW).d)) $(LAST_BUILD_CONFIG)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
KERNEL_ELF_TTABLES = target/$(TARGET)/release/kernel+ttables
|
|
|
|
|
|
|
|
KERNEL_ELF_TTABLES_DEPS = $(KERNEL_ELF_RAW) $(wildcard $(TT_TOOL_PATH)/*)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
KERNEL_ELF = $(KERNEL_ELF_TTABLES)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -98,7 +111,7 @@ OBJCOPY_CMD = rust-objcopy \
|
|
|
|
-O binary
|
|
|
|
-O binary
|
|
|
|
|
|
|
|
|
|
|
|
EXEC_QEMU = $(QEMU_BINARY) -M $(QEMU_MACHINE_TYPE)
|
|
|
|
EXEC_QEMU = $(QEMU_BINARY) -M $(QEMU_MACHINE_TYPE)
|
|
|
|
EXEC_TT_TOOL = ruby translation_table_tool/main.rb
|
|
|
|
EXEC_TT_TOOL = ruby $(TT_TOOL_PATH)/main.rb
|
|
|
|
EXEC_TEST_DISPATCH = ruby ../common/tests/dispatch.rb
|
|
|
|
EXEC_TEST_DISPATCH = ruby ../common/tests/dispatch.rb
|
|
|
|
EXEC_MINIPUSH = ruby ../common/serial/minipush.rb
|
|
|
|
EXEC_MINIPUSH = ruby ../common/serial/minipush.rb
|
|
|
|
|
|
|
|
|
|
|
@ -134,29 +147,49 @@ endif
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
## Targets
|
|
|
|
## Targets
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
##--------------------------------------------------------------------------------------------------
|
|
|
|
.PHONY: all $(KERNEL_ELF) $(KERNEL_BIN) doc qemu chainboot clippy clean readelf objdump nm check
|
|
|
|
.PHONY: all doc qemu chainboot clippy clean readelf objdump nm check
|
|
|
|
|
|
|
|
|
|
|
|
all: $(KERNEL_BIN)
|
|
|
|
all: $(KERNEL_BIN)
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
## Build the kernel ELF
|
|
|
|
## Save the configuration as a file, so make understands if it changed.
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
$(KERNEL_ELF):
|
|
|
|
$(LAST_BUILD_CONFIG):
|
|
|
|
$(call colorecho, "\nCompiling kernel - $(BSP)")
|
|
|
|
@rm -f target/*.build_config
|
|
|
|
|
|
|
|
@mkdir -p target
|
|
|
|
|
|
|
|
@touch $(LAST_BUILD_CONFIG)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
## Compile the kernel ELF
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
$(KERNEL_ELF_RAW): $(KERNEL_ELF_RAW_DEPS)
|
|
|
|
|
|
|
|
$(call color_header, "Compiling kernel ELF - $(BSP)")
|
|
|
|
@RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(RUSTC_CMD)
|
|
|
|
@RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(RUSTC_CMD)
|
|
|
|
@$(DOCKER_TOOLS) $(EXEC_TT_TOOL) $(TARGET) $(BSP) $(KERNEL_ELF)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
## Build the stripped kernel binary
|
|
|
|
## Precompute the kernel translation tables and patch them into the kernel ELF
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
$(KERNEL_ELF_TTABLES): $(KERNEL_ELF_TTABLES_DEPS)
|
|
|
|
|
|
|
|
$(call color_header, "Precomputing kernel translation tables and patching kernel ELF")
|
|
|
|
|
|
|
|
@cp $(KERNEL_ELF_RAW) $(KERNEL_ELF_TTABLES)
|
|
|
|
|
|
|
|
@$(DOCKER_TOOLS) $(EXEC_TT_TOOL) $(TARGET) $(BSP) $(KERNEL_ELF_TTABLES)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
## Generate the stripped kernel binary
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
$(KERNEL_BIN): $(KERNEL_ELF)
|
|
|
|
$(KERNEL_BIN): $(KERNEL_ELF_TTABLES)
|
|
|
|
@$(OBJCOPY_CMD) $(KERNEL_ELF) $(KERNEL_BIN)
|
|
|
|
$(call color_header, "Generating stripped binary")
|
|
|
|
|
|
|
|
@$(OBJCOPY_CMD) $(KERNEL_ELF_TTABLES) $(KERNEL_BIN)
|
|
|
|
|
|
|
|
$(call color_progress_prefix, "Name")
|
|
|
|
|
|
|
|
@echo $(KERNEL_BIN)
|
|
|
|
|
|
|
|
$(call color_progress_prefix, "Size")
|
|
|
|
|
|
|
|
@printf '%s KiB\n' `du -k $(KERNEL_BIN) | cut -f1`
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
## Build the documentation
|
|
|
|
## Generate the documentation
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
doc:
|
|
|
|
doc:
|
|
|
|
$(call colorecho, "\nGenerating docs")
|
|
|
|
$(call color_header, "Generating docs")
|
|
|
|
@$(DOC_CMD) --document-private-items --open
|
|
|
|
@$(DOC_CMD) --document-private-items --open
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
@ -165,12 +198,12 @@ doc:
|
|
|
|
ifeq ($(QEMU_MACHINE_TYPE),) # QEMU is not supported for the board.
|
|
|
|
ifeq ($(QEMU_MACHINE_TYPE),) # QEMU is not supported for the board.
|
|
|
|
|
|
|
|
|
|
|
|
qemu:
|
|
|
|
qemu:
|
|
|
|
$(call colorecho, "\n$(QEMU_MISSING_STRING)")
|
|
|
|
$(call color_header, "$(QEMU_MISSING_STRING)")
|
|
|
|
|
|
|
|
|
|
|
|
else # QEMU is supported.
|
|
|
|
else # QEMU is supported.
|
|
|
|
|
|
|
|
|
|
|
|
qemu: $(KERNEL_BIN)
|
|
|
|
qemu: $(KERNEL_BIN)
|
|
|
|
$(call colorecho, "\nLaunching QEMU")
|
|
|
|
$(call color_header, "Launching QEMU")
|
|
|
|
@$(DOCKER_QEMU) $(EXEC_QEMU) $(QEMU_RELEASE_ARGS) -kernel $(KERNEL_BIN)
|
|
|
|
@$(DOCKER_QEMU) $(EXEC_QEMU) $(QEMU_RELEASE_ARGS) -kernel $(KERNEL_BIN)
|
|
|
|
|
|
|
|
|
|
|
|
endif
|
|
|
|
endif
|
|
|
@ -197,14 +230,14 @@ clean:
|
|
|
|
## Run readelf
|
|
|
|
## Run readelf
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
readelf: $(KERNEL_ELF)
|
|
|
|
readelf: $(KERNEL_ELF)
|
|
|
|
$(call colorecho, "\nLaunching readelf")
|
|
|
|
$(call color_header, "Launching readelf")
|
|
|
|
@$(DOCKER_TOOLS) $(READELF_BINARY) --headers $(KERNEL_ELF)
|
|
|
|
@$(DOCKER_TOOLS) $(READELF_BINARY) --headers $(KERNEL_ELF)
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
## Run objdump
|
|
|
|
## Run objdump
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
objdump: $(KERNEL_ELF)
|
|
|
|
objdump: $(KERNEL_ELF)
|
|
|
|
$(call colorecho, "\nLaunching objdump")
|
|
|
|
$(call color_header, "Launching objdump")
|
|
|
|
@$(DOCKER_TOOLS) $(OBJDUMP_BINARY) --disassemble --demangle \
|
|
|
|
@$(DOCKER_TOOLS) $(OBJDUMP_BINARY) --disassemble --demangle \
|
|
|
|
--section .text \
|
|
|
|
--section .text \
|
|
|
|
--section .rodata \
|
|
|
|
--section .rodata \
|
|
|
@ -215,7 +248,7 @@ objdump: $(KERNEL_ELF)
|
|
|
|
## Run nm
|
|
|
|
## Run nm
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
nm: $(KERNEL_ELF)
|
|
|
|
nm: $(KERNEL_ELF)
|
|
|
|
$(call colorecho, "\nLaunching nm")
|
|
|
|
$(call color_header, "Launching nm")
|
|
|
|
@$(DOCKER_TOOLS) $(NM_BINARY) --demangle --print-size $(KERNEL_ELF) | sort | rustfilt
|
|
|
|
@$(DOCKER_TOOLS) $(NM_BINARY) --demangle --print-size $(KERNEL_ELF) | sort | rustfilt
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
@ -241,7 +274,7 @@ jtagboot:
|
|
|
|
## Start OpenOCD session
|
|
|
|
## Start OpenOCD session
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
openocd:
|
|
|
|
openocd:
|
|
|
|
$(call colorecho, "\nLaunching OpenOCD")
|
|
|
|
$(call color_header, "Launching OpenOCD")
|
|
|
|
@$(DOCKER_OPENOCD) openocd $(OPENOCD_ARG)
|
|
|
|
@$(DOCKER_OPENOCD) openocd $(OPENOCD_ARG)
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
@ -250,7 +283,7 @@ openocd:
|
|
|
|
gdb: RUSTC_MISC_ARGS += -C debuginfo=2
|
|
|
|
gdb: RUSTC_MISC_ARGS += -C debuginfo=2
|
|
|
|
gdb-opt0: RUSTC_MISC_ARGS += -C debuginfo=2 -C opt-level=0
|
|
|
|
gdb-opt0: RUSTC_MISC_ARGS += -C debuginfo=2 -C opt-level=0
|
|
|
|
gdb gdb-opt0: $(KERNEL_ELF)
|
|
|
|
gdb gdb-opt0: $(KERNEL_ELF)
|
|
|
|
$(call colorecho, "\nLaunching GDB")
|
|
|
|
$(call color_header, "Launching GDB")
|
|
|
|
@$(DOCKER_GDB) gdb-multiarch -q $(KERNEL_ELF)
|
|
|
|
@$(DOCKER_GDB) gdb-multiarch -q $(KERNEL_ELF)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -263,7 +296,7 @@ gdb gdb-opt0: $(KERNEL_ELF)
|
|
|
|
ifeq ($(QEMU_MACHINE_TYPE),) # QEMU is not supported for the board.
|
|
|
|
ifeq ($(QEMU_MACHINE_TYPE),) # QEMU is not supported for the board.
|
|
|
|
|
|
|
|
|
|
|
|
test_boot test_unit test_integration test:
|
|
|
|
test_boot test_unit test_integration test:
|
|
|
|
$(call colorecho, "\n$(QEMU_MISSING_STRING)")
|
|
|
|
$(call color_header, "$(QEMU_MISSING_STRING)")
|
|
|
|
|
|
|
|
|
|
|
|
else # QEMU is supported.
|
|
|
|
else # QEMU is supported.
|
|
|
|
|
|
|
|
|
|
|
@ -271,7 +304,7 @@ else # QEMU is supported.
|
|
|
|
## Run boot test
|
|
|
|
## Run boot test
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
test_boot: $(KERNEL_BIN)
|
|
|
|
test_boot: $(KERNEL_BIN)
|
|
|
|
$(call colorecho, "\nBoot test - $(BSP)")
|
|
|
|
$(call color_header, "Boot test - $(BSP)")
|
|
|
|
@$(DOCKER_TEST) $(EXEC_TEST_DISPATCH) $(EXEC_QEMU) $(QEMU_RELEASE_ARGS) -kernel $(KERNEL_BIN)
|
|
|
|
@$(DOCKER_TEST) $(EXEC_TEST_DISPATCH) $(EXEC_QEMU) $(QEMU_RELEASE_ARGS) -kernel $(KERNEL_BIN)
|
|
|
|
|
|
|
|
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
@ -300,7 +333,7 @@ endef
|
|
|
|
## Run unit test(s)
|
|
|
|
## Run unit test(s)
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
test_unit:
|
|
|
|
test_unit:
|
|
|
|
$(call colorecho, "\nCompiling unit test(s) - $(BSP)")
|
|
|
|
$(call color_header, "Compiling unit test(s) - $(BSP)")
|
|
|
|
$(call test_prepare)
|
|
|
|
$(call test_prepare)
|
|
|
|
@RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(TEST_CMD) --lib
|
|
|
|
@RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(TEST_CMD) --lib
|
|
|
|
|
|
|
|
|
|
|
@ -308,7 +341,7 @@ test_unit:
|
|
|
|
## Run integration test(s)
|
|
|
|
## Run integration test(s)
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
##------------------------------------------------------------------------------
|
|
|
|
test_integration:
|
|
|
|
test_integration:
|
|
|
|
$(call colorecho, "\nCompiling integration test(s) - $(BSP)")
|
|
|
|
$(call color_header, "Compiling integration test(s) - $(BSP)")
|
|
|
|
$(call test_prepare)
|
|
|
|
$(call test_prepare)
|
|
|
|
@RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(TEST_CMD) $(TEST_ARG)
|
|
|
|
@RUSTFLAGS="$(RUSTFLAGS_PEDANTIC)" $(TEST_CMD) $(TEST_ARG)
|
|
|
|
|
|
|
|
|
|
|
|