2018-04-12 17:48:07 +02:00
|
|
|
export NATIVEINCLUDES += -DNATIVE_INCLUDES
|
|
|
|
export NATIVEINCLUDES += -I$(RIOTBOARD)/$(BOARD)/include/
|
|
|
|
export NATIVEINCLUDES += -I$(RIOTBASE)/core/include/
|
|
|
|
export NATIVEINCLUDES += -I$(RIOTBASE)/drivers/include/
|
2013-03-19 22:02:22 +01:00
|
|
|
|
2018-04-12 17:48:07 +02:00
|
|
|
export CPU = native
|
2018-02-27 18:36:53 +01:00
|
|
|
|
2016-03-08 14:19:52 +01:00
|
|
|
USEMODULE += native-drivers
|
|
|
|
|
2014-02-01 13:16:58 +01:00
|
|
|
# toolchain:
|
|
|
|
export PREFIX =
|
|
|
|
export CC ?= $(PREFIX)gcc
|
2014-06-25 03:17:20 +02:00
|
|
|
export CXX ?= $(PREFIX)g++
|
2017-09-22 14:52:12 +02:00
|
|
|
|
2015-07-14 09:34:58 +02:00
|
|
|
ifeq ($(LTO),1)
|
2017-09-22 14:52:12 +02:00
|
|
|
export AR = $(PREFIX)gcc-ar
|
2015-07-14 09:34:58 +02:00
|
|
|
else
|
2017-09-22 14:52:12 +02:00
|
|
|
export AR = $(PREFIX)ar
|
2015-07-14 09:34:58 +02:00
|
|
|
endif
|
2017-09-22 14:52:12 +02:00
|
|
|
|
2014-04-20 07:26:12 +02:00
|
|
|
export AS ?= $(PREFIX)as
|
|
|
|
export LINK ?= $(PREFIX)gcc
|
|
|
|
export SIZE ?= $(PREFIX)size
|
2017-09-22 14:52:12 +02:00
|
|
|
|
2014-11-13 16:00:52 +01:00
|
|
|
ifneq ($(shell uname -s),Darwin)
|
2017-09-22 14:52:12 +02:00
|
|
|
export OBJCOPY ?= $(PREFIX)objcopy
|
2014-11-28 17:35:14 +01:00
|
|
|
else
|
2017-09-22 14:52:12 +02:00
|
|
|
ifeq (0,$(shell which gobjcopy 2>&1 > /dev/null ; echo $$?))
|
|
|
|
export OBJCOPY ?= gobjcopy
|
|
|
|
else
|
2018-03-27 11:55:08 +02:00
|
|
|
# If gobjcopy is not available, just do nothing. The hexfile
|
2017-09-22 14:52:12 +02:00
|
|
|
# is not used for native anyways.
|
2018-03-27 11:55:08 +02:00
|
|
|
export OBJCOPY ?= true
|
2017-09-22 14:52:12 +02:00
|
|
|
endif
|
2014-11-13 16:00:52 +01:00
|
|
|
endif
|
2013-03-19 22:02:22 +01:00
|
|
|
|
2016-10-27 07:50:16 +02:00
|
|
|
ifeq ($(shell uname -s),Darwin)
|
2017-09-22 14:52:12 +02:00
|
|
|
export DEBUGGER ?= lldb
|
2016-10-27 07:50:16 +02:00
|
|
|
else
|
2017-09-22 14:52:12 +02:00
|
|
|
export DEBUGGER ?= gdb
|
2016-10-27 07:50:16 +02:00
|
|
|
endif
|
2017-09-22 14:52:12 +02:00
|
|
|
|
2019-02-25 16:46:44 +01:00
|
|
|
TERMPROG ?= $(ELFFILE)
|
2014-02-01 13:16:58 +01:00
|
|
|
export FLASHER = true
|
2013-12-02 11:00:43 +01:00
|
|
|
export VALGRIND ?= valgrind
|
2014-03-14 12:56:44 +01:00
|
|
|
export CGANNOTATE ?= cg_annotate
|
|
|
|
export GPROF ?= gprof
|
2013-03-19 22:02:22 +01:00
|
|
|
|
2014-08-13 07:47:00 +02:00
|
|
|
# basic cflags:
|
2018-07-11 14:57:22 +02:00
|
|
|
export CFLAGS += -Wall -Wextra -pedantic
|
|
|
|
# default std set to gnu99 of not overwritten by user
|
|
|
|
ifeq (,$(filter -std=%, $(CFLAGS)))
|
|
|
|
export CFLAGS += -std=gnu99
|
|
|
|
endif
|
2017-09-22 14:52:12 +02:00
|
|
|
|
2014-08-29 18:30:37 +02:00
|
|
|
ifeq ($(shell uname -m),x86_64)
|
2017-09-22 14:52:12 +02:00
|
|
|
export CFLAGS += -m32
|
2014-08-29 18:30:37 +02:00
|
|
|
endif
|
2014-08-13 07:47:00 +02:00
|
|
|
ifneq (,$(filter -DDEVELHELP,$(CFLAGS)))
|
2017-09-22 14:52:12 +02:00
|
|
|
export CFLAGS += -fstack-protector-all
|
2014-08-13 07:47:00 +02:00
|
|
|
endif
|
2014-04-10 14:58:12 +02:00
|
|
|
ifeq ($(shell uname -s),FreeBSD)
|
2017-09-22 14:52:12 +02:00
|
|
|
ifeq ($(shell uname -m),amd64)
|
|
|
|
export CFLAGS += -m32 -DCOMPAT_32BIT -B/usr/lib32
|
|
|
|
endif
|
2014-04-10 14:58:12 +02:00
|
|
|
endif
|
2015-07-14 13:25:36 +02:00
|
|
|
ifeq ($(shell uname -s),Darwin)
|
2017-09-22 14:52:12 +02:00
|
|
|
export CFLAGS += -Wno-deprecated-declarations
|
2015-07-14 13:25:36 +02:00
|
|
|
endif
|
2014-05-09 12:23:34 +02:00
|
|
|
|
2014-06-25 03:17:20 +02:00
|
|
|
# unwanted (CXXUWFLAGS) and extra (CXXEXFLAGS) flags for c++
|
|
|
|
export CXXUWFLAGS +=
|
|
|
|
export CXXEXFLAGS +=
|
|
|
|
|
2014-08-29 18:30:37 +02:00
|
|
|
ifeq ($(shell uname -m),x86_64)
|
2017-09-22 14:52:12 +02:00
|
|
|
export LINKFLAGS += -m32
|
2014-08-29 18:30:37 +02:00
|
|
|
endif
|
2014-04-10 14:58:12 +02:00
|
|
|
ifeq ($(shell uname -s),FreeBSD)
|
2017-09-22 14:52:12 +02:00
|
|
|
ifeq ($(shell uname -m),amd64)
|
|
|
|
export LINKFLAGS += -m32 -DCOMPAT_32BIT -L/usr/lib32 -B/usr/lib32
|
|
|
|
endif
|
|
|
|
export LINKFLAGS += -L $(BINDIR)
|
2014-04-10 14:58:12 +02:00
|
|
|
else
|
2017-09-22 14:52:12 +02:00
|
|
|
export LINKFLAGS += -ldl
|
2014-04-10 14:58:12 +02:00
|
|
|
endif
|
2014-05-09 12:23:34 +02:00
|
|
|
|
2015-07-14 13:13:13 +02:00
|
|
|
# clean up unused functions
|
|
|
|
export CFLAGS += -ffunction-sections -fdata-sections
|
2016-09-01 09:59:10 +02:00
|
|
|
ifeq ($(shell uname -s),Darwin)
|
2017-09-22 14:52:12 +02:00
|
|
|
export LINKFLAGS += -Wl,-dead_strip
|
2016-09-01 09:59:10 +02:00
|
|
|
else
|
2017-09-22 14:52:12 +02:00
|
|
|
export LINKFLAGS += -Wl,--gc-sections
|
2016-09-01 09:59:10 +02:00
|
|
|
endif
|
|
|
|
export LINKFLAGS += -ffunction-sections
|
2015-07-14 13:13:13 +02:00
|
|
|
|
2014-10-21 19:48:22 +02:00
|
|
|
# set the tap interface for term/valgrind
|
2016-10-24 12:05:10 +02:00
|
|
|
ifneq (,$(filter netdev_default gnrc_netdev_default,$(USEMODULE)))
|
2017-09-22 14:52:12 +02:00
|
|
|
export PORT ?= tap0
|
2014-10-21 19:48:22 +02:00
|
|
|
else
|
2017-09-22 14:52:12 +02:00
|
|
|
export PORT =
|
2014-10-21 19:48:22 +02:00
|
|
|
endif
|
|
|
|
|
2019-02-25 16:46:44 +01:00
|
|
|
TERMFLAGS := $(PORT) $(TERMFLAGS)
|
2014-10-21 19:48:22 +02:00
|
|
|
|
2014-02-01 13:16:58 +01:00
|
|
|
export ASFLAGS =
|
2016-10-25 09:31:40 +02:00
|
|
|
ifeq ($(shell basename $(DEBUGGER)),lldb)
|
2018-01-31 11:00:22 +01:00
|
|
|
export DEBUGGER_FLAGS = -- $(ELFFILE) $(TERMFLAGS)
|
2016-10-25 09:31:40 +02:00
|
|
|
else
|
2018-01-31 11:00:22 +01:00
|
|
|
export DEBUGGER_FLAGS = -q --args $(ELFFILE) $(TERMFLAGS)
|
2016-10-25 09:31:40 +02:00
|
|
|
endif
|
2014-08-22 20:05:43 +02:00
|
|
|
term-valgrind: export VALGRIND_FLAGS ?= \
|
2016-06-01 22:33:33 +02:00
|
|
|
--leak-check=full \
|
2014-08-22 20:05:43 +02:00
|
|
|
--track-origins=yes \
|
|
|
|
--fullpath-after=$(RIOTBASE)/ \
|
|
|
|
--read-var-info=yes
|
2016-01-26 17:38:15 +01:00
|
|
|
debug-valgrind-server: export VALGRIND_FLAGS ?= --vgdb=yes --vgdb-error=0 -v \
|
2018-03-22 16:20:19 +01:00
|
|
|
--leak-check=full --track-origins=yes --fullpath-after=$(RIOTBASE) \
|
2016-01-26 17:38:15 +01:00
|
|
|
--read-var-info=yes
|
2014-03-14 12:48:19 +01:00
|
|
|
term-cachegrind: export CACHEGRIND_FLAGS += --tool=cachegrind
|
2019-02-25 16:46:44 +01:00
|
|
|
term-gprof: TERMPROG = GMON_OUT_PREFIX=gmon.out $(ELFFILE)
|
2019-01-26 13:33:34 +01:00
|
|
|
all-valgrind: export CFLAGS += -DHAVE_VALGRIND_H -g3
|
2018-04-12 17:48:07 +02:00
|
|
|
all-valgrind: export NATIVEINCLUDES += $(shell pkg-config valgrind --cflags)
|
2019-01-26 13:33:34 +01:00
|
|
|
all-debug: export CFLAGS += -g3
|
|
|
|
all-cachegrind: export CFLAGS += -g3
|
2014-03-01 16:48:36 +01:00
|
|
|
all-gprof: export CFLAGS += -pg
|
|
|
|
all-gprof: export LINKFLAGS += -pg
|
2019-01-26 13:33:34 +01:00
|
|
|
all-asan: export CFLAGS += -fsanitize=address -fno-omit-frame-pointer -g3
|
2015-07-07 14:37:56 +02:00
|
|
|
all-asan: export CFLAGS += -DNATIVE_IN_CALLOC
|
2019-01-26 13:33:34 +01:00
|
|
|
all-asan: export LINKFLAGS += -fsanitize=address -fno-omit-frame-pointer -g3
|
2014-02-27 10:30:30 +01:00
|
|
|
|
2018-04-12 17:48:07 +02:00
|
|
|
export INCLUDES += $(NATIVEINCLUDES)
|
|
|
|
|
2016-11-18 13:40:47 +01:00
|
|
|
export CFLAGS += -DDEBUG_ASSERT_VERBOSE
|
|
|
|
|
2014-12-09 12:22:24 +01:00
|
|
|
# workaround for https://gcc.gnu.org/bugzilla/show_bug.cgi?id=52624
|
|
|
|
ifneq ($(shell gcc --version | head -1 | grep -E ' (4.6|4.7)'),)
|
2017-09-22 14:52:12 +02:00
|
|
|
export CFLAGS += -DHAVE_NO_BUILTIN_BSWAP16
|
2014-12-09 12:22:24 +01:00
|
|
|
endif
|
|
|
|
|
2014-02-01 15:39:16 +01:00
|
|
|
# backward compatability with glibc <= 2.17 for native
|
|
|
|
ifeq ($(CPU),native)
|
2017-09-22 14:52:12 +02:00
|
|
|
ifeq ($(shell uname -s),Linux)
|
|
|
|
ifeq ($(shell ldd --version | awk '/^ldd/{if ($$NF < 2.17) {print "yes"} else {print "no"} }'),yes)
|
|
|
|
LINKFLAGS += -lrt
|
|
|
|
endif
|
|
|
|
endif
|
2014-02-01 15:39:16 +01:00
|
|
|
endif
|
|
|
|
|
|
|
|
# clumsy way to enable building native on osx:
|
|
|
|
BUILDOSXNATIVE = 0
|
|
|
|
ifeq ($(CPU),native)
|
2017-09-22 14:52:12 +02:00
|
|
|
ifeq ($(shell uname -s),Darwin)
|
|
|
|
BUILDOSXNATIVE = 1
|
|
|
|
endif
|
2014-02-01 15:39:16 +01:00
|
|
|
endif
|
|
|
|
|
2013-12-02 11:00:43 +01:00
|
|
|
all: # do not override first target
|
|
|
|
|
2014-04-22 16:53:08 +02:00
|
|
|
all-debug: all
|
|
|
|
|
2014-03-01 16:48:36 +01:00
|
|
|
all-gprof: all
|
2014-02-26 10:43:07 +01:00
|
|
|
|
2015-07-07 14:37:56 +02:00
|
|
|
all-asan: all
|
|
|
|
|
2013-12-02 11:00:43 +01:00
|
|
|
all-valgrind: all
|
|
|
|
|
2014-03-14 12:48:19 +01:00
|
|
|
all-cachegrind: all
|
|
|
|
|
|
|
|
term-valgrind:
|
2018-01-31 11:00:22 +01:00
|
|
|
$(VALGRIND) $(VALGRIND_FLAGS) $(ELFFILE) $(PORT)
|
2014-02-26 10:43:07 +01:00
|
|
|
|
2016-01-26 17:38:15 +01:00
|
|
|
debug-valgrind-server:
|
2018-01-31 11:00:22 +01:00
|
|
|
$(VALGRIND) $(VALGRIND_FLAGS) $(ELFFILE) $(PORT)
|
2016-01-26 17:38:15 +01:00
|
|
|
|
|
|
|
debug-valgrind:
|
2018-03-22 16:20:19 +01:00
|
|
|
$(eval VALGRIND_PID ?= $(shell pgrep -n memcheck-x86-li -u $(USER) | cut -d" " -f1))
|
|
|
|
$(eval DEBUGGER_FLAGS := -ex "target remote | vgdb --pid=$(VALGRIND_PID)" $(DEBUGGER_FLAGS))
|
2016-01-26 17:38:15 +01:00
|
|
|
$(DEBUGGER) $(DEBUGGER_FLAGS)
|
|
|
|
|
2014-03-14 12:48:19 +01:00
|
|
|
term-cachegrind:
|
2018-01-31 11:00:22 +01:00
|
|
|
$(VALGRIND) $(CACHEGRIND_FLAGS) $(ELFFILE) $(PORT)
|
2014-03-01 16:48:36 +01:00
|
|
|
|
2014-03-14 12:48:19 +01:00
|
|
|
term-gprof: term
|
|
|
|
|
|
|
|
eval-gprof:
|
2018-01-31 11:00:22 +01:00
|
|
|
$(GPROF) $(ELFFILE) $(shell ls -rt gmon.out* | tail -1)
|
2014-03-14 12:48:19 +01:00
|
|
|
|
|
|
|
eval-cachegrind:
|
2014-03-14 12:56:44 +01:00
|
|
|
$(CGANNOTATE) $(shell ls -rt cachegrind.out* | tail -1)
|
2014-02-15 12:31:43 +01:00
|
|
|
|
2016-10-18 23:27:59 +02:00
|
|
|
export UNDEF += $(BINDIR)/cpu/startup.o
|