gateway: refactor olsr_set_inet_gateway
[olsrd.git] / Makefile.inc
index 401ade0..9ef9881 100644 (file)
@@ -5,15 +5,34 @@
 #
 
 # activate debugging with 1 or deactivate with 0
-DEBUG ?= 0
+DEBUG ?= 1
 
 # compile OLSR_PRINTF out
 NO_DEBUG_MESSAGES ?= 0
 
+# the optimize option to be set for gcc
+OPTIMIZE ?= 
+
 # enable mudflap with 1 or deactivate with 0
 # you need a recent enough gcc and the libmudflap installed
 MUDFLAP ?= 0
 
+# shows full compiler/linker calls if activated
+VERBOSE ?= 0
+
+ifeq ($(VERBOSE),0)
+MAKECMDPREFIX = @
+else
+MAKECMDPREFIX =
+endif
+
+# OS detection
+ifeq ($(OS),Windows_NT)
+OS := win32
+endif
+ifeq ($(OS),)
+OS := $(shell sh $(TOPDIR)/make/guess_os.sh)
+endif
 
 ######################
 #
@@ -21,13 +40,12 @@ MUDFLAP ?= 0
 #
 
 # programs
-#CCACHE ?=       $(shell IFS=:; for i in $$PATH;do test -x "$$i/ccache" && echo "$$i/ccache" && break; done)
-#ifeq ($(origin CC),default)
-#CC =          $(CCACHE) gcc
-#else
-#CC ?=                 $(CCACHE) gcc
-#endif
-CC=/home/markus/freifunk/whiterussian/openwrt/staging_dir_mipsel/bin/mipsel-linux-uclibc-gcc
+CCACHE ?=       $(shell IFS=:; for i in $$PATH;do test -x "$$i/ccache" && echo "$$i/ccache" && break; done)
+ifeq ($(origin CC),default)
+CC =           $(CCACHE) gcc
+else
+CC ?=          $(CCACHE) gcc
+endif
 ifeq ($(DEBUG),0)
 STRIP ?=       strip
 else
@@ -38,15 +56,21 @@ FLEX ?=             flex
 TAGCMD ?=      etags
 
 # target directories and names
-DESTDIR ?=
-SBINDIR ?= $(DESTDIR)/usr/sbin
-ETCDIR  ?= $(DESTDIR)/etc
-LIBDIR  ?= $(DESTDIR)/usr/lib
-DOCDIR  ?= $(DESTDIR)/usr/share/doc
-MANDIR  ?= $(DESTDIR)/usr/share/man
-EXENAME ?= olsrd
-CFGNAME ?= $(EXENAME).conf
-CFGFILE ?= $(ETCDIR)/$(CFGNAME)
+DESTDIR  ?=
+ETCDIR   ?= $(DESTDIR)/etc
+USRDIR   ?= $(DESTDIR)/usr
+INCLUDEDIR ?= $(DESTDIR)/usr/include
+LIBDIR   ?= $(USRDIR)/lib
+SBINDIR  ?= $(USRDIR)/sbin
+SHAREDIR ?= $(USRDIR)/share
+DOCDIR   ?= $(SHAREDIR)/doc
+MANDIR   ?= $(SHAREDIR)/man
+EXENAME  ?= olsrd
+CFGNAME  ?= $(EXENAME).conf
+CFGFILE  ?= $(ETCDIR)/$(CFGNAME)
+
+DOCDIR_OLSRD ?= $(DOCDIR)/$(EXENAME)
+
 
 CPPFLAGS =     -Isrc
 ifneq ($(TOPDIR),.)
@@ -74,10 +98,25 @@ WARNINGS += -Wwrite-strings
 WARNINGS +=    -Wbad-function-cast
 WARNINGS +=    -Wpointer-arith
 WARNINGS +=    -Wcast-qual
