1122715Sbde# $FreeBSD$
2122715Sbde
3122715Sbde# Part of a unified Makefile for building kernels.  This part includes all
4122715Sbde# the definitions that need to be after all the % directives except %RULES
5122715Sbde# and ones that act like they are part of %RULES.
685909Simp#
788893Simp# Most make variables should not be defined in this file.  Instead, they
888893Simp# should be defined in the kern.pre.mk so that port makefiles can
988969Simp# override or augment them.
1085909Simp
11115572Sphk# In case the config had a makeoptions DESTDIR...
12115572Sphk.if defined(DESTDIR)
13115572SphkMKMODULESENV+=	DESTDIR="${DESTDIR}"
14115572Sphk.endif
15191794SjhbSYSDIR?= ${S:C;^[^/];${.CURDIR}/&;}
16191794SjhbMKMODULESENV+=	KERNBUILDDIR="${.CURDIR}" SYSDIR="${SYSDIR}"
17115572Sphk
18205640Snetchild.if defined(CONF_CFLAGS)
19205640SnetchildMKMODULESENV+=	CONF_CFLAGS="${CONF_CFLAGS}"
20205640Snetchild.endif
21205640Snetchild
22206082Snetchild.if defined(WITH_CTF)
23206082SnetchildMKMODULESENV+=	WITH_CTF="${WITH_CTF}"
24206082Snetchild.endif
25206082Snetchild
26111211Sru.MAIN: all
2785909Simp
28111802Sru.for target in all clean cleandepend cleandir clobber depend install \
29111802Sru    obj reinstall tags
30111211Sru${target}: kernel-${target}
31111211Sru.if !defined(MODULES_WITH_WORLD) && !defined(NO_MODULES) && exists($S/modules)
32111211Sru${target}: modules-${target}
33111211Srumodules-${target}:
34111802Sru	cd $S/modules; ${MKMODULESENV} ${MAKE} \
35111802Sru	    ${target:S/^reinstall$/install/:S/^clobber$/cleandir/}
36111211Sru.endif
37111211Sru.endfor
3885909Simp
39237090Sdougb# Handle ports (as defined by the user) that build kernel modules
40147155Simp.if !defined(NO_MODULES) && defined(PORTS_MODULES)
41237090Sdougb#
42237090Sdougb# The ports tree needs some environment variables defined to match the new kernel
43237090Sdougb#
44237090Sdougb# Ports search for some dependencies in PATH, so add the location of the installed files
45237090SdougbLOCALBASE?=	/usr/local
46237090Sdougb# SRC_BASE is how the ports tree refers to the location of the base source files
47237090Sdougb.if !defined(SRC_BASE)
48237090SdougbSRC_BASE!=	realpath "${SYSDIR:H}/"
49237090Sdougb.endif
50237090Sdougb# OSVERSION is used by some ports to determine build options
51237090Sdougb.if !defined(OSRELDATE)
52237090Sdougb# Definition copied from src/Makefile.inc1
53237090SdougbOSRELDATE!=	awk '/^\#define[[:space:]]*__FreeBSD_version/ { print $$3 }' \
54237090Sdougb		    ${MAKEOBJDIRPREFIX}${SRC_BASE}/include/osreldate.h
55237090Sdougb.endif
56237090Sdougb# Keep the related ports builds in the obj directory so that they are only rebuilt once per kernel build
57237090SdougbWRKDIRPREFIX?=	${MAKEOBJDIRPREFIX}${SRC_BASE}/sys/${KERNCONF}
58237090SdougbPORTSMODULESENV=\
59237090Sdougb	PATH=${PATH}:${LOCALBASE}/bin:${LOCALBASE}/sbin \
60237090Sdougb	SRC_BASE=${SRC_BASE} \
61237090Sdougb	OSVERSION=${OSRELDATE} \
62237090Sdougb	WRKDIRPREFIX=${WRKDIRPREFIX}
63238038Sdougb
64238038Sdougb# The WRKDIR needs to be cleaned before building, and trying to change the target
65238038Sdougb# with a :C pattern below results in install -> instclean
66238038Sdougball:
67238038Sdougb.for __i in ${PORTS_MODULES}
68238038Sdougb	@${ECHO} "===> Ports module ${__i} (all)"
69238038Sdougb	cd $${PORTSDIR:-/usr/ports}/${__i}; ${PORTSMODULESENV} ${MAKE} -B clean all
70238038Sdougb.endfor
71238038Sdougb
72238038Sdougb.for __target in install reinstall clean
73142424Simp${__target}: ports-${__target}
74142413Simpports-${__target}:
75137596Simp.for __i in ${PORTS_MODULES}
76238038Sdougb	@${ECHO} "===> Ports module ${__i} (${__target})"
77238038Sdougb	cd $${PORTSDIR:-/usr/ports}/${__i}; ${PORTSMODULESENV} ${MAKE} -B ${__target:C/install/deinstall reinstall/:C/reinstall/deinstall reinstall/}
78137596Simp.endfor
79137596Simp.endfor
80137596Simp.endif
81137596Simp
82111211Sru.ORDER: kernel-install modules-install
83111211Sru
84167845Simpkernel-all: ${KERNEL_KO} ${KERNEL_EXTRA}
85111211Sru
86155427Srukernel-cleandir: kernel-clean kernel-cleandepend
87111802Sru
88111802Srukernel-clobber:
89111766Sru	find . -maxdepth 1 ! -type d ! -name version -delete
90111211Sru
91111766Srukernel-obj:
92111766Sru
93111211Sru.if !defined(MODULES_WITH_WORLD) && !defined(NO_MODULES) && exists($S/modules)
94111211Srumodules: modules-all
95111211Sru
96111211Sru.if !defined(NO_MODULES_OBJ)
97111211Srumodules-all modules-depend: modules-obj
98111211Sru.endif
99111211Sru.endif
100111211Sru
101151636Simp.if !defined(DEBUG)
102151636SimpFULLKERNEL=	${KERNEL_KO}
103151636Simp.else
104151636SimpFULLKERNEL=	${KERNEL_KO}.debug
105151750Sru${KERNEL_KO}: ${FULLKERNEL} ${KERNEL_KO}.symbols
106151750Sru	${OBJCOPY} --strip-debug --add-gnu-debuglink=${KERNEL_KO}.symbols\
107151731Sru	    ${FULLKERNEL} ${.TARGET}
108151750Sru${KERNEL_KO}.symbols: ${FULLKERNEL}
109151731Sru	${OBJCOPY} --only-keep-debug ${FULLKERNEL} ${.TARGET}
110151646Sruinstall.debug reinstall.debug: gdbinit
111151646Sru	cd ${.CURDIR}; ${MAKE} ${.TARGET:R}
112116252Sgrog
113123965Sbde# Install gdbinit files for kernel debugging.
114116252Sgroggdbinit:
115123965Sbde	grep -v '# XXX' ${S}/../tools/debugscripts/dot.gdbinit | \
116123965Sbde	    sed "s:MODPATH:${.OBJDIR}/modules:" > .gdbinit
117135611Sphk	cp ${S}/../tools/debugscripts/gdbinit.kernel ${.CURDIR}
118211725Simp.if exists(${S}/../tools/debugscripts/gdbinit.${MACHINE_CPUARCH})
119211725Simp	cp ${S}/../tools/debugscripts/gdbinit.${MACHINE_CPUARCH} \
120123965Sbde	    ${.CURDIR}/gdbinit.machine
12185909Simp.endif
122124776Sru.endif
12385909Simp
124239107Sbrooks${FULLKERNEL}: ${SYSTEM_DEP} vers.o ${MFS_IMAGE}
12585909Simp	@rm -f ${.TARGET}
12685909Simp	@echo linking ${.TARGET}
12785909Simp	${SYSTEM_LD}
128228158Sfjoe.if ${MK_CTF} != "no"
129228124Sfjoe	${CTFMERGE} ${CTFFLAGS} -o ${.TARGET} ${SYSTEM_OBJS} vers.o
130228124Sfjoe.endif
131125775Sru.if !defined(DEBUG)
132125775Sru	${OBJCOPY} --strip-debug ${.TARGET}
133125775Sru.endif
13485909Simp	${SYSTEM_LD_TAIL}
135159560Scognet.if defined(MFS_IMAGE)
136239107Sbrooks	sh ${S}/tools/embed_mfs.sh ${FULLKERNEL} ${MFS_IMAGE}
137159560Scognet.endif
13885909Simp
139116691Sru.if !exists(${.OBJDIR}/.depend)
140131129Simp${SYSTEM_OBJS}: assym.s vnode_if.h ${BEFORE_DEPEND:M*.h} ${MFILES:T:S/.m$/.h/}
14185909Simp.endif
14285909Simp
143116341SmarkmLNFILES=	${CFILES:T:S/.c$/.ln/}
144116341Smarkm
14585909Simp.for mfile in ${MFILES}
146102082Sbde# XXX the low quality .m.o rules gnerated by config are normally used
147102082Sbde# instead of the .m.c rules here.
148102082Sbde${mfile:T:S/.m$/.c/}: ${mfile}
149102082Sbde	${AWK} -f $S/tools/makeobjops.awk ${mfile} -c
15085909Simp${mfile:T:S/.m$/.h/}: ${mfile}
15195844Sobrien	${AWK} -f $S/tools/makeobjops.awk ${mfile} -h
15285909Simp.endfor
15385909Simp
15485909Simpkernel-clean:
15585909Simp	rm -f *.o *.so *.So *.ko *.s eddep errs \
156151750Sru	    ${FULLKERNEL} ${KERNEL_KO} ${KERNEL_KO}.symbols \
157242072Simp	    linterrs tags vers.c \
158145416Sru	    vnode_if.c vnode_if.h vnode_if_newproto.h vnode_if_typedef.h \
159123965Sbde	    ${MFILES:T:S/.m$/.c/} ${MFILES:T:S/.m$/.h/} \
160163332Sru	    ${CLEAN}
16185909Simp
162116341Smarkmlint: ${LNFILES}
163123965Sbde	${LINT} ${LINTKERNFLAGS} ${CFLAGS:M-[DILU]*} ${.ALLSRC} 2>&1 | \
164123965Sbde	    tee -a linterrs
16592491Smarkm
16685909Simp# This is a hack.  BFD "optimizes" away dynamic mode if there are no
16785909Simp# dynamic references.  We could probably do a '-Bforcedynamic' mode like
16885909Simp# in the a.out ld.  For now, this works.
16985909SimpHACK_EXTRA_FLAGS?= -shared
17085909Simphack.So: Makefile
171161283Sdes	:> hack.c
172123966Sbde	${CC} ${HACK_EXTRA_FLAGS} -nostdlib hack.c -o hack.So
17385909Simp	rm -f hack.c
17485909Simp
175123965Sbde# This rule stops ./assym.s in .depend from causing problems.
17685909Simp./assym.s: assym.s
17785909Simp
17885909Simpassym.s: $S/kern/genassym.sh genassym.o
179127306Sobrien	NM='${NM}' sh $S/kern/genassym.sh genassym.o > ${.TARGET}
18085909Simp
18185909Simpgenassym.o: $S/$M/$M/genassym.c
182123985Sbde	${CC} -c ${CFLAGS:N-fno-common} $S/$M/$M/genassym.c
18385909Simp
18485909Simp${SYSTEM_OBJS} genassym.o vers.o: opt_global.h
18585909Simp
186233578Speter# We have "special" -I include paths for opensolaris/zfs files in 'depend'.
187233578SpeterCFILES_NOZFS=	${CFILES:N*/opensolaris/*}
188233578SpeterSFILES_NOZFS=	${SFILES:N*/opensolaris/*}
189233578SpeterCFILES_ZFS=	${CFILES:M*/opensolaris/*}
190233578SpeterSFILES_ZFS=	${SFILES:M*/opensolaris/*}
191233578Speter
192145403Srukernel-depend: .depend
193102073Sbde# The argument list can be very long, so use make -V and xargs to
19491104Sjake# pass it to mkdep.
195152964SruSRCS=	assym.s vnode_if.h ${BEFORE_DEPEND} ${CFILES} \
196152964Sru	${SYSTEM_CFILES} ${GEN_CFILES} ${SFILES} \
197152964Sru	${MFILES:T:S/.m$/.h/}
198163332Sru.depend: .PRECIOUS ${SRCS}
19985909Simp	rm -f .newdep
200233578Speter	${MAKE} -V CFILES_NOZFS -V SYSTEM_CFILES -V GEN_CFILES | \
201102073Sbde	    MKDEP_CPP="${CC} -E" CC="${CC}" xargs mkdep -a -f .newdep ${CFLAGS}
202233578Speter	${MAKE} -V CFILES_ZFS | \
203233578Speter	    MKDEP_CPP="${CC} -E" CC="${CC}" xargs mkdep -a -f .newdep ${ZFS_CFLAGS}
204233578Speter	${MAKE} -V SFILES_NOZFS | \
205102073Sbde	    MKDEP_CPP="${CC} -E" xargs mkdep -a -f .newdep ${ASM_CFLAGS}
206233578Speter	${MAKE} -V SFILES_ZFS | \
207233578Speter	    MKDEP_CPP="${CC} -E" xargs mkdep -a -f .newdep ${ZFS_ASM_CFLAGS}
20885909Simp	rm -f .depend
20985909Simp	mv .newdep .depend
21085909Simp
211152964Sru_ILINKS= machine
212209993Snwhitehorn.if ${MACHINE} != ${MACHINE_CPUARCH}
213209993Snwhitehorn_ILINKS+= ${MACHINE_CPUARCH}
214152964Sru.endif
215214629Sjhb.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
216214629Sjhb_ILINKS+= x86
217214629Sjhb.endif
218152964Sru
219152964Sru# Ensure that the link exists without depending on it when it exists.
220152964Sru.for _link in ${_ILINKS}
221152964Sru.if !exists(${.OBJDIR}/${_link})
222254340Ssjg${SRCS} ${CLEAN:M*.o}: ${_link}
223152964Sru.endif
224152964Sru.endfor
225152964Sru
226152964Sru${_ILINKS}:
227152964Sru	@case ${.TARGET} in \
228152964Sru	machine) \
229152964Sru		path=${S}/${MACHINE}/include ;; \
230214629Sjhb	*) \
231214629Sjhb		path=${S}/${.TARGET}/include ;; \
232152964Sru	esac ; \
233152964Sru	${ECHO} ${.TARGET} "->" $$path ; \
234152964Sru	ln -s $$path ${.TARGET}
235152964Sru
236163332Sru# .depend needs include links so we remove them only together.
23785909Simpkernel-cleandepend:
238163332Sru	rm -f .depend ${_ILINKS}
23985909Simp
24085909Simpkernel-tags:
24185909Simp	@[ -f .depend ] || { echo "you must make depend first"; exit 1; }
24285909Simp	sh $S/conf/systags.sh
24385909Simp
244127246Smarcelkernel-install:
245151731Sru	@if [ ! -f ${KERNEL_KO} ] ; then \
24685909Simp		echo "You must build a kernel first." ; \
24785909Simp		exit 1 ; \
24885909Simp	fi
24985909Simp.if exists(${DESTDIR}${KODIR})
25085909Simp	-thiskernel=`sysctl -n kern.bootfile` ; \
251145623Sru	if [ ! "`dirname "$$thiskernel"`" -ef ${DESTDIR}${KODIR} ] ; then \
25285909Simp		chflags -R noschg ${DESTDIR}${KODIR} ; \
25385909Simp		rm -rf ${DESTDIR}${KODIR} ; \
25485909Simp	else \
25585909Simp		if [ -d ${DESTDIR}${KODIR}.old ] ; then \
25685909Simp			chflags -R noschg ${DESTDIR}${KODIR}.old ; \
25785909Simp			rm -rf ${DESTDIR}${KODIR}.old ; \
25885909Simp		fi ; \
25985909Simp		mv ${DESTDIR}${KODIR} ${DESTDIR}${KODIR}.old ; \
260118633Sru		sysctl kern.bootfile=${DESTDIR}${KODIR}.old/"`basename "$$thiskernel"`" ; \
26185909Simp	fi
26285909Simp.endif
26385909Simp	mkdir -p ${DESTDIR}${KODIR}
264186854Sbz	${INSTALL} -p -m 555 -o ${KMODOWN} -g ${KMODGRP} ${KERNEL_KO} ${DESTDIR}${KODIR}
265238050Sobrien.if defined(DEBUG) && !defined(INSTALL_NODEBUG) && ${MK_KERNEL_SYMBOLS} != "no"
266186854Sbz	${INSTALL} -p -m 555 -o ${KMODOWN} -g ${KMODGRP} ${KERNEL_KO}.symbols ${DESTDIR}${KODIR}
267151636Simp.endif
268167845Simp.if defined(KERNEL_EXTRA_INSTALL)
269186854Sbz	${INSTALL} -p -m 555 -o ${KMODOWN} -g ${KMODGRP} ${KERNEL_EXTRA_INSTALL} ${DESTDIR}${KODIR}
270167845Simp.endif
27185909Simp
272167845Simp
273167845Simp
27495356Srukernel-reinstall:
27585909Simp	@-chflags -R noschg ${DESTDIR}${KODIR}
276186854Sbz	${INSTALL} -p -m 555 -o ${KMODOWN} -g ${KMODGRP} ${KERNEL_KO} ${DESTDIR}${KODIR}
277238050Sobrien.if defined(DEBUG) && !defined(INSTALL_NODEBUG) && ${MK_KERNEL_SYMBOLS} != "no"
278186854Sbz	${INSTALL} -p -m 555 -o ${KMODOWN} -g ${KMODGRP} ${KERNEL_KO}.symbols ${DESTDIR}${KODIR}
279151636Simp.endif
28085909Simp
281144293Sphkconfig.o env.o hints.o vers.o vnode_if.o:
28285909Simp	${NORMAL_C}
283228158Sfjoe	${NORMAL_CTFCONVERT}
28485909Simp
285144293Sphkconfig.ln env.ln hints.ln vers.ln vnode_if.ln:
286116341Smarkm	${NORMAL_LINT}
287116341Smarkm
28885909Simpvers.c: $S/conf/newvers.sh $S/sys/param.h ${SYSTEM_DEP}
289135371Sru	MAKE=${MAKE} sh $S/conf/newvers.sh ${KERN_IDENT}
29085909Simp
29191512Sobrienvnode_if.c: $S/tools/vnode_if.awk $S/kern/vnode_if.src
29291512Sobrien	${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -c
29385909Simp
294163705Sruvnode_if.h vnode_if_newproto.h vnode_if_typedef.h: $S/tools/vnode_if.awk \
295163705Sru    $S/kern/vnode_if.src
296163705Sruvnode_if.h: vnode_if_newproto.h vnode_if_typedef.h
29791512Sobrien	${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -h
298163705Sruvnode_if_newproto.h:
299138290Sphk	${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -p
300163705Sruvnode_if_typedef.h:
301138290Sphk	${AWK} -f $S/tools/vnode_if.awk $S/kern/vnode_if.src -q
30285909Simp
303116691Sru# XXX strictly, everything depends on Makefile because changes to ${PROF}
304116691Sru# only appear there, but we don't handle that.
30585909Simp
306111686Sru.include "kern.mk"
307