2020-06-10 18:54:14 +02:00
|
|
|
LLVMPREFIX ?= llvm-
|
2016-01-20 15:16:45 +01:00
|
|
|
# Apple XCode doesn't prefix its tools with llvm-, but manually installed LLVM
|
|
|
|
# on OSX might have the llvm- prefix, we can't simply test against uname -s.
|
|
|
|
# Test if llvm-ar exists
|
|
|
|
ifeq (,$(shell command -v $(LLVMPREFIX)ar 2>/dev/null))
|
2020-06-10 18:54:14 +02:00
|
|
|
# fall back to system tools
|
|
|
|
LLVMPREFIX :=
|
2016-01-20 15:16:45 +01:00
|
|
|
endif
|
2020-06-10 18:54:14 +02:00
|
|
|
CC = clang
|
|
|
|
CXX = clang++
|
|
|
|
CCAS ?= $(CC)
|
|
|
|
AS = $(LLVMPREFIX)as
|
|
|
|
AR = $(LLVMPREFIX)ar
|
|
|
|
NM = $(LLVMPREFIX)nm
|
2018-01-15 13:51:25 +01:00
|
|
|
# LLVM does have a linker, however, it is not entirely
|
|
|
|
# compatible with GCC. For instance spec files as used in
|
|
|
|
# `makefiles/libc/newlib.mk` are not supported. Therefore
|
|
|
|
# we just use GCC for now.
|
2020-06-10 18:54:14 +02:00
|
|
|
LINK = $(PREFIX)gcc
|
|
|
|
LINKXX = $(PREFIX)g++
|
2015-05-30 12:05:16 +02:00
|
|
|
# objcopy does not have a clear substitute in LLVM, use GNU binutils
|
2020-06-10 18:54:14 +02:00
|
|
|
# OBJCOPY = $(LLVMPREFIX)objcopy
|
|
|
|
_OBJCOPY := $(shell command -v $(PREFIX)objcopy || command -v gobjcopy || command -v objcopy)
|
|
|
|
OBJCOPY ?= $(_OBJCOPY)
|
2017-03-01 11:43:49 +01:00
|
|
|
ifeq ($(OBJCOPY),)
|
2020-06-10 18:54:14 +02:00
|
|
|
$(warning objcopy not found. Hex file will not be created.)
|
|
|
|
OBJCOPY = true
|
2017-03-01 11:43:49 +01:00
|
|
|
endif
|
2019-01-25 16:55:37 +01:00
|
|
|
# Default to the native (g)objdump, helps when using toolchain from docker
|
2020-06-10 18:54:14 +02:00
|
|
|
_OBJDUMP := $(or $(shell command -v $(LLVMPREFIX)objdump || command -v gobjdump),objdump)
|
|
|
|
OBJDUMP ?= $(_OBJDUMP)
|
|
|
|
SIZE = $(LLVMPREFIX)size
|
2015-05-30 12:05:16 +02:00
|
|
|
# LLVM lacks a binutils strip tool as well...
|
|
|
|
#export STRIP = $(LLVMPREFIX)strip
|
2017-10-06 13:51:47 +02:00
|
|
|
# We use GDB for debugging for now, maybe LLDB will be supported in the future.
|
|
|
|
include $(RIOTMAKE)/tools/gdb.inc.mk
|
2015-05-30 12:05:16 +02:00
|
|
|
|
2018-10-15 21:01:26 +02:00
|
|
|
# Include directories from gcc
|
2023-05-19 22:09:56 +02:00
|
|
|
# $1: language <c|c++>
|
2018-10-15 21:01:26 +02:00
|
|
|
#
|
|
|
|
# `realpath` is used instead of `abspath` to support Mingw32 which has issues
|
|
|
|
# with windows formatted gcc directories
|
|
|
|
#
|
|
|
|
# CFLAGS_CPU is used to get the correct multilib include header.
|
|
|
|
gcc_include_dirs = $(realpath \
|
2023-05-19 22:09:56 +02:00
|
|
|
$(shell $(PREFIX)g++ $(CFLAGS_CPU) -v -x $1 -E /dev/null 2>&1 | \
|
2018-10-15 21:01:26 +02:00
|
|
|
sed \
|
|
|
|
-e '1,/\#include <...> search starts here:/d' \
|
|
|
|
-e '/End of search list./,$$d' \
|
|
|
|
-e 's/^ *//')\
|
|
|
|
)
|
2016-01-15 18:21:29 +01:00
|
|
|
|
2018-10-15 21:01:26 +02:00
|
|
|
ifneq (,$(TARGET_ARCH))
|
2021-02-11 17:11:46 +01:00
|
|
|
TARGET_ARCH_LLVM ?= $(TARGET_ARCH)
|
2018-10-15 21:01:26 +02:00
|
|
|
ifeq (,$(CFLAGS_CPU))
|
|
|
|
$(error CFLAGS_CPU must have been defined to use `llvm`.)
|
2017-02-14 20:35:36 +01:00
|
|
|
endif
|
2016-01-15 18:21:29 +01:00
|
|
|
|
2016-12-21 13:54:35 +01:00
|
|
|
# Tell clang to cross compile
|
2021-02-11 17:11:46 +01:00
|
|
|
CFLAGS += -target $(TARGET_ARCH_LLVM)
|
|
|
|
CXXFLAGS += -target $(TARGET_ARCH_LLVM)
|
2018-01-15 13:51:25 +01:00
|
|
|
# We currently don't use LLVM for linking (see comment above).
|
2021-02-11 17:11:46 +01:00
|
|
|
# LINKFLAGS += -target $(TARGET_ARCH_LLVM)
|
2016-01-15 18:21:29 +01:00
|
|
|
|
2018-10-15 21:01:26 +02:00
|
|
|
# Clang on Linux uses GCC's C and C++ headers and libstdc++ (installed with GCC)
|
2016-01-20 15:16:45 +01:00
|
|
|
|
2018-10-15 21:01:26 +02:00
|
|
|
# Extract include directories from GCC
|
|
|
|
GCC_C_INCLUDE_DIRS = $(call gcc_include_dirs,c)
|
|
|
|
GCC_CXX_INCLUDE_DIRS = $(call gcc_include_dirs,c++)
|
2016-01-20 15:16:45 +01:00
|
|
|
|
2018-10-15 21:01:26 +02:00
|
|
|
GCC_C_INCLUDES = $(addprefix -isystem ,$(GCC_C_INCLUDE_DIRS))
|
|
|
|
GCC_CXX_INCLUDES = $(addprefix -isystem ,$(GCC_CXX_INCLUDE_DIRS))
|
2016-01-20 15:16:45 +01:00
|
|
|
|
2018-10-15 21:01:26 +02:00
|
|
|
INCLUDES += $(GCC_C_INCLUDES)
|
|
|
|
CXXINCLUDES += $(GCC_CXX_INCLUDES)
|
2017-02-14 20:35:36 +01:00
|
|
|
endif
|
2019-08-28 19:43:17 +02:00
|
|
|
|
2019-10-09 10:15:47 +02:00
|
|
|
# For bare metal targets the performance penalty of atomic operations being
|
|
|
|
# implemented with library calls is totally insignificant. In case LTO is
|
|
|
|
# is enabled, the overhead compared to manually disabling interrupts is fully
|
|
|
|
# optimized out (unless atomic operations could be grouped together to a single
|
|
|
|
# critical section). So there is - in our use case - no value in having the
|
|
|
|
# warning
|
|
|
|
CFLAGS += -Wno-atomic-alignment
|
|
|
|
|
|
|
|
# For compatibility with older clang versions we also disable warnings on
|
|
|
|
# unsupported warning flags:
|
|
|
|
CFLAGS += -Wno-unknown-warning-option
|
|
|
|
|
2023-05-19 22:11:54 +02:00
|
|
|
# Designated initializers make the code much more readable and are part
|
|
|
|
# of the C standard since C99. C++ with C++20 finally caught up.
|
|
|
|
# Until we switch to that C++ version, let's disable the annoying
|
|
|
|
# warning rather than reducing the code quality for the sake of
|
|
|
|
# strict C++ compatibility of our headers.
|
|
|
|
CXXEXFLAGS += -Wno-c99-designator
|
|
|
|
|
2019-08-28 19:43:17 +02:00
|
|
|
OPTIONAL_CFLAGS_BLACKLIST += -fno-delete-null-pointer-checks
|
|
|
|
OPTIONAL_CFLAGS_BLACKLIST += -Wformat-overflow
|
|
|
|
OPTIONAL_CFLAGS_BLACKLIST += -Wformat-truncation
|
2023-05-21 10:24:14 +02:00
|
|
|
|
|
|
|
LLVM_VERSION := $(shell command -v $(CC) > /dev/null && $(CC) -dumpversion | cut -d . -f 1)
|