xref: /freebsd/sys/conf/kmod.mk (revision db0cd7e1035cfe10211388db0dcae9b6112557ac)
1639a2e50SGarrett Wollman#	From: @(#)bsd.prog.mk	5.26 (Berkeley) 6/25/91
27f3dea24SPeter Wemm# $FreeBSD$
353996fadSWolfram Schneider#
41f089616SRuslan Ermilov# The include file <bsd.kmod.mk> handles building and installing loadable
51f089616SRuslan Ermilov# kernel modules.
653996fadSWolfram Schneider#
753996fadSWolfram Schneider#
853996fadSWolfram Schneider# +++ variables +++
953996fadSWolfram Schneider#
1053996fadSWolfram Schneider# CLEANFILES	Additional files to remove for the clean and cleandir targets.
1153996fadSWolfram Schneider#
121f089616SRuslan Ermilov# EXPORT_SYMS	A list of symbols that should be exported from the module,
131f089616SRuslan Ermilov#		or the name of a file containing a list of symbols, or YES
141f089616SRuslan Ermilov#		to export all symbols.  If not defined, no symbols are
151f089616SRuslan Ermilov#		exported.
161f089616SRuslan Ermilov#
17fe3cac87SNick Hibma# KMOD		The name of the kernel module to build.
1853996fadSWolfram Schneider#
193bdfa9e5SDavid E. O'Brien# KMODDIR	Base path for kernel modules (see kld(4)). [/boot/kernel]
2053996fadSWolfram Schneider#
211f089616SRuslan Ermilov# KMODOWN	Module file owner. [${BINOWN}]
2253996fadSWolfram Schneider#
231f089616SRuslan Ermilov# KMODGRP	Module file group. [${BINGRP}]
2453996fadSWolfram Schneider#
251f089616SRuslan Ermilov# KMODMODE	Module file mode. [${BINMODE}]
2653996fadSWolfram Schneider#
27fe3cac87SNick Hibma# KMODLOAD	Command to load a kernel module [/sbin/kldload]
287bc830bbSWolfram Schneider#
29fe3cac87SNick Hibma# KMODUNLOAD	Command to unload a kernel module [/sbin/kldunload]
307bc830bbSWolfram Schneider#
317fecffecSDoug Rabson# MFILES	Optionally a list of interfaces used by the module.
327fecffecSDoug Rabson#		This file contains a default list of interfaces.
3353996fadSWolfram Schneider#
341f089616SRuslan Ermilov# PROG		The name of the kernel module to build.
351f089616SRuslan Ermilov#		If not supplied, ${KMOD}.ko is used.
361f089616SRuslan Ermilov#
371f089616SRuslan Ermilov# SRCS		List of source files.
381f089616SRuslan Ermilov#
391f089616SRuslan Ermilov# DESTDIR	The tree where the module gets installed. [not set]
400b3178a4SMike Smith#
4153996fadSWolfram Schneider# +++ targets +++
4253996fadSWolfram Schneider#
4353996fadSWolfram Schneider# 	install:
4417d6c636SRuslan Ermilov#               install the kernel module; if the Makefile
4553996fadSWolfram Schneider#               does not itself define the target install, the targets
4653996fadSWolfram Schneider#               beforeinstall and afterinstall may also be used to cause
4753996fadSWolfram Schneider#               actions immediately before and after the install target
4853996fadSWolfram Schneider#		is executed.
4953996fadSWolfram Schneider#
5053996fadSWolfram Schneider# 	load:
511f089616SRuslan Ermilov#		Load a module.
5253996fadSWolfram Schneider#
5353996fadSWolfram Schneider# 	unload:
541f089616SRuslan Ermilov#		Unload a module.
5553996fadSWolfram Schneider#
56639a2e50SGarrett Wollman
57b7bbb709SDavid E. O'BrienAWK?=		awk
58fe3cac87SNick HibmaKMODLOAD?=	/sbin/kldload
59fe3cac87SNick HibmaKMODUNLOAD?=	/sbin/kldunload
60f6611608SSheldon HearnOBJCOPY?=	objcopy
617bc830bbSWolfram Schneider
6206639be7SPeter Wemm.if defined(KMODDEPS)
631f089616SRuslan Ermilov.error "Do not use KMODDEPS on 5.0+; use MODULE_VERSION/MODULE_DEPEND"
6406639be7SPeter Wemm.endif
6506639be7SPeter Wemm
660ac2fc87SRuslan Ermilov.include <bsd.init.mk>
67639a2e50SGarrett Wollman
68639a2e50SGarrett Wollman.SUFFIXES: .out .o .c .cc .cxx .C .y .l .s .S
69639a2e50SGarrett Wollman
7006d6e4fcSTom Rhodes.if ${CC} == "icc"
715a19f6d9STom RhodesCFLAGS:=	${CFLAGS:C/(-x[^M^K^W]+)[MKW]+|-x[MKW]+/\1/}
72daaea395SWarner Losh.else
73db0cd7e1SDavid E. O'Brien. if ${CFLAGS:M-O[23s]} != ""
74db0cd7e1SDavid E. O'BrienCFLAGS+= -fno-strict-aliasing
75db0cd7e1SDavid E. O'Brien. endif
76daaea395SWarner LoshWERROR?=	-Werror
7706d6e4fcSTom Rhodes.endif
78daaea395SWarner LoshCFLAGS+=	${WERROR}
7948aea4daSRuslan ErmilovCFLAGS+=	-D_KERNEL
808fe644b2SMike SmithCFLAGS+=	-DKLD_MODULE
814a2d2630SBruce Evans
82021886ffSBruce Evans# Don't use any standard or source-relative include directories.
83021886ffSBruce Evans# Since -nostdinc will annull any previous -I paths, we repeat all
84021886ffSBruce Evans# such paths after -nostdinc.  It doesn't seem to be possible to
85021886ffSBruce Evans# add to the front of `make' variable.
86021886ffSBruce Evans_ICFLAGS:=	${CFLAGS:M-I*}
8706d6e4fcSTom Rhodes.if ${CC} == "icc"
8806d6e4fcSTom RhodesNOSTDINC=	-X
8906d6e4fcSTom Rhodes.else
9006d6e4fcSTom RhodesNOSTDINC=	-nostdinc
9106d6e4fcSTom Rhodes.endif
9206d6e4fcSTom RhodesCFLAGS+=	${NOSTDINC} -I- ${INCLMAGIC} ${_ICFLAGS}
938fa793d0SBrian Feldman.if defined(KERNBUILDDIR)
9475504450SBrian FeldmanCFLAGS+=	-include ${KERNBUILDDIR}/opt_global.h
958fa793d0SBrian Feldman.endif
96021886ffSBruce Evans
971f089616SRuslan Ermilov# Add -I paths for system headers.  Individual module makefiles don't
98021886ffSBruce Evans# need any -I paths for this.  Similar defaults for .PATH can't be
99021886ffSBruce Evans# set because there are no standard paths for non-headers.
10074455e55SWarner LoshCFLAGS+=	-I. -I@
1014a2d2630SBruce Evans
10202b199f1SMax Laier# Add -I path for altq headers as they are included via net/if_var.h
10302b199f1SMax Laier# for example.
10402b199f1SMax LaierCFLAGS+=	-I@/contrib/altq
10502b199f1SMax Laier
106a0b845feSBruce Evans# Add a -I path to standard headers like <stddef.h>.  Use a relative
107a0b845feSBruce Evans# path to src/include if possible.  If the @ symlink hasn't been built
108a0b845feSBruce Evans# yet, then we can't tell if the relative path exists.  Add both the
109a0b845feSBruce Evans# potential relative path and an absolute path in that case.
110a0b845feSBruce Evans.if exists(@)
111a0b845feSBruce Evans.if exists(@/../include)
112a0b845feSBruce EvansCFLAGS+=	-I@/../include
113a0b845feSBruce Evans.else
114b3e17ba2SSatoshi AsamiCFLAGS+=	-I${DESTDIR}/usr/include
115b3e17ba2SSatoshi Asami.endif
116a0b845feSBruce Evans.else # !@
117a0b845feSBruce EvansCFLAGS+=	-I@/../include -I${DESTDIR}/usr/include
118a0b845feSBruce Evans.endif # @
11956bac51bSPoul-Henning Kamp
12006d6e4fcSTom Rhodes.if ${CC} != "icc"
121a92a2144SPeter WemmCFLAGS+=	-finline-limit=${INLINE_LIMIT}
12206d6e4fcSTom Rhodes.endif
1232a51529fSPeter Wemm
1240b3178a4SMike Smith# Disallow common variables, and if we end up with commons from
1250b3178a4SMike Smith# somewhere unexpected, allocate storage for them in the module itself.
12606d6e4fcSTom Rhodes.if ${CC} != "icc"
1270b3178a4SMike SmithCFLAGS+=	-fno-common
12806d6e4fcSTom Rhodes.endif
1290b3178a4SMike SmithLDFLAGS+=	-d -warn-common
1300b3178a4SMike Smith
1319e4be63dSBruce EvansCFLAGS+=	${DEBUG_FLAGS}
13283c457dcSIan Dowse.if ${MACHINE_ARCH} == amd64
13383c457dcSIan DowseCFLAGS+=	-fno-omit-frame-pointer
13483c457dcSIan Dowse.endif
1359e4be63dSBruce Evans
136fded756eSPeter Grehan.if ${MACHINE_ARCH} == "powerpc"
13755a5dcc8SPeter GrehanCFLAGS+=	-mlongcall -fno-omit-frame-pointer
138fded756eSPeter Grehan.endif
139fded756eSPeter Grehan
140639a2e50SGarrett WollmanOBJS+=	${SRCS:N*.h:R:S/$/.o/g}
141639a2e50SGarrett Wollman
142639a2e50SGarrett Wollman.if !defined(PROG)
14390f60fc9SMike SmithPROG=	${KMOD}.ko
14490f60fc9SMike Smith.endif
145639a2e50SGarrett Wollman
146817b59bfSRuslan Ermilov.if !defined(DEBUG_FLAGS)
147f6611608SSheldon HearnFULLPROG=	${PROG}
148f6611608SSheldon Hearn.else
149f6611608SSheldon HearnFULLPROG=	${PROG}.debug
150f6611608SSheldon Hearn${PROG}: ${FULLPROG}
151f6611608SSheldon Hearn	${OBJCOPY} --strip-debug ${FULLPROG} ${PROG}
152f6611608SSheldon Hearn.endif
153f6611608SSheldon Hearn
1544d6bcc83SPeter Wemm.if ${MACHINE_ARCH} != amd64
155f6611608SSheldon Hearn${FULLPROG}: ${KMOD}.kld
15609be11baSPeter Wemm	${LD} -Bshareable ${LDFLAGS} -o ${.TARGET} ${KMOD}.kld
157817b59bfSRuslan Ermilov.if !defined(DEBUG_FLAGS)
158817b59bfSRuslan Ermilov	${OBJCOPY} --strip-debug ${.TARGET}
1594c293d35SRuslan Ermilov.endif
1604d6bcc83SPeter Wemm.endif
16109be11baSPeter Wemm
16293f03548SMike SmithEXPORT_SYMS?=	NO
16393f03548SMike Smith.if ${EXPORT_SYMS} != YES
1641f089616SRuslan ErmilovCLEANFILES+=	export_syms
1650b3178a4SMike Smith.endif
1660b3178a4SMike Smith
1674d6bcc83SPeter Wemm.if ${MACHINE_ARCH} != amd64
16809be11baSPeter Wemm${KMOD}.kld: ${OBJS}
1694d6bcc83SPeter Wemm.else
1704d6bcc83SPeter Wemm${FULLPROG}: ${OBJS}
1714d6bcc83SPeter Wemm.endif
1720b3178a4SMike Smith	${LD} ${LDFLAGS} -r -d -o ${.TARGET} ${OBJS}
1730b3178a4SMike Smith.if defined(EXPORT_SYMS)
17493f03548SMike Smith.if ${EXPORT_SYMS} != YES
1750b3178a4SMike Smith.if ${EXPORT_SYMS} == NO
1761f089616SRuslan Ermilov	touch export_syms
1770b3178a4SMike Smith.elif !exists(${.CURDIR}/${EXPORT_SYMS})
1781f089616SRuslan Ermilov	echo ${EXPORT_SYMS} > export_syms
1790b3178a4SMike Smith.else
1801f089616SRuslan Ermilov	grep -v '^#' < ${EXPORT_SYMS} > export_syms
1810b3178a4SMike Smith.endif
1820b3178a4SMike Smith	awk -f ${SYSDIR}/conf/kmod_syms.awk ${.TARGET} \
1831f089616SRuslan Ermilov	    export_syms | xargs -J% ${OBJCOPY} % ${.TARGET}
18493f03548SMike Smith.endif
1850b3178a4SMike Smith.endif
1864d6bcc83SPeter Wemm.if !defined(DEBUG_FLAGS) && ${MACHINE_ARCH} == amd64
1874d6bcc83SPeter Wemm	${OBJCOPY} --strip-debug ${.TARGET}
1884d6bcc83SPeter Wemm.endif
1890b3178a4SMike Smith
1904a2d2630SBruce Evans_ILINKS=@ machine
191639a2e50SGarrett Wollman
192b25a566dSRuslan Ermilovall: objwarn ${PROG}
1934a2d2630SBruce Evans
194985f41afSWarner Loshbeforedepend: ${_ILINKS}
195985f41afSWarner Losh
196f3cc9575SWarner Losh# Ensure that the links exist without depending on it when it exists which
197f3cc9575SWarner Losh# causes all the modules to be rebuilt when the directory pointed to changes.
198f3cc9575SWarner Losh.for _link in ${_ILINKS}
199f3cc9575SWarner Losh.if !exists(${.OBJDIR}/${_link})
200f3cc9575SWarner Losh${OBJS}: ${_link}
201f3cc9575SWarner Losh.endif
202f3cc9575SWarner Losh.endfor
2034a2d2630SBruce Evans
2049a8631b3SWarner Losh# Search for kernel source tree in standard places.
2059a8631b3SWarner Losh.for _dir in ${.CURDIR}/../.. ${.CURDIR}/../../.. /sys /usr/src/sys
206776f50b9SRuslan Ermilov.if !defined(SYSDIR) && exists(${_dir}/kern/)
2079a8631b3SWarner LoshSYSDIR=	${_dir}
2089a8631b3SWarner Losh.endif
2099a8631b3SWarner Losh.endfor
210776f50b9SRuslan Ermilov.if !defined(SYSDIR) || !exists(${SYSDIR}/kern/)
2119a8631b3SWarner Losh.error "can't find kernel source tree"
2129a8631b3SWarner Losh.endif
2139a8631b3SWarner Losh
2144a2d2630SBruce Evans${_ILINKS}:
2159a8631b3SWarner Losh	@case ${.TARGET} in \
21608a04a89SPeter Wemm	machine) \
2179a8631b3SWarner Losh		path=${SYSDIR}/${MACHINE_ARCH}/include ;; \
21808a04a89SPeter Wemm	@) \
2199a8631b3SWarner Losh		path=${SYSDIR} ;; \
22008a04a89SPeter Wemm	esac ; \
22108a04a89SPeter Wemm	path=`(cd $$path && /bin/pwd)` ; \
22208a04a89SPeter Wemm	${ECHO} ${.TARGET} "->" $$path ; \
22308a04a89SPeter Wemm	ln -s $$path ${.TARGET}
2244a2d2630SBruce Evans
2251f089616SRuslan ErmilovCLEANFILES+= ${PROG} ${KMOD}.kld ${OBJS} ${_ILINKS}
226361186e5SMaxime Henrion
227817b59bfSRuslan Ermilov.if defined(DEBUG_FLAGS)
228361186e5SMaxime HenrionCLEANFILES+= ${FULLPROG}
229361186e5SMaxime Henrion.endif
230639a2e50SGarrett Wollman
231639a2e50SGarrett Wollman.if !target(install)
232639a2e50SGarrett Wollman
233ea87b3cbSDavid E. O'Brien_INSTALLFLAGS:=	${INSTALLFLAGS}
234e902c1bbSTim Vanderhoek.for ie in ${INSTALLFLAGS_EDIT}
235e902c1bbSTim Vanderhoek_INSTALLFLAGS:=	${_INSTALLFLAGS${ie}}
236e902c1bbSTim Vanderhoek.endfor
237e902c1bbSTim Vanderhoek
2381f089616SRuslan Ermilov.if !target(install.debug) && defined(DEBUG_FLAGS)
239b25a566dSRuslan Ermilovinstall.debug:
2402cbc81ffSRuslan Ermilov	cd ${.CURDIR}; ${MAKE} -DINSTALL_DEBUG install
2412cbc81ffSRuslan Ermilov.endif
242a4c00586SDag-Erling Smørgrav
2432b06260dSRuslan Ermilov.if !target(realinstall)
2442b06260dSRuslan Ermilovrealinstall: _kmodinstall
2452b06260dSRuslan Ermilov.ORDER: beforeinstall _kmodinstall
2462b06260dSRuslan Ermilov_kmodinstall:
247817b59bfSRuslan Ermilov.if defined(DEBUG_FLAGS) && defined(INSTALL_DEBUG)
248d2893b16SRuslan Ermilov	${INSTALL} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \
2492b06260dSRuslan Ermilov	    ${_INSTALLFLAGS} ${FULLPROG} ${DESTDIR}${KMODDIR}
2502cbc81ffSRuslan Ermilov.else
251d2893b16SRuslan Ermilov	${INSTALL} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \
2522b06260dSRuslan Ermilov	    ${_INSTALLFLAGS} ${PROG} ${DESTDIR}${KMODDIR}
2532b06260dSRuslan Ermilov
2542b06260dSRuslan Ermilov.include <bsd.links.mk>
2552b06260dSRuslan Ermilov
2564875819cSJake Burkholder.if !defined(NO_XREF)
2572b06260dSRuslan Ermilovafterinstall: _kldxref
2582b06260dSRuslan Ermilov.ORDER: realinstall _kldxref
2592b06260dSRuslan Ermilov.ORDER: _installlinks _kldxref
2602b06260dSRuslan Ermilov_kldxref:
261be1d673dSRuslan Ermilov	@if type kldxref >/dev/null 2>&1; then \
262be1d673dSRuslan Ermilov		${ECHO} kldxref ${DESTDIR}${KMODDIR}; \
263be1d673dSRuslan Ermilov		kldxref ${DESTDIR}${KMODDIR}; \
264be1d673dSRuslan Ermilov	fi
265505222d3SPeter Wemm.endif
2662cbc81ffSRuslan Ermilov.endif
2672b06260dSRuslan Ermilov.endif !target(realinstall)
268639a2e50SGarrett Wollman
2692b06260dSRuslan Ermilov.endif !target(install)
270639a2e50SGarrett Wollman
271639a2e50SGarrett Wollman.if !target(load)
2729a8631b3SWarner Loshload: ${PROG}
2731f089616SRuslan Ermilov	${KMODLOAD} -v ${.OBJDIR}/${PROG}
274639a2e50SGarrett Wollman.endif
275639a2e50SGarrett Wollman
276639a2e50SGarrett Wollman.if !target(unload)
277fe3cac87SNick Hibmaunload:
2781f089616SRuslan Ermilov	${KMODUNLOAD} -v ${PROG}
27908a04a89SPeter Wemm.endif
2801aa57be3SGarrett Wollman
2816b1bb559SWarner Losh.if defined(KERNBUILDDIR)
2826b1bb559SWarner Losh.PATH: ${KERNBUILDDIR}
2836b1bb559SWarner LoshCFLAGS+=	-I${KERNBUILDDIR}
2846b1bb559SWarner Losh.for _src in ${SRCS:Mopt_*.h}
2856b1bb559SWarner LoshCLEANFILES+=	${_src}
2866b1bb559SWarner Losh.if !target(${_src})
2876b1bb559SWarner Losh${_src}:
28831e81ae4SJoerg Wunsch	ln -s ${KERNBUILDDIR}/${_src} ${.TARGET}
2896b1bb559SWarner Losh.endif
2906b1bb559SWarner Losh.endfor
2916b1bb559SWarner Losh.else
2924fea6704SBruce Evans.for _src in ${SRCS:Mopt_*.h}
2934fea6704SBruce EvansCLEANFILES+=	${_src}
2944fea6704SBruce Evans.if !target(${_src})
2954fea6704SBruce Evans${_src}:
2964fea6704SBruce Evans	touch ${.TARGET}
2974fea6704SBruce Evans.endif
2984fea6704SBruce Evans.endfor
2996b1bb559SWarner Losh.endif
3004fea6704SBruce Evans
301268597acSMarcel MoolenaarMFILES?= dev/acpica/acpi_if.m dev/eisa/eisa_if.m dev/iicbus/iicbb_if.m \
302268597acSMarcel Moolenaar	dev/iicbus/iicbus_if.m dev/mii/miibus_if.m dev/ofw/ofw_bus_if.m \
3037e820aaaSMike Smith	dev/pccard/card_if.m dev/pccard/power_if.m dev/pci/pci_if.m \
3047e820aaaSMike Smith	dev/pci/pcib_if.m dev/ppbus/ppbus_if.m dev/smbus/smbus_if.m \
305268597acSMarcel Moolenaar	dev/sound/pcm/ac97_if.m dev/sound/pcm/channel_if.m \
306268597acSMarcel Moolenaar	dev/sound/pcm/feeder_if.m dev/sound/pcm/mixer_if.m dev/uart/uart_if.m \
307335e4ff3SNate Lawson	dev/usb/usb_if.m isa/isa_if.m \
308335e4ff3SNate Lawson	kern/bus_if.m kern/cpufreq_if.m kern/device_if.m \
309268597acSMarcel Moolenaar	libkern/iconv_converter_if.m opencrypto/crypto_if.m \
31021a0216eSMarius Strobl	pc98/pc98/canbus_if.m pci/agp_if.m
3117fecffecSDoug Rabson
3127fecffecSDoug Rabson.for _srcsrc in ${MFILES}
3134fea6704SBruce Evans.for _ext in c h
3144fea6704SBruce Evans.for _src in ${SRCS:M${_srcsrc:T:R}.${_ext}}
3154fea6704SBruce EvansCLEANFILES+=	${_src}
3164fea6704SBruce Evans.if !target(${_src})
317f3cc9575SWarner Losh.if !exists(@)
3184fea6704SBruce Evans${_src}: @
3199f73f0e8SRuslan Ermilov.else
3209fa411aeSDavid E. O'Brien${_src}: @/tools/makeobjops.awk @/${_srcsrc}
3214fea6704SBruce Evans.endif
3229fa411aeSDavid E. O'Brien	${AWK} -f @/tools/makeobjops.awk @/${_srcsrc} -${_ext}
3234fea6704SBruce Evans.endif
3244fea6704SBruce Evans.endfor # _src
3254fea6704SBruce Evans.endfor # _ext
3264fea6704SBruce Evans.endfor # _srcsrc
3274fea6704SBruce Evans
32878b2c868SBrian Feldman.if ${SRCS:Mvnode_if.c} != ""
32978b2c868SBrian FeldmanCLEANFILES+=	vnode_if.c
330f3cc9575SWarner Losh.if !exists(@)
33178b2c868SBrian Feldmanvnode_if.c: @
3329f73f0e8SRuslan Ermilov.else
33378b2c868SBrian Feldmanvnode_if.c: @/tools/vnode_if.awk @/kern/vnode_if.src
3344fea6704SBruce Evans.endif
33578b2c868SBrian Feldman	${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -c
3364fea6704SBruce Evans.endif
33778b2c868SBrian Feldman
33878b2c868SBrian Feldman.if ${SRCS:Mvnode_if.h} != ""
3399f73f0e8SRuslan ErmilovCLEANFILES+=	vnode_if.h vnode_if_newproto.h vnode_if_typedef.h
34078b2c868SBrian Feldman.if !exists(@)
3419f73f0e8SRuslan Ermilovvnode_if.h vnode_if_newproto.h vnode_if_typedef.h: @
3429f73f0e8SRuslan Ermilov.else
3439f73f0e8SRuslan Ermilovvnode_if.h vnode_if_newproto.h vnode_if_typedef.h: @/tools/vnode_if.awk \
3449f73f0e8SRuslan Ermilov    @/kern/vnode_if.src
34578b2c868SBrian Feldman.endif
3469f73f0e8SRuslan Ermilovvnode_if.h: vnode_if_newproto.h vnode_if_typedef.h
34778b2c868SBrian Feldman	${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -h
3489f73f0e8SRuslan Ermilovvnode_if_newproto.h:
34978b2c868SBrian Feldman	${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -p
3509f73f0e8SRuslan Ermilovvnode_if_typedef.h:
35178b2c868SBrian Feldman	${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -q
35278b2c868SBrian Feldman.endif
3531aa57be3SGarrett Wollman
3544e91eaf2SWarner Losh.for _i in mii pccard
355dba6dd17SWarner Losh.if ${SRCS:M${_i}devs.h} != ""
356dba6dd17SWarner LoshCLEANFILES+=	${_i}devs.h
3572d3ce713SDavid E. O'Brien.if !exists(@)
358dba6dd17SWarner Losh${_i}devs.h: @
3599f73f0e8SRuslan Ermilov.else
360dba6dd17SWarner Losh${_i}devs.h: @/tools/${_i}devs2h.awk @/dev/${_i}/${_i}devs
3612d3ce713SDavid E. O'Brien.endif
362dba6dd17SWarner Losh	${AWK} -f @/tools/${_i}devs2h.awk @/dev/${_i}/${_i}devs
3632d3ce713SDavid E. O'Brien.endif
364dba6dd17SWarner Losh.endfor # _i
3652d3ce713SDavid E. O'Brien
3664e91eaf2SWarner Losh.if ${SRCS:Musbdevs.h} != ""
3674e91eaf2SWarner LoshCLEANFILES+=	usbdevs.h
3684e91eaf2SWarner Losh.if !exists(@)
3694e91eaf2SWarner Loshusbdevs.h: @
3704e91eaf2SWarner Losh.else
3714e91eaf2SWarner Loshusbdevs.h: @/tools/usbdevs2h.awk @/dev/usb/usbdevs
3724e91eaf2SWarner Losh.endif
3734e91eaf2SWarner Losh	${AWK} -f @/tools/usbdevs2h.awk @/dev/usb/usbdevs -h
3744e91eaf2SWarner Losh.endif
3754e91eaf2SWarner Losh
3764e91eaf2SWarner Losh.if ${SRCS:Musbdevs_data.h} != ""
3774e91eaf2SWarner LoshCLEANFILES+=	usbdevs_data.h
3784e91eaf2SWarner Losh.if !exists(@)
3794e91eaf2SWarner Loshusbdevs_data.h: @
3804e91eaf2SWarner Losh.else
3814e91eaf2SWarner Loshusbdevs_data.h: @/tools/usbdevs2h.awk @/dev/usb/usbdevs
3824e91eaf2SWarner Losh.endif
3834e91eaf2SWarner Losh	${AWK} -f @/tools/usbdevs2h.awk @/dev/usb/usbdevs -d
3844e91eaf2SWarner Losh.endif
3854e91eaf2SWarner Losh
386684c1c1dSNate Lawson.if ${SRCS:Macpi_quirks.h} != ""
387684c1c1dSNate LawsonCLEANFILES+=	acpi_quirks.h
388684c1c1dSNate Lawson.if !exists(@)
389684c1c1dSNate Lawsonacpi_quirks.h: @
3909f73f0e8SRuslan Ermilov.else
391684c1c1dSNate Lawsonacpi_quirks.h: @/tools/acpi_quirks2h.awk @/dev/acpica/acpi_quirks
392684c1c1dSNate Lawson.endif
393684c1c1dSNate Lawson	${AWK} -f @/tools/acpi_quirks2h.awk @/dev/acpica/acpi_quirks
394684c1c1dSNate Lawson.endif
395684c1c1dSNate Lawson
396766f7d6eSMark Murraylint: ${SRCS}
397bbb467cdSRuslan Ermilov	${LINT} ${LINTKERNFLAGS} ${CFLAGS:M-[DILU]*} ${.ALLSRC:M*.c}
398766f7d6eSMark Murray
39968e00b92SJordan K. Hubbard.include <bsd.dep.mk>
40047da63c3SBruce Evans
401f2bffe0fSRuslan Ermilov.if !exists(${.OBJDIR}/${DEPENDFILE})
402589d9341SBruce Evans${OBJS}: ${SRCS:M*.h}
40347da63c3SBruce Evans.endif
40447da63c3SBruce Evans
405afba897fSBruce Evans.include <bsd.obj.mk>
406ddc474a8SRuslan Ermilov.include "kern.mk"
407