mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge pull request #5119 from gebart/pr/newlib-nano-pmod
newlib: Introduce newlib_nano pseudomodule
This commit is contained in:
commit
4fad0394ca
@ -290,6 +290,10 @@ ifneq (,$(filter gnrc_pktdump,$(USEMODULE)))
|
||||
USEMODULE += od
|
||||
endif
|
||||
|
||||
ifneq (,$(filter newlib_nano,$(USEMODULE)))
|
||||
USEMODULE += newlib
|
||||
endif
|
||||
|
||||
ifneq (,$(filter newlib,$(USEMODULE)))
|
||||
# allow custom newlib syscalls implementations by adding
|
||||
# newlib_syscalls_XXX to USEMODULE
|
||||
|
@ -17,6 +17,7 @@ PSEUDOMODULES += gnrc_pktbuf
|
||||
PSEUDOMODULES += log
|
||||
PSEUDOMODULES += log_printfnoformat
|
||||
PSEUDOMODULES += newlib
|
||||
PSEUDOMODULES += newlib_nano
|
||||
PSEUDOMODULES += pktqueue
|
||||
PSEUDOMODULES += schedstatistics
|
||||
PSEUDOMODULES += netif
|
||||
|
@ -29,10 +29,7 @@ export LINKFLAGS += $(CFLAGS_CPU) $(CFLAGS_DBG) $(CFLAGS_OPT) -static -lgcc -nos
|
||||
export LINKFLAGS += -Wl,--gc-sections
|
||||
|
||||
# use the nano-specs of Newlib when available
|
||||
ifeq ($(shell $(LINK) -specs=nano.specs -E - 2>/dev/null >/dev/null </dev/null ; echo $$?),0)
|
||||
export CFLAGS += -specs=nano.specs
|
||||
export LINKFLAGS += -specs=nano.specs -lc -lnosys
|
||||
endif
|
||||
USEMODULE += newlib_nano
|
||||
|
||||
ifeq ($(PORT),)
|
||||
export PORT = /dev/ttyUSB0
|
||||
|
@ -94,10 +94,7 @@ endif
|
||||
include $(RIOTCPU)/cortexm_common/Makefile.include
|
||||
|
||||
# use the nano-specs of Newlib when available
|
||||
ifeq ($(shell $(LINK) -specs=nano.specs -E - 2>/dev/null >/dev/null </dev/null ; echo $$?),0)
|
||||
export CFLAGS += -specs=nano.specs
|
||||
export LINKFLAGS += -specs=nano.specs -lc -lnosys
|
||||
endif
|
||||
USEMODULE += newlib_nano
|
||||
|
||||
# Avoid overriding the default rule:
|
||||
all:
|
||||
|
@ -1,5 +1,18 @@
|
||||
UNDEF := $(BINDIR)newlib_syscalls_default/syscalls.o $(UNDEF)
|
||||
|
||||
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
|
||||
endif
|
||||
endif
|
||||
|
||||
ifeq (1,$(USE_NEWLIB_NANO))
|
||||
export LINKFLAGS += -specs=nano.specs
|
||||
endif
|
||||
|
||||
export LINKFLAGS += -lc -lnosys
|
||||
|
||||
# Search for Newlib include directories
|
||||
|
||||
# Since Clang is not installed as a separate instance for each crossdev target
|
||||
@ -25,15 +38,21 @@ NEWLIB_INCLUDE_PATTERNS ?= \
|
||||
# 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)
|
||||
NEWLIB_INCLUDES ?= \
|
||||
$(foreach dir, \
|
||||
$(foreach pat, $(NEWLIB_INCLUDE_PATTERNS), $(wildcard $(pat))), \
|
||||
-isystem $(dir))
|
||||
NEWLIB_INCLUDE_DIR ?= $(firstword $(wildcard $(NEWLIB_INCLUDE_PATTERNS)))
|
||||
|
||||
# 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 (,$(NEWLIB_INCLUDES))
|
||||
NEWLIB_INCLUDES := $(addprefix -isystem ,$(wildcard $(dir $(shell which $(PREFIX)gcc))../$(TARGET_ARCH)/include))
|
||||
ifeq (,$(NEWLIB_INCLUDE_DIR))
|
||||
NEWLIB_INCLUDE_DIR := $(abspath $(wildcard $(dir $(shell which $(PREFIX)gcc))../$(TARGET_ARCH)/include))
|
||||
endif
|
||||
|
||||
NEWLIB_INCLUDES := -isystem $(NEWLIB_INCLUDE_DIR)
|
||||
|
||||
ifeq (1,$(USE_NEWLIB_NANO))
|
||||
NEWLIB_NANO_INCLUDE_DIR ?= $(NEWLIB_INCLUDE_DIR)/nano
|
||||
# newlib-nano overrides newlib.h and its include dir should therefore go before
|
||||
# the regular newlib include dir.
|
||||
NEWLIB_INCLUDES := -isystem $(NEWLIB_NANO_INCLUDE_DIR) $(NEWLIB_INCLUDES)
|
||||
endif
|
||||
|
||||
# Newlib includes should go before GCC includes.
|
||||
|
Loading…
Reference in New Issue
Block a user