kern.pre.mk revision 242715
185909Simp# $FreeBSD: head/sys/conf/kern.pre.mk 242715 2012-11-07 22:15:28Z dim $
285909Simp
3122116Sbde# Part of a unified Makefile for building kernels.  This part contains all
4122116Sbde# of the definitions that need to be before %BEFORE_DEPEND.
5122116Sbde
6180012Sru.include <bsd.own.mk>
7240468Sbrooks.include <bsd.compiler.mk>
8160440Sobrien
9210151Simp# backwards compat option for older systems.
10239272SgonzoMACHINE_CPUARCH?=${MACHINE_ARCH:C/mips(n32|64)?(el)?/mips/:C/arm(v6)?(eb)?/arm/:C/powerpc64/powerpc/}
11210151Simp
1285909Simp# Can be overridden by makeoptions or /etc/make.conf
1385909SimpKERNEL_KO?=	kernel
1485909SimpKERNEL?=	kernel
1585909SimpKODIR?=		/boot/${KERNEL}
16175888SimpLDSCRIPT_NAME?=	ldscript.$M
17175888SimpLDSCRIPT?=	$S/conf/${LDSCRIPT_NAME}
1885909Simp
19218538SimpM=		${MACHINE_CPUARCH}
2085909Simp
2191512SobrienAWK?=		awk
22240451SnpCP?=		cp
23116341SmarkmLINT?=		lint
2485909SimpNM?=		nm
2585909SimpOBJCOPY?=	objcopy
2685909SimpSIZE?=		size
2785909Simp
28220863Sdim.if defined(DEBUG)
29140606Sobrien_MINUS_O=	-O
30187103SgnnCTFFLAGS+=	-g
31220863Sdim.else
32224882Snwhitehorn.if ${MACHINE_CPUARCH} == "powerpc"
33224882Snwhitehorn_MINUS_O=	-O	# gcc miscompiles some code at -O2
34224882Snwhitehorn.else
35140606Sobrien_MINUS_O=	-O2
36220863Sdim.endif
37224882Snwhitehorn.endif
38220863Sdim.if ${MACHINE_CPUARCH} == "amd64"
39240468Sbrooks.if ${COMPILER_TYPE} != "clang"
40127204SobrienCOPTFLAGS?=-O2 -frename-registers -pipe
41220863Sdim.else
42228868SdimCOPTFLAGS?=-O2 -pipe
43228868Sdim.endif
44228868Sdim.else
45140606SobrienCOPTFLAGS?=${_MINUS_O} -pipe
46220863Sdim.endif
47220863Sdim.if !empty(COPTFLAGS:M-O[23s]) && empty(COPTFLAGS:M-fno-strict-aliasing)
48124834SruCOPTFLAGS+= -fno-strict-aliasing
49124834Sru.endif
5085909Simp.if !defined(NO_CPU_COPTFLAGS)
5185909SimpCOPTFLAGS+= ${_CPUCFLAGS}
5285909Simp.endif
53160043SobrienC_DIALECT= -std=c99
54126890StrhodesNOSTDINC= -nostdinc
5585909Simp
56192901SthompsaINCLUDES= ${NOSTDINC} ${INCLMAGIC} -I. -I$S
57126890Strhodes
58151605Sobrien# This hack lets us use the OpenBSD altq code without spamming a new
59151605Sobrien# include path into contrib'ed source files.
60130416SmlaierINCLUDES+= -I$S/contrib/altq
61130416Smlaier
62149978Sobrien.if make(depend) || make(kernel-depend)
63149978Sobrien
64149978Sobrien# ... and the same for ipfilter
65149978SobrienINCLUDES+= -I$S/contrib/ipfilter
66149978Sobrien
67185522Ssam# ... and the same for ath
68185522SsamINCLUDES+= -I$S/dev/ath -I$S/dev/ath/ath_hal
69149978Sobrien
70149978Sobrien# ... and the same for the NgATM stuff
71149978SobrienINCLUDES+= -I$S/contrib/ngatm
72149978Sobrien
73229353Sgjb# ... and the same for twa
74149978SobrienINCLUDES+= -I$S/dev/twa
75149978Sobrien
76218792Snp# ... and the same for cxgb and cxgbe
77218792SnpINCLUDES+= -I$S/dev/cxgb -I$S/dev/cxgbe
78183292Skmacy
79149978Sobrien.endif
80149978Sobrien
81160043SobrienCFLAGS=	${COPTFLAGS} ${C_DIALECT} ${DEBUG} ${CWARNFLAGS}
82150966SglebiusCFLAGS+= ${INCLUDES} -D_KERNEL -DHAVE_KERNEL_OPTION_HEADERS -include opt_global.h
83240468Sbrooks.if ${COMPILER_TYPE} != "clang"
84124834SruCFLAGS+= -fno-common -finline-limit=${INLINE_LIMIT}
85210311Sjmallett.if ${MACHINE_CPUARCH} != "mips"
86132766SkanCFLAGS+= --param inline-unit-growth=100
87132766SkanCFLAGS+= --param large-function-growth=1000
88210311Sjmallett.else
89210311Sjmallett# XXX Actually a gross hack just for Octeon because of the Simple Executive.
90215988SjmallettCFLAGS+= --param inline-unit-growth=10000
91210311SjmallettCFLAGS+= --param large-function-growth=100000
92215988SjmallettCFLAGS+= --param max-inline-insns-single=10000
93210311Sjmallett.endif
94210394Srpaulo.endif
95171239SpeterWERROR?= -Werror
9685909Simp
9785909Simp# XXX LOCORE means "don't declare C stuff" not "for locore.s".
9885909SimpASM_CFLAGS= -x assembler-with-cpp -DLOCORE ${CFLAGS}
9985909Simp
100240468Sbrooks.if ${COMPILER_TYPE} == "clang"
101232263SdimCLANG_NO_IAS= -no-integrated-as
102232263Sdim.endif
103232263Sdim
10499923Sbde.if defined(PROFLEVEL) && ${PROFLEVEL} >= 1
105242715SdimCFLAGS+=	-DGPROF
106242715Sdim.if ${COMPILER_TYPE} != "clang"
107242715SdimCFLAGS+=	-falign-functions=16
108242715Sdim.endif
10999932Sbde.if ${PROFLEVEL} >= 2
11099932SbdeCFLAGS+=	-DGPROF4 -DGUPROF
111230422SandreastPROF=	-pg -mprofiler-epilogue
11299932Sbde.else
113230422SandreastPROF=	-pg
11499923Sbde.endif
11599932Sbde.endif
11685909SimpDEFINED_PROF=	${PROF}
11791002Speter
11885909Simp# Put configuration-specific C flags last (except for ${PROF}) so that they
11985909Simp# can override the others.
12085909SimpCFLAGS+=	${CONF_CFLAGS}
12185909Simp
122116341Smarkm# Optional linting. This can be overridden in /etc/make.conf.
123116341SmarkmLINTFLAGS=	${LINTOBJKERNFLAGS}
124116341Smarkm
12591002SpeterNORMAL_C= ${CC} -c ${CFLAGS} ${WERROR} ${PROF} ${.IMPSRC}
12691002SpeterNORMAL_S= ${CC} -c ${ASM_CFLAGS} ${WERROR} ${.IMPSRC}
12791002SpeterPROFILE_C= ${CC} -c ${CFLAGS} ${WERROR} ${.IMPSRC}
128105489SmuxNORMAL_C_NOWERROR= ${CC} -c ${CFLAGS} ${PROF} ${.IMPSRC}
12985909Simp
130105462SmuxNORMAL_M= ${AWK} -f $S/tools/makeobjops.awk ${.IMPSRC} -c ; \
131105462Smux	  ${CC} -c ${CFLAGS} ${WERROR} ${PROF} ${.PREFIX}.c
13285909Simp
133239956SjhbNORMAL_FW= uudecode -o ${.TARGET} ${.ALLSRC}
134239957SjhbNORMAL_FWO= ${LD} -b binary --no-warn-mismatch -d -warn-common -r \
135239957Sjhb	-o ${.TARGET} ${.ALLSRC:M*.fw}
136239955Sjhb
137233578Speter# Special flags for managing the compat compiles for ZFS
138233578SpeterZFS_CFLAGS=	-DFREEBSD_NAMECACHE -DBUILDING_ZFS -nostdinc -I$S/cddl/compat/opensolaris -I$S/cddl/contrib/opensolaris/uts/common/fs/zfs -I$S/cddl/contrib/opensolaris/uts/common/zmod -I$S/cddl/contrib/opensolaris/uts/common -I$S -I$S/cddl/contrib/opensolaris/common/zfs -I$S/cddl/contrib/opensolaris/common ${CFLAGS} -Wno-unknown-pragmas -Wno-missing-prototypes -Wno-undef -Wno-strict-prototypes -Wno-cast-qual -Wno-parentheses -Wno-redundant-decls -Wno-missing-braces -Wno-uninitialized -Wno-unused -Wno-inline -Wno-switch -Wno-pointer-arith -Wno-unknown-pragmas
139233578SpeterZFS_ASM_CFLAGS= -x assembler-with-cpp -DLOCORE ${ZFS_CFLAGS}
140233578SpeterZFS_C=		${CC} -c ${ZFS_CFLAGS} ${WERROR} ${PROF} ${.IMPSRC}
141233578SpeterZFS_S=		${CC} -c ${ZFS_ASM_CFLAGS} ${WERROR} ${.IMPSRC}
142233578Speter
143228158Sfjoe.if ${MK_CTF} != "no"
144228140SfjoeNORMAL_CTFCONVERT=	${CTFCONVERT} ${CTFFLAGS} ${.TARGET}
145228158Sfjoe.elif ${MAKE_VERSION} >= 5201111300
146228158SfjoeNORMAL_CTFCONVERT=
147228124Sfjoe.else
148228158SfjoeNORMAL_CTFCONVERT=	@:
149228124Sfjoe.endif
150179226Sjb
151116341SmarkmNORMAL_LINT=	${LINT} ${LINTFLAGS} ${CFLAGS:M-[DIU]*} ${.IMPSRC}
152116341Smarkm
153219819Sjeff# Infiniband C flags.  Correct include paths and omit errors that linux
154219819Sjeff# does not honor.
155219819SjeffOFEDINCLUDES=	-I$S/ofed/include/
156219819SjeffOFEDNOERR=	-Wno-cast-qual -Wno-pointer-arith -fms-extensions
157219819SjeffOFEDCFLAGS=	${CFLAGS:N-I*} ${OFEDINCLUDES} ${CFLAGS:M-I*} ${OFEDNOERR}
158219819SjeffOFED_C_NOIMP=	${CC} -c -o ${.TARGET} ${OFEDCFLAGS} ${WERROR} ${PROF}
159219819SjeffOFED_C=		${OFED_C_NOIMP} ${.IMPSRC}
160219819Sjeff
161131210SimpGEN_CFILES= $S/$M/$M/genassym.c ${MFILES:T:S/.m$/.c/}
162144293SphkSYSTEM_CFILES= config.c env.c hints.c vnode_if.c
16385909SimpSYSTEM_DEP= Makefile ${SYSTEM_OBJS}
164111684SruSYSTEM_OBJS= locore.o ${MDOBJS} ${OBJS}
165111684SruSYSTEM_OBJS+= ${SYSTEM_CFILES:.c=.o}
166111684SruSYSTEM_OBJS+= hack.So
167239957SjhbSYSTEM_LD= @${LD} -Bdynamic -T ${LDSCRIPT} --no-warn-mismatch \
16889180Smsmith	-warn-common -export-dynamic -dynamic-linker /red/herring \
16985909Simp	-o ${.TARGET} -X ${SYSTEM_OBJS} vers.o
17085909SimpSYSTEM_LD_TAIL= @${OBJCOPY} --strip-symbol gcc2_compiled. ${.TARGET} ; \
171123966Sbde	${SIZE} ${.TARGET} ; chmod 755 ${.TARGET}
172175888SimpSYSTEM_DEP+= ${LDSCRIPT}
17385909Simp
17488893Simp# MKMODULESENV is set here so that port makefiles can augment
17588893Simp# them.
17688893Simp
177221265SbzMKMODULESENV+=	MAKEOBJDIRPREFIX=${.OBJDIR}/modules KMODDIR=${KODIR}
178210151SimpMKMODULESENV+=	MACHINE_CPUARCH=${MACHINE_CPUARCH}
17990789Sphk.if (${KERN_IDENT} == LINT)
18090789SphkMKMODULESENV+=	ALL_MODULES=LINT
18190789Sphk.endif
18288893Simp.if defined(MODULES_OVERRIDE)
18388893SimpMKMODULESENV+=	MODULES_OVERRIDE="${MODULES_OVERRIDE}"
18488893Simp.endif
185216746Scperciva.if defined(WITHOUT_MODULES)
186216746ScpercivaMKMODULESENV+=	WITHOUT_MODULES="${WITHOUT_MODULES}"
187216746Scperciva.endif
18888893Simp.if defined(DEBUG)
189125772SruMKMODULESENV+=	DEBUG_FLAGS="${DEBUG}"
19088893Simp.endif
191240402Sobrien
192240402Sobrien# Are various things configured?
193240402SobrienDDB_ENABLED!=	grep DDB opt_ddb.h || true ; echo
194240402SobrienDTR_ENABLED!=	grep KDTRACE_FRAME opt_kdtrace.h || true ; echo
195240402SobrienHWPMC_ENABLED!=	grep HWPMC opt_hwpmc_hooks.h || true ; echo
196