mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
feee507bf9
This improves the target triple detection logic to include all possible target triples of compilers that might be able to generate our binaries.
46 lines
1.7 KiB
Makefile
46 lines
1.7 KiB
Makefile
# Target architecture for the build.
|
|
|
|
# The correct triple for 32 bit embedded RISC-V targets is "riscv32-none-elf".
|
|
# However, is unknown is used as sys (in place of none), it will also fall back
|
|
# to none. Finally, if the GCC RISC-V cross compiler is compiled with full
|
|
# multilib support, it can create both 32 bit and 64 bit binaries. Often this is
|
|
# indicated with "riscv" being used instead of "riscv32/riscv64", but e.g.
|
|
# Ubuntu uses "riscv64-unknown-elf" despite being able to produce both 32 and
|
|
# 64 bit binaries. We'll test all possible combinations from the most correct
|
|
# triple to the least correct triple all that might be able to produce our
|
|
# binaries. Finally, "riscv-none-embed" is also tested for compatibility with
|
|
# an previously popular legacy toolchain.
|
|
|
|
_TRIPLES_TO_TEST := \
|
|
riscv32-none-elf \
|
|
riscv-none-elf \
|
|
riscv32-unknown-elf \
|
|
riscv-unknown-elf \
|
|
riscv64-none-elf \
|
|
riscv64-unknown-elf \
|
|
riscv-none-embed
|
|
|
|
TARGET_ARCH_RISCV ?= \
|
|
$(strip \
|
|
$(subst -gcc,,\
|
|
$(notdir \
|
|
$(word 1,\
|
|
$(foreach triple,$(_TRIPLES_TO_TEST),$(shell which $(triple)-gcc))))))
|
|
|
|
TARGET_ARCH ?= $(TARGET_ARCH_RISCV)
|
|
|
|
# define build specific options
|
|
CFLAGS_CPU = -march=rv32imac -mabi=ilp32 -mcmodel=medlow -msmall-data-limit=8
|
|
CFLAGS_LINK = -nostartfiles -ffunction-sections -fdata-sections
|
|
CFLAGS_DBG ?= -g3
|
|
CFLAGS_OPT ?= -Os
|
|
|
|
LINKFLAGS += -L$(RIOTCPU)/$(CPU)/ldscripts
|
|
LINKER_SCRIPT ?= $(CPU_MODEL).ld
|
|
LINKFLAGS += -T$(LINKER_SCRIPT)
|
|
|
|
CFLAGS += $(CFLAGS_CPU) $(CFLAGS_DBG) $(CFLAGS_OPT) $(CFLAGS_LINK)
|
|
ASFLAGS += $(CFLAGS_CPU) $(CFLAGS_DBG)
|
|
# export linker flags
|
|
LINKFLAGS += $(CFLAGS_CPU) $(CFLAGS_LINK) $(CFLAGS_DBG) $(CFLAGS_OPT) -Wl,--gc-sections -static -lgcc
|