Imported Upstream version 16.04
[deb_dpdk.git] / mk / toolchain / icc / 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, ... (overriden by cmdline value)
36 #   - define TOOLCHAIN_CFLAGS variable (overriden by cmdline value)
37 #   - define TOOLCHAIN_LDFLAGS variable (overriden by cmdline value)
38 #   - define TOOLCHAIN_ASFLAGS variable (overriden by cmdline value)
39 #
40
41 # Warning: we do not use CROSS environment variable as icc is mainly a
42 # x86->x86 compiler
43
44 CC        = icc
45 KERNELCC  = gcc
46 CPP       = cpp
47 AS        = nasm
48 AR        = ar
49 LD        = ld
50 OBJCOPY   = objcopy
51 OBJDUMP   = objdump
52 STRIP     = strip
53 READELF   = readelf
54
55 ifeq ($(KERNELRELEASE),)
56 HOSTCC    = icc
57 else
58 HOSTCC    = gcc
59 endif
60 HOSTAS    = as
61
62 TOOLCHAIN_CFLAGS =
63 TOOLCHAIN_LDFLAGS =
64 TOOLCHAIN_ASFLAGS =
65
66 # Turn off some ICC warnings -
67 #   Remark #271   : trailing comma is nonstandard
68 #   Warning #1478 : function "<func_name>" (declared at line N of "<filename>")
69 #   error #13368: loop was not vectorized with "vector always assert"
70 #   error #15527: loop was not vectorized: function call to fprintf cannot be vectorize
71 #                   was declared "deprecated"
72 WERROR_FLAGS := -Wall -w2 -diag-disable 271 -diag-warning 1478
73 WERROR_FLAGS += -diag-disable 13368 -diag-disable 15527
74
75 ifeq ($(RTE_DEVEL_BUILD),y)
76 WERROR_FLAGS += -Werror-all
77 endif
78
79 # process cpu flags
80 include $(RTE_SDK)/mk/toolchain/$(RTE_TOOLCHAIN)/rte.toolchain-compat.mk
81 # disable max-inline params boundaries for ICC compiler for version 15 and greater
82 ifeq ($(shell test $(ICC_MAJOR_VERSION) -ge 14 && echo 1), 1)
83         TOOLCHAIN_CFLAGS += -no-inline-max-size -no-inline-max-total-size
84 endif
85
86 export CC AS AR LD OBJCOPY OBJDUMP STRIP READELF
87 export TOOLCHAIN_CFLAGS TOOLCHAIN_LDFLAGS TOOLCHAIN_ASFLAGS