-# the following 5 do not work yet and need more work on it
-#WARNINGS +=   -Wshadow
-#WARNINGS +=   -Wpointer-arith
-#WARNINGS +=   -Wcast-align
+WARNINGS +=    -Wshadow
+WARNINGS +=    -Wformat
+WARNINGS +=    -Wsequence-point
+WARNINGS +=    -Wcast-align
+WARNINGS +=    -Wformat-security
+WARNINGS +=    -Wformat-y2k
+WARNINGS +=     -Werror=format-security
+WARNINGS +=    -Winit-self
+WARNINGS +=    -Wswitch-default
+WARNINGS +=    -Wsync-nand
+WARNINGS +=    -Wundef
+WARNINGS +=    -Wlogical-op
+ifneq ($(OS),android)
+WARNINGS +=    -Wdouble-promotion
+WARNINGS +=    -Wjump-misses-init
+WARNINGS +=    -Wtrampolines
+endif
+WARNINGS +=    -Wunused-parameter
+# the following 2 do not work yet and need more work on it
 #WARNINGS +=   -Wconversion
 #WARNINGS +=   -Wredundant-decls
 ifeq ($(MUDFLAP),0)
@@ -88,14 +127,15 @@ endif
 #WARNINGS +=   -Wunreachable-code
 WARNINGS +=    -Winline
 WARNINGS +=    -Wdisabled-optimization
-WARNINGS +=    -Werror
+# WARNINGS +=  -Werror
 WARNINGS +=    -finline-functions-called-once
-#WARNINGS +=   -fearly-inlining
+WARNINGS +=    -funit-at-a-time
+WARNINGS +=    -fearly-inlining
 ifeq ($(DEBUG),0)
 WARNINGS +=    -fomit-frame-pointer
 endif
 # we have small inline functions in src/lq_route.h which should always be inlined
-WARNINGS +=    -finline-limit=700
+WARNINGS +=    -finline-limit=350
 # These tell gcc to put each function and global variable in a separate section.
 # The linker can than remove all unreferenced section. But in the olsrd binary
 # unused doesn't imply unused at all since the function may be used by plugins,
@@ -104,14 +144,14 @@ WARNINGS +=       -finline-limit=700
 # from the source by hand.
 #WARNINGS +=   -ffunction-sections
 #WARNINGS +=   -fdata-sections
-WARNINGS :=    $(shell CC="$(CC)" $(TOPDIR)/gcc-warnings $(WARNINGS))
+WARNINGS :=    $(shell CC="$(CC)" "$(TOPDIR)/gcc-warnings" $(WARNINGS))
 endif
 CFLAGS +=      $(WARNINGS)
 CFLAGS +=      $(OPTIMIZE)
 CFLAGS +=      $(EXTRA_CFLAGS)
 
 # Must be specified along with -lpthread on linux
-#CPPFLAGS +=   $(OS_CFLAG_PTHREAD)
+CPPFLAGS +=    $(OS_CFLAG_PTHREAD)
 endif
 ifneq ($(MUDFLAP),0)
 CFLAGS +=      -fmudflapth
@@ -120,12 +160,19 @@ endif
 ifdef OLSRD_PLUGIN
 # c and ld flags for libraries (plugins)
 CPPFLAGS +=    -DOLSR_PLUGIN
+ifeq ($(OS),win32)
+  LDFLAGS +=   -Wl,-export-all-symbols,--enable-auto-import
+endif
 LDFLAGS +=     -shared
-LDFLAGS +=     -Wl,-soname,$(PLUGIN_NAME)
+LDFLAGS +=     -Wl,-soname,$(PLUGIN_SONAME)
 LDFLAGS +=     -Wl,--version-script=version-script.txt 
 else
 # c and ld flags for main
-LDFLAGS +=     -Wl,-export-dynamic 
+ifeq ($(OS),win32)
+  LDFLAGS +=   -Wl,-export-all-symbols
+else 
+  LDFLAGS +=   -Wl,-export-dynamic 
+endif
 LDFLAGS +=     -Wl,-rpath,$(LIBDIR)
 endif
 # LDFLAGS for all 
@@ -137,7 +184,7 @@ LDFLAGS +=  -Wl,--warn-common
 ifneq ($(MUDFLAP),0)
 LIBS +=                -lmudflapth
 endif
