New upstream version 17.11.4
[deb_dpdk.git] / mk / toolchain / gcc / rte.vars.mk
1 #   BSD LICENSE
2 #
3 #   Copyright(c) 2010-2014 Intel Corporation. All rights reserved.
4 #   All rights reserved.
5 #
6 #   Redistribution and use in source and binary forms, with or without
7 #   modification, are permitted provided that the following conditions
8 #   are met:
9 #
10 #     * Redistributions of source code must retain the above copyright
11 #       notice, this list of conditions and the following disclaimer.
12 #     * Redistributions in binary form must reproduce the above copyright
13 #       notice, this list of conditions and the following disclaimer in
14 #       the documentation and/or other materials provided with the
15 #       distribution.
16 #     * Neither the name of Intel Corporation nor the names of its
17 #       contributors may be used to endorse or promote products derived
18 #       from this software without specific prior written permission.
19 #
20 #   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 #   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 #   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 #   A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 #   OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 #   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 #   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 #   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 #   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 #   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 #   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
32 #
33 # toolchain:
34 #
35 #   - define CC, LD, AR, AS, ... (overridden by cmdline value)
36 #   - define TOOLCHAIN_CFLAGS variable (overridden by cmdline value)
37 #   - define TOOLCHAIN_LDFLAGS variable (overridden by cmdline value)
38 #   - define TOOLCHAIN_ASFLAGS variable (overridden by cmdline value)
39 #
40
41 CC        = $(CROSS)gcc
42 KERNELCC  = $(CROSS)gcc
43 CPP       = $(CROSS)cpp
44 # for now, we don't use as but nasm.
45 # AS      = $(CROSS)as
46 AS        = nasm
47 AR        = $(CROSS)ar
48 LD        = $(CROSS)ld
49 OBJCOPY   = $(CROSS)objcopy
50 OBJDUMP   = $(CROSS)objdump
51 STRIP     = $(CROSS)strip
52 READELF   = $(CROSS)readelf
53 GCOV      = $(CROSS)gcov
54
55 ifeq ("$(origin CC)", "command line")
56 HOSTCC    = $(CC)
57 else
58 HOSTCC    = gcc
59 endif
60 HOSTAS    = as
61
62 TOOLCHAIN_ASFLAGS =
63 TOOLCHAIN_CFLAGS =
64 TOOLCHAIN_LDFLAGS =
65
66 ifeq ($(CONFIG_RTE_LIBRTE_GCOV),y)
67 TOOLCHAIN_CFLAGS += --coverage
68 TOOLCHAIN_LDFLAGS += --coverage
69 ifeq (,$(findstring -O0,$(EXTRA_CFLAGS)))
70   $(warning "EXTRA_CFLAGS doesn't contains -O0, coverage will be inaccurate with optimizations enabled")
71 endif
72 endif
73
74 WERROR_FLAGS := -W -Wall -Wstrict-prototypes -Wmissing-prototypes
75 WERROR_FLAGS += -Wmissing-declarations -Wold-style-definition -Wpointer-arith
76 WERROR_FLAGS += -Wcast-align -Wnested-externs -Wcast-qual
77 WERROR_FLAGS += -Wformat-nonliteral -Wformat-security
78 WERROR_FLAGS += -Wundef -Wwrite-strings
79
80 ifeq ($(RTE_DEVEL_BUILD),y)
81 WERROR_FLAGS += -Werror
82 endif
83
84 # There are many issues reported for strict alignment architectures
85 # which are not necessarily fatal. Report as warnings.
86 ifeq ($(CONFIG_RTE_ARCH_STRICT_ALIGN),y)
87 WERROR_FLAGS += -Wno-error=cast-align
88 endif
89
90 # process cpu flags
91 include $(RTE_SDK)/mk/toolchain/$(RTE_TOOLCHAIN)/rte.toolchain-compat.mk
92
93 # workaround GCC bug with warning "missing initializer" for "= {0}"
94 ifeq ($(shell test $(GCC_VERSION) -lt 47 && echo 1), 1)
95 WERROR_FLAGS += -Wno-missing-field-initializers
96 endif
97 # workaround GCC bug with warning "may be used uninitialized"
98 ifeq ($(shell test $(GCC_VERSION) -lt 47 && echo 1), 1)
99 WERROR_FLAGS += -Wno-uninitialized
100 endif
101
102 HOST_WERROR_FLAGS := $(WERROR_FLAGS)
103
104 ifeq ($(shell test $(HOST_GCC_VERSION) -gt 70 && echo 1), 1)
105 # Tell GCC only to error for switch fallthroughs without a suitable comment
106 HOST_WERROR_FLAGS += -Wimplicit-fallthrough=2
107 # Ignore errors for snprintf truncation
108 HOST_WERROR_FLAGS += -Wno-format-truncation
109 endif
110
111 ifeq ($(shell test $(GCC_VERSION) -gt 70 && echo 1), 1)
112 # Tell GCC only to error for switch fallthroughs without a suitable comment
113 WERROR_FLAGS += -Wimplicit-fallthrough=2
114 # Ignore errors for snprintf truncation
115 WERROR_FLAGS += -Wno-format-truncation
116 endif
117
118 export CC AS AR LD OBJCOPY OBJDUMP STRIP READELF
119 export TOOLCHAIN_CFLAGS TOOLCHAIN_LDFLAGS TOOLCHAIN_ASFLAGS