2015-05-30 12:05:16 +02:00
|
|
|
export 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))
|
|
|
|
# fall back to system tools
|
|
|
|
export LLVMPREFIX :=
|
|
|
|
endif
|
2015-05-30 12:05:16 +02:00
|
|
|
export CC = clang
|
|
|
|
export CXX = clang++
|
2017-03-01 11:24:11 +01:00
|
|
|
export CCAS ?= $(CC)
|
2015-05-30 12:05:16 +02:00
|
|
|
export AS = $(LLVMPREFIX)as
|
|
|
|
export AR = $(LLVMPREFIX)ar
|
|
|
|
export 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.
|
|
|
|
export LINK = $(PREFIX)gcc
|
2015-05-30 12:05:16 +02:00
|
|
|
# objcopy does not have a clear substitute in LLVM, use GNU binutils
|
|
|
|
#export OBJCOPY = $(LLVMPREFIX)objcopy
|
2017-03-01 11:43:49 +01:00
|
|
|
export OBJCOPY ?= $(shell command -v $(PREFIX)objcopy gobjcopy objcopy | head -n 1)
|
|
|
|
ifeq ($(OBJCOPY),)
|
|
|
|
$(warning objcopy not found. Hex file will not be created.)
|
|
|
|
export OBJCOPY = true
|
|
|
|
endif
|
2015-05-30 12:05:16 +02:00
|
|
|
export OBJDUMP = $(LLVMPREFIX)objdump
|
|
|
|
export SIZE = $(LLVMPREFIX)size
|
|
|
|
# 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
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
ifneq (,$(TARGET_ARCH))
|
|
|
|
# Clang on Linux uses GCC's C++ headers and libstdc++ (installed with GCC)
|
|
|
|
# Ubuntu and Debian use /etc/alternatives/gcc-$(TARGET_ARCH)-include/c++/$(GCC_VERSION)
|
|
|
|
# Arch uses /usr/$(TARGET_ARCH)/include/c++/$(GCC_VERSION)
|
|
|
|
# Gentoo uses /usr/lib/gcc/$(TARGET_ARCH)/$(GCC_VERSION)/include/g++-v5
|
|
|
|
GCC_CXX_INCLUDE_PATTERNS ?= \
|
2016-01-15 18:21:29 +01:00
|
|
|
/etc/alternatives/gcc-$(TARGET_ARCH)-include/c++/*/ \
|
|
|
|
/usr/$(TARGET_ARCH)/include/c++/*/ \
|
2016-12-21 13:07:57 +01:00
|
|
|
/usr/lib/gcc/$(TARGET_ARCH)/*/include/g++-v8 \
|
|
|
|
/usr/lib/gcc/$(TARGET_ARCH)/*/include/g++-v7 \
|
|
|
|
/usr/lib/gcc/$(TARGET_ARCH)/*/include/g++-v6 \
|
2016-01-15 18:21:29 +01:00
|
|
|
/usr/lib/gcc/$(TARGET_ARCH)/*/include/g++-v5 \
|
|
|
|
#
|
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
# Try to find the proper multilib directory using GCC, this may fail if a cross-
|
|
|
|
# GCC is not installed.
|
|
|
|
ifeq ($(GCC_MULTI_DIR),)
|
|
|
|
GCC_MULTI_DIR := $(shell $(PREFIX)gcc $(CFLAGS) -print-multi-directory 2>/dev/null)
|
|
|
|
endif
|
2016-01-15 18:21:29 +01:00
|
|
|
|
2016-12-21 13:54:35 +01:00
|
|
|
# Tell clang to cross compile
|
|
|
|
export CFLAGS += -target $(TARGET_ARCH)
|
|
|
|
export CXXFLAGS += -target $(TARGET_ARCH)
|
2018-01-15 13:51:25 +01:00
|
|
|
# We currently don't use LLVM for linking (see comment above).
|
|
|
|
#export LINKFLAGS += -target $(TARGET_ARCH)
|
2016-01-15 18:21:29 +01:00
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
# Use the wildcard Makefile function to search for existing directories matching
|
|
|
|
# the patterns above. We use the -isystem gcc/clang argument to add the include
|
|
|
|
# directories as system include directories, which means they will not be
|
|
|
|
# searched until after all the project specific include directories (-I/path)
|
|
|
|
# We sort the list of found directories and take the last one, it will likely be
|
|
|
|
# the most recent GCC version. This avoids using old headers left over from
|
|
|
|
# previous tool chain installations.
|
|
|
|
GCC_CXX_INCLUDES ?= \
|
|
|
|
$(addprefix \
|
|
|
|
-isystem $(firstword \
|
|
|
|
$(foreach pat, $(GCC_CXX_INCLUDE_PATTERNS), $(lastword $(sort $(wildcard $(pat)))))), \
|
|
|
|
/. /$(TARGET_ARCH)/$(GCC_MULTI_DIR) /backward \
|
|
|
|
)
|
2016-01-15 18:21:29 +01:00
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
# If nothing was found we will try to fall back to searching for a cross-gcc in
|
|
|
|
# the current PATH and use a relative path for the includes
|
|
|
|
ifeq (,$(GCC_CXX_INCLUDES))
|
|
|
|
GCC_CXX_INCLUDES := $(addprefix -isystem ,$(wildcard $(dir $(shell which $(PREFIX)gcc))../$(TARGET_TRIPLE)/include))
|
|
|
|
endif
|
2016-01-20 15:16:45 +01:00
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
# Pass the includes to the C++ compilation rule in Makefile.base
|
|
|
|
export CXXINCLUDES += $(GCC_CXX_INCLUDES)
|
2016-01-20 15:16:45 +01:00
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
# Some C headers (e.g. limits.h) are located with the GCC libraries
|
|
|
|
GCC_C_INCLUDE_PATTERNS ?= \
|
|
|
|
/usr/lib/gcc/$(TARGET_TRIPLE)/*/ \
|
|
|
|
#
|
2016-01-20 15:16:45 +01:00
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
GCC_C_INCLUDES ?= \
|
|
|
|
$(addprefix -isystem ,$(wildcard $(addprefix \
|
|
|
|
$(lastword $(sort \
|
|
|
|
$(foreach pat, $(GCC_C_INCLUDE_PATTERNS), $(wildcard $(pat))))), \
|
|
|
|
include include-fixed) \
|
|
|
|
))
|
2016-01-20 15:16:45 +01:00
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
# If nothing was found we will try to fall back to searching for the libgcc used
|
|
|
|
# by an installed cross-GCC and use its headers.
|
|
|
|
ifeq (,$(GCC_C_INCLUDES))
|
|
|
|
GCC_C_INCLUDES := $(addprefix -isystem ,$(wildcard $(addprefix $(dir $(shell $(PREFIX)gcc -print-libgcc-file-name)), include include-fixed)))
|
|
|
|
endif
|
2016-01-20 15:16:45 +01:00
|
|
|
|
2017-02-14 20:35:36 +01:00
|
|
|
export INCLUDES += $(GCC_C_INCLUDES)
|
|
|
|
endif
|