-#LIBS +=               $(OS_LIB_PTHREAD)
+LIBS +=                $(OS_LIB_PTHREAD)
 
 # extra options from the outside
 CPPFLAGS +=    $(EXTRA_CPPFLAGS)
@@ -156,13 +203,6 @@ CPPFLAGS +=     -DUSE_FPM
 SRCS +=                $(wildcard src/common/*.c src/*.c *.c)
 HDRS +=                $(wildcard src/common/*.h src/*.h *.h)
 
-# OS detection
-ifeq ($(OS),Windows_NT)
-OS := win32
-endif
-ifeq ($(OS),)
-OS := $(shell sh $(TOPDIR)/make/guess_os.sh)
-endif
 ifeq ($(OS),UNKNOWN)
 all: help
 else
@@ -178,14 +218,18 @@ OBJS +=           $(SRCS:%.c=%.o)
 ifeq ($(DEBUG),1)
 CPPFLAGS +=    -DDEBUG
 CFLAGS +=      -ggdb
-OPTIMIZE ?=    -O0
 else
 CPPFLAGS +=    -DNDEBUG
-OPTIMIZE ?=    -O2
+ifeq ($(OPTIMIZE),)
+OPTIMIZE += -O2 -D_FORTIFY_SOURCE=2 
+endif
 endif
 ifeq ($(NO_DEBUG_MESSAGES),1)
 CPPFLAGS +=    -DNODEBUG
-OPTIMIZE ?=    -Os
+endif
+
+ifeq ($(OS),linux)
+CPPFLAGS+=-DHTTPINFO_PUD -I$(TOPDIR)/lib -I$(TOPDIR)/lib/pud/nmealib/include -I$(TOPDIR)/lib/pud/wireformat/include
 endif
 
 # a make function to quote "/" and "."
@@ -193,7 +237,13 @@ quote = $(subst .,\.,$(subst /,\/,$1))
 
 # fully automatic and working dependency generation
 %.d: %.c
-       @$(filter-out $(CCACHE),$(CC)) -M $(strip $(CPPFLAGS)) "$<" | sed -e '1s/\($(call quote,$(*F))\.o\)[ :]*/$(call quote,$(*D)/\1 $@: Makefile $(TOPDIR)$(if $(TOPDIR),/)Makefile.inc) /g' >"$@"
+       $(MAKECMDPREFIX)$(filter-out $(CCACHE),$(CC)) -M $(strip $(CPPFLAGS)) "$<" | sed -e '1s/\($(call quote,$(*F))\.o\)[ :]*/$(call quote,$(*D)/\1 $@: Makefile $(TOPDIR)$(if $(TOPDIR),/)Makefile.inc) /g' >"$@"
+
+%.o: %.c
+ifeq ($(VERBOSE),0)
+       @echo "[CC] $<"
+endif
+       $(MAKECMDPREFIX)$(CC) $(CFLAGS) $(CPPFLAGS) -c -o $@ $<
 
 # we always need the includes and defines
 # for legacy since now
@@ -216,12 +266,13 @@ help:
        @echo ' by setting the OS variable! Valid  '
        @echo ' target OSes are:                   '
        @echo ' ---------------------------------  '
-       @echo ' linux - GNU/Linux                  '
-       @echo ' win32 - MS Windows                 '
-       @echo ' fbsd  - FreeBSD                    '
-       @echo ' nbsd  - NetBSD                     '
-       @echo ' obsd  - OpenBSD                    '
-       @echo ' osx   - Mac OS X                   '
+       @echo ' linux   - GNU/Linux                '
+       @echo ' win32   - MS Windows               '
+       @echo ' fbsd    - FreeBSD                  '
+       @echo ' nbsd    - NetBSD                   '
+       @echo ' obsd    - OpenBSD                  '
+       @echo ' osx     - Mac OS X                 '
+       @echo ' android - Android                  '
        @echo ' ---------------------------------  '
        @echo ' Example - build for windows:       '
        @echo ' make OS=win32                      '