1# $FreeBSD$ 2 3# 4# Warning flags for compiling the kernel and components of the kernel: 5# 6CWARNFLAGS?= -Wall -Wredundant-decls -Wnested-externs -Wstrict-prototypes \ 7 -Wmissing-prototypes -Wpointer-arith -Winline -Wcast-qual \ 8 -Wundef -Wno-pointer-sign ${FORMAT_EXTENSIONS} \ 9 -Wmissing-include-dirs -fdiagnostics-show-option \ 10 ${CWARNEXTRA} 11# 12# The following flags are next up for working on: 13# -Wextra 14 15# Disable a few warnings for clang, since there are several places in the 16# kernel where fixing them is more trouble than it is worth, or where there is 17# a false positive. 18.if ${COMPILER_TYPE} == "clang" 19NO_WCONSTANT_CONVERSION= -Wno-constant-conversion 20NO_WARRAY_BOUNDS= -Wno-array-bounds 21NO_WSHIFT_COUNT_NEGATIVE= -Wno-shift-count-negative 22NO_WSHIFT_COUNT_OVERFLOW= -Wno-shift-count-overflow 23NO_WUNUSED_VALUE= -Wno-unused-value 24NO_WSELF_ASSIGN= -Wno-self-assign 25NO_WFORMAT_SECURITY= -Wno-format-security 26NO_WUNNEEDED_INTERNAL_DECL= -Wno-unneeded-internal-declaration 27NO_WSOMETIMES_UNINITIALIZED= -Wno-error-sometimes-uninitialized 28# Several other warnings which might be useful in some cases, but not severe 29# enough to error out the whole kernel build. Display them anyway, so there is 30# some incentive to fix them eventually. 31CWARNEXTRA?= -Wno-error-tautological-compare -Wno-error-empty-body \ 32 -Wno-error-parentheses-equality -Wno-unused-function \ 33 ${NO_WFORMAT} 34.endif 35 36# External compilers may not support our format extensions. Allow them 37# to be disabled. WARNING: format checking is disabled in this case. 38.if ${MK_FORMAT_EXTENSIONS} == "no" 39NO_WFORMAT= -Wno-format 40.else 41FORMAT_EXTENSIONS= -fformat-extensions 42.endif 43 44# 45# On i386, do not align the stack to 16-byte boundaries. Otherwise GCC 2.95 46# and above adds code to the entry and exit point of every function to align the 47# stack to 16-byte boundaries -- thus wasting approximately 12 bytes of stack 48# per function call. While the 16-byte alignment may benefit micro benchmarks, 49# it is probably an overall loss as it makes the code bigger (less efficient 50# use of code cache tag lines) and uses more stack (less efficient use of data 51# cache tag lines). Explicitly prohibit the use of FPU, SSE and other SIMD 52# operations inside the kernel itself. These operations are exclusively 53# reserved for user applications. 54# 55# gcc: 56# Setting -mno-mmx implies -mno-3dnow 57# Setting -mno-sse implies -mno-sse2, -mno-sse3 and -mno-ssse3 58# 59# clang: 60# Setting -mno-mmx implies -mno-3dnow and -mno-3dnowa 61# Setting -mno-sse implies -mno-sse2, -mno-sse3, -mno-ssse3, -mno-sse41 and -mno-sse42 62# 63.if ${MACHINE_CPUARCH} == "i386" 64CFLAGS.gcc+= -mno-align-long-strings -mpreferred-stack-boundary=2 65CFLAGS.clang+= -mno-aes -mno-avx 66CFLAGS+= -mno-mmx -mno-sse -msoft-float 67INLINE_LIMIT?= 8000 68.endif 69 70.if ${MACHINE_CPUARCH} == "arm" 71INLINE_LIMIT?= 8000 72.endif 73 74# 75# For IA-64, we use r13 for the kernel globals pointer and we only use 76# a very small subset of float registers for integer divides. 77# 78.if ${MACHINE_CPUARCH} == "ia64" 79CFLAGS+= -ffixed-r13 -mfixed-range=f32-f127 -fpic #-mno-sdata 80INLINE_LIMIT?= 15000 81.endif 82 83# 84# For sparc64 we want the medany code model so modules may be located 85# anywhere in the 64-bit address space. We also tell GCC to use floating 86# point emulation. This avoids using floating point registers for integer 87# operations which it has a tendency to do. 88# 89.if ${MACHINE_CPUARCH} == "sparc64" 90CFLAGS.clang+= -mcmodel=large -fno-dwarf2-cfi-asm 91CFLAGS.gcc+= -mcmodel=medany -msoft-float 92INLINE_LIMIT?= 15000 93.endif 94 95# 96# For AMD64, we explicitly prohibit the use of FPU, SSE and other SIMD 97# operations inside the kernel itself. These operations are exclusively 98# reserved for user applications. 99# 100# gcc: 101# Setting -mno-mmx implies -mno-3dnow 102# Setting -mno-sse implies -mno-sse2, -mno-sse3, -mno-ssse3 and -mfpmath=387 103# 104# clang: 105# Setting -mno-mmx implies -mno-3dnow and -mno-3dnowa 106# Setting -mno-sse implies -mno-sse2, -mno-sse3, -mno-ssse3, -mno-sse41 and -mno-sse42 107# (-mfpmath= is not supported) 108# 109.if ${MACHINE_CPUARCH} == "amd64" 110CFLAGS.clang+= -mno-aes -mno-avx 111CFLAGS+= -mcmodel=kernel -mno-red-zone -mno-mmx -mno-sse -msoft-float \ 112 -fno-asynchronous-unwind-tables 113INLINE_LIMIT?= 8000 114.endif 115 116# 117# For PowerPC we tell gcc to use floating point emulation. This avoids using 118# floating point registers for integer operations which it has a tendency to do. 119# Also explicitly disable Altivec instructions inside the kernel. 120# 121.if ${MACHINE_CPUARCH} == "powerpc" 122CFLAGS+= -msoft-float -mno-altivec 123INLINE_LIMIT?= 15000 124.endif 125 126# 127# Use dot symbols on powerpc64 to make ddb happy 128# 129.if ${MACHINE_ARCH} == "powerpc64" 130CFLAGS+= -mcall-aixdesc 131.endif 132 133# 134# For MIPS we also tell gcc to use floating point emulation 135# 136.if ${MACHINE_CPUARCH} == "mips" 137CFLAGS+= -msoft-float 138INLINE_LIMIT?= 8000 139.endif 140 141# 142# GCC 3.0 and above like to do certain optimizations based on the 143# assumption that the program is linked against libc. Stop this. 144# 145CFLAGS+= -ffreestanding 146 147# 148# GCC SSP support 149# 150.if ${MK_SSP} != "no" && ${MACHINE_CPUARCH} != "ia64" && \ 151 ${MACHINE_CPUARCH} != "arm" && ${MACHINE_CPUARCH} != "mips" 152CFLAGS+= -fstack-protector 153.endif 154 155# 156# Add -gdwarf-2 when compiling -g. The default starting in clang v3.4 157# and gcc 4.8 is to generate DWARF version 4. However, our tools don't 158# cope well with DWARF 4, so force it to genereate DWARF2, which they 159# understand. Do this unconditionally as it is harmless when not needed, 160# but critical for these newer versions. 161# 162.if ${CFLAGS:M-g} != "" && ${CFLAGS:M-gdwarf*} == "" 163CFLAGS+= -gdwarf-2 164.endif 165 166CFLAGS+= ${CFLAGS.${COMPILER_TYPE}} 167