2016-03-21 07:36:02 +01:00
|
|
|
ifneq (,$(filter newlib_nano,$(USEMODULE)))
|
|
|
|
# Test if nano.specs is available
|
|
|
|
ifeq ($(shell $(LINK) -specs=nano.specs -E - 2>/dev/null >/dev/null </dev/null ; echo $$?),0)
|
|
|
|
USE_NEWLIB_NANO = 1
|
2016-07-12 19:50:44 +02:00
|
|
|
ifeq ($(shell echo "int main(){} void _exit(int n) {(void)n;while(1);}" | LC_ALL=C $(CC) -xc - -o /dev/null -lc -specs=nano.specs -Wall -Wextra -pedantic 2>&1 | grep -q "use of wchar_t values across objects may fail" ; echo $$?),0)
|
|
|
|
CFLAGS += -fshort-wchar
|
2016-08-29 19:14:01 +02:00
|
|
|
LINKFLAGS += -Wl,--no-wchar-size-warning
|
2016-07-12 19:50:44 +02:00
|
|
|
endif
|
2016-03-21 07:36:02 +01:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2017-10-23 15:49:10 +02:00
|
|
|
ifneq (,$(filter newlib_gnu_source,$(USEMODULE)))
|
|
|
|
CFLAGS += -D_GNU_SOURCE=1
|
|
|
|
endif
|
|
|
|
|
2016-03-21 07:36:02 +01:00
|
|
|
ifeq (1,$(USE_NEWLIB_NANO))
|
|
|
|
export LINKFLAGS += -specs=nano.specs
|
|
|
|
endif
|
|
|
|
|
2017-09-20 12:13:29 +02:00
|
|
|
export LINKFLAGS += -lc
|
2016-03-21 07:36:02 +01:00
|
|
|
|
2015-05-30 12:05:16 +02:00
|
|
|
# Search for Newlib include directories
|
|
|
|
|
2018-06-21 14:20:31 +02:00
|
|
|
# Try to search for newlib in the standard search path of the compiler for includes
|
|
|
|
ifeq (,$(NEWLIB_INCLUDE_DIR))
|
|
|
|
COMPILER_INCLUDE_PATHS := $(shell $(PREFIX)gcc -v -x c -E /dev/null 2>&1 | grep '^\s' | tr -d '\n')
|
|
|
|
NEWLIB_INCLUDE_DIR := $(firstword $(dir $(wildcard $(addsuffix /newlib.h, $(COMPILER_INCLUDE_PATHS)))))
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq (,$(NEWLIB_INCLUDE_DIR))
|
2015-05-30 12:05:16 +02:00
|
|
|
# Since Clang is not installed as a separate instance for each crossdev target
|
|
|
|
# we need to tell it where to look for platform specific includes (Newlib
|
|
|
|
# headers instead of Linux/Glibc headers.)
|
|
|
|
# On GCC this is done when building the cross compiler toolchain so we do not
|
|
|
|
# actually need to specify the include paths for system includes.
|
|
|
|
# Ubuntu gcc-arm-embedded toolchain (https://launchpad.net/gcc-arm-embedded)
|
|
|
|
# places newlib headers in several places, but the primary source seem to be
|
|
|
|
# /etc/alternatives/gcc-arm-none-eabi-include
|
|
|
|
# Gentoo Linux crossdev place the newlib headers in /usr/arm-none-eabi/include
|
|
|
|
# Arch Linux also place the newlib headers in /usr/arm-none-eabi/include
|
|
|
|
# Ubuntu seem to put a copy of the newlib headers in the same place as
|
|
|
|
# Gentoo crossdev, but we prefer to look at /etc/alternatives first.
|
|
|
|
# On OSX, newlib includes are possibly located in
|
2016-03-22 14:46:16 +01:00
|
|
|
# /usr/local/opt/arm-none-eabi*/arm-none-eabi/include or /usr/local/opt/gcc-arm/arm-none-eabi/include
|
2018-06-21 14:20:31 +02:00
|
|
|
NEWLIB_INCLUDE_PATTERNS ?= \
|
|
|
|
/etc/alternatives/gcc-$(TARGET_ARCH)-include \
|
|
|
|
/usr/$(TARGET_ARCH)/include \
|
|
|
|
/usr/local/opt/$(TARGET_ARCH)*/$(TARGET_ARCH)/include \
|
|
|
|
/usr/local/opt/gcc-*/$(TARGET_ARCH)/include \
|
|
|
|
#
|
2015-05-30 12:05:16 +02: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)
|
2018-06-21 14:20:31 +02:00
|
|
|
NEWLIB_INCLUDE_DIR ?= $(firstword $(dir $(wildcard $(addsuffix /newlib.h, $(NEWLIB_INCLUDE_PATTERNS)))))
|
|
|
|
endif
|
2015-05-30 12:05:16 +02:00
|
|
|
|
2016-01-19 14:45:21 +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
|
2016-03-21 07:36:02 +01:00
|
|
|
ifeq (,$(NEWLIB_INCLUDE_DIR))
|
2017-03-01 10:03:41 +01:00
|
|
|
NEWLIB_INCLUDE_DIR := $(abspath $(wildcard $(dir $(shell command -v $(PREFIX)gcc 2>/dev/null))/../$(TARGET_ARCH)/include))
|
2016-03-21 07:36:02 +01:00
|
|
|
endif
|
2016-12-20 17:33:00 +01:00
|
|
|
|
2016-12-21 13:10:54 +01:00
|
|
|
ifeq ($(TOOLCHAIN),llvm)
|
|
|
|
# A cross GCC already knows the target libc include path (build-in at compile time)
|
|
|
|
# but Clang, when cross-compiling, needs to be told where to find the headers
|
|
|
|
# for the system being built.
|
|
|
|
# We also add -nostdinc to avoid including the host system headers by mistake
|
|
|
|
# in case some header is missing from the cross tool chain
|
|
|
|
NEWLIB_INCLUDES := -isystem $(NEWLIB_INCLUDE_DIR) -nostdinc
|
|
|
|
NEWLIB_INCLUDES += $(addprefix -isystem ,$(abspath $(wildcard $(dir $(NEWLIB_INCLUDE_DIR))/usr/include)))
|
|
|
|
endif
|
2016-12-20 17:33:00 +01:00
|
|
|
|
|
|
|
ifeq (1,$(USE_NEWLIB_NANO))
|
2018-06-21 14:20:31 +02:00
|
|
|
NEWLIB_NANO_INCLUDE_DIR ?= $(firstword $(wildcard $(NEWLIB_INCLUDE_DIR)newlib-nano \
|
|
|
|
$(NEWLIB_INCLUDE_DIR)newlib/nano \
|
|
|
|
$(NEWLIB_INCLUDE_DIR)nano))
|
2016-03-21 07:36:02 +01:00
|
|
|
# newlib-nano overrides newlib.h and its include dir should therefore go before
|
2016-12-21 13:10:54 +01:00
|
|
|
# the regular system include dirs.
|
|
|
|
INCLUDES := -isystem $(NEWLIB_NANO_INCLUDE_DIR) $(INCLUDES)
|
2016-01-19 14:45:21 +01:00
|
|
|
endif
|
|
|
|
|
2017-02-14 20:35:12 +01:00
|
|
|
# Newlib includes should go before GCC includes. This is especially important
|
|
|
|
# when using Clang, because Clang will yield compilation errors on some GCC-
|
|
|
|
# bundled headers. Clang compatible versions of those headers are already
|
|
|
|
# provided by Newlib, so placing this directory first will eliminate those problems.
|
|
|
|
# The above problem was observed with LLVM 3.9.1 when building against GCC 6.3.0 headers.
|
|
|
|
export INCLUDES := $(NEWLIB_INCLUDES) $(INCLUDES)
|