xref: /freebsd/sys/conf/kmod.mk (revision fded756e72640c73ae2b7f026a32c7c21faef96d)
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/}
7206d6e4fcSTom Rhodes.endif
7348aea4daSRuslan ErmilovCFLAGS+=	-D_KERNEL
748fe644b2SMike SmithCFLAGS+=	-DKLD_MODULE
754a2d2630SBruce Evans
76021886ffSBruce Evans# Don't use any standard or source-relative include directories.
77021886ffSBruce Evans# Since -nostdinc will annull any previous -I paths, we repeat all
78021886ffSBruce Evans# such paths after -nostdinc.  It doesn't seem to be possible to
79021886ffSBruce Evans# add to the front of `make' variable.
80021886ffSBruce Evans_ICFLAGS:=	${CFLAGS:M-I*}
8106d6e4fcSTom Rhodes.if ${CC} == "icc"
8206d6e4fcSTom RhodesNOSTDINC=	-X
8306d6e4fcSTom Rhodes.else
8406d6e4fcSTom RhodesNOSTDINC=	-nostdinc
8506d6e4fcSTom Rhodes.endif
8606d6e4fcSTom RhodesCFLAGS+=	${NOSTDINC} -I- ${INCLMAGIC} ${_ICFLAGS}
878fa793d0SBrian Feldman.if defined(KERNBUILDDIR)
8875504450SBrian FeldmanCFLAGS+=	-include ${KERNBUILDDIR}/opt_global.h
898fa793d0SBrian Feldman.endif
90021886ffSBruce Evans
911f089616SRuslan Ermilov# Add -I paths for system headers.  Individual module makefiles don't
92021886ffSBruce Evans# need any -I paths for this.  Similar defaults for .PATH can't be
93021886ffSBruce Evans# set because there are no standard paths for non-headers.
9474455e55SWarner LoshCFLAGS+=	-I. -I@
954a2d2630SBruce Evans
9602b199f1SMax Laier# Add -I path for altq headers as they are included via net/if_var.h
9702b199f1SMax Laier# for example.
9802b199f1SMax LaierCFLAGS+=	-I@/contrib/altq
9902b199f1SMax Laier
100a0b845feSBruce Evans# Add a -I path to standard headers like <stddef.h>.  Use a relative
101a0b845feSBruce Evans# path to src/include if possible.  If the @ symlink hasn't been built
102a0b845feSBruce Evans# yet, then we can't tell if the relative path exists.  Add both the
103a0b845feSBruce Evans# potential relative path and an absolute path in that case.
104a0b845feSBruce Evans.if exists(@)
105a0b845feSBruce Evans.if exists(@/../include)
106a0b845feSBruce EvansCFLAGS+=	-I@/../include
107a0b845feSBruce Evans.else
108b3e17ba2SSatoshi AsamiCFLAGS+=	-I${DESTDIR}/usr/include
109b3e17ba2SSatoshi Asami.endif
110a0b845feSBruce Evans.else # !@
111a0b845feSBruce EvansCFLAGS+=	-I@/../include -I${DESTDIR}/usr/include
112a0b845feSBruce Evans.endif # @
11356bac51bSPoul-Henning Kamp
11406d6e4fcSTom Rhodes.if ${CC} != "icc"
115a92a2144SPeter WemmCFLAGS+=	-finline-limit=${INLINE_LIMIT}
11606d6e4fcSTom Rhodes.endif
1172a51529fSPeter Wemm
1180b3178a4SMike Smith# Disallow common variables, and if we end up with commons from
1190b3178a4SMike Smith# somewhere unexpected, allocate storage for them in the module itself.
12006d6e4fcSTom Rhodes.if ${CC} != "icc"
1210b3178a4SMike SmithCFLAGS+=	-fno-common
12206d6e4fcSTom Rhodes.endif
1230b3178a4SMike SmithLDFLAGS+=	-d -warn-common
1240b3178a4SMike Smith
1259e4be63dSBruce EvansCFLAGS+=	${DEBUG_FLAGS}
12683c457dcSIan Dowse.if ${MACHINE_ARCH} == amd64
12783c457dcSIan DowseCFLAGS+=	-fno-omit-frame-pointer
12883c457dcSIan Dowse.endif
1299e4be63dSBruce Evans
130fded756eSPeter Grehan.if ${MACHINE_ARCH} == "powerpc"
131fded756eSPeter GrehanCFLAGS+=	-mlongcall
132fded756eSPeter Grehan.endif
133fded756eSPeter Grehan
134639a2e50SGarrett WollmanOBJS+=	${SRCS:N*.h:R:S/$/.o/g}
135639a2e50SGarrett Wollman
136639a2e50SGarrett Wollman.if !defined(PROG)
13790f60fc9SMike SmithPROG=	${KMOD}.ko
13890f60fc9SMike Smith.endif
139639a2e50SGarrett Wollman
140817b59bfSRuslan Ermilov.if !defined(DEBUG_FLAGS)
141f6611608SSheldon HearnFULLPROG=	${PROG}
142f6611608SSheldon Hearn.else
143f6611608SSheldon HearnFULLPROG=	${PROG}.debug
144f6611608SSheldon Hearn${PROG}: ${FULLPROG}
145f6611608SSheldon Hearn	${OBJCOPY} --strip-debug ${FULLPROG} ${PROG}
146f6611608SSheldon Hearn.endif
147f6611608SSheldon Hearn
1484d6bcc83SPeter Wemm.if ${MACHINE_ARCH} != amd64
149f6611608SSheldon Hearn${FULLPROG}: ${KMOD}.kld
15009be11baSPeter Wemm	${LD} -Bshareable ${LDFLAGS} -o ${.TARGET} ${KMOD}.kld
151817b59bfSRuslan Ermilov.if !defined(DEBUG_FLAGS)
152817b59bfSRuslan Ermilov	${OBJCOPY} --strip-debug ${.TARGET}
1534c293d35SRuslan Ermilov.endif
1544d6bcc83SPeter Wemm.endif
15509be11baSPeter Wemm
15693f03548SMike SmithEXPORT_SYMS?=	NO
15793f03548SMike Smith.if ${EXPORT_SYMS} != YES
1581f089616SRuslan ErmilovCLEANFILES+=	export_syms
1590b3178a4SMike Smith.endif
1600b3178a4SMike Smith
1614d6bcc83SPeter Wemm.if ${MACHINE_ARCH} != amd64
16209be11baSPeter Wemm${KMOD}.kld: ${OBJS}
1634d6bcc83SPeter Wemm.else
1644d6bcc83SPeter Wemm${FULLPROG}: ${OBJS}
1654d6bcc83SPeter Wemm.endif
1660b3178a4SMike Smith	${LD} ${LDFLAGS} -r -d -o ${.TARGET} ${OBJS}
1670b3178a4SMike Smith.if defined(EXPORT_SYMS)
16893f03548SMike Smith.if ${EXPORT_SYMS} != YES
1690b3178a4SMike Smith.if ${EXPORT_SYMS} == NO
1701f089616SRuslan Ermilov	touch export_syms
1710b3178a4SMike Smith.elif !exists(${.CURDIR}/${EXPORT_SYMS})
1721f089616SRuslan Ermilov	echo ${EXPORT_SYMS} > export_syms
1730b3178a4SMike Smith.else
1741f089616SRuslan Ermilov	grep -v '^#' < ${EXPORT_SYMS} > export_syms
1750b3178a4SMike Smith.endif
1760b3178a4SMike Smith	awk -f ${SYSDIR}/conf/kmod_syms.awk ${.TARGET} \
1771f089616SRuslan Ermilov	    export_syms | xargs -J% ${OBJCOPY} % ${.TARGET}
17893f03548SMike Smith.endif
1790b3178a4SMike Smith.endif
1804d6bcc83SPeter Wemm.if !defined(DEBUG_FLAGS) && ${MACHINE_ARCH} == amd64
1814d6bcc83SPeter Wemm	${OBJCOPY} --strip-debug ${.TARGET}
1824d6bcc83SPeter Wemm.endif
1830b3178a4SMike Smith
1844a2d2630SBruce Evans_ILINKS=@ machine
185639a2e50SGarrett Wollman
186b25a566dSRuslan Ermilovall: objwarn ${PROG}
1874a2d2630SBruce Evans
188985f41afSWarner Loshbeforedepend: ${_ILINKS}
189985f41afSWarner Losh
190f3cc9575SWarner Losh# Ensure that the links exist without depending on it when it exists which
191f3cc9575SWarner Losh# causes all the modules to be rebuilt when the directory pointed to changes.
192f3cc9575SWarner Losh.for _link in ${_ILINKS}
193f3cc9575SWarner Losh.if !exists(${.OBJDIR}/${_link})
194f3cc9575SWarner Losh${OBJS}: ${_link}
195f3cc9575SWarner Losh.endif
196f3cc9575SWarner Losh.endfor
1974a2d2630SBruce Evans
1989a8631b3SWarner Losh# Search for kernel source tree in standard places.
1999a8631b3SWarner Losh.for _dir in ${.CURDIR}/../.. ${.CURDIR}/../../.. /sys /usr/src/sys
200776f50b9SRuslan Ermilov.if !defined(SYSDIR) && exists(${_dir}/kern/)
2019a8631b3SWarner LoshSYSDIR=	${_dir}
2029a8631b3SWarner Losh.endif
2039a8631b3SWarner Losh.endfor
204776f50b9SRuslan Ermilov.if !defined(SYSDIR) || !exists(${SYSDIR}/kern/)
2059a8631b3SWarner Losh.error "can't find kernel source tree"
2069a8631b3SWarner Losh.endif
2079a8631b3SWarner Losh
2084a2d2630SBruce Evans${_ILINKS}:
2099a8631b3SWarner Losh	@case ${.TARGET} in \
21008a04a89SPeter Wemm	machine) \
2119a8631b3SWarner Losh		path=${SYSDIR}/${MACHINE_ARCH}/include ;; \
21208a04a89SPeter Wemm	@) \
2139a8631b3SWarner Losh		path=${SYSDIR} ;; \
21408a04a89SPeter Wemm	esac ; \
21508a04a89SPeter Wemm	path=`(cd $$path && /bin/pwd)` ; \
21608a04a89SPeter Wemm	${ECHO} ${.TARGET} "->" $$path ; \
21708a04a89SPeter Wemm	ln -s $$path ${.TARGET}
2184a2d2630SBruce Evans
2191f089616SRuslan ErmilovCLEANFILES+= ${PROG} ${KMOD}.kld ${OBJS} ${_ILINKS}
220361186e5SMaxime Henrion
221817b59bfSRuslan Ermilov.if defined(DEBUG_FLAGS)
222361186e5SMaxime HenrionCLEANFILES+= ${FULLPROG}
223361186e5SMaxime Henrion.endif
224639a2e50SGarrett Wollman
225639a2e50SGarrett Wollman.if !target(install)
226639a2e50SGarrett Wollman
227ea87b3cbSDavid E. O'Brien_INSTALLFLAGS:=	${INSTALLFLAGS}
228e902c1bbSTim Vanderhoek.for ie in ${INSTALLFLAGS_EDIT}
229e902c1bbSTim Vanderhoek_INSTALLFLAGS:=	${_INSTALLFLAGS${ie}}
230e902c1bbSTim Vanderhoek.endfor
231e902c1bbSTim Vanderhoek
2321f089616SRuslan Ermilov.if !target(install.debug) && defined(DEBUG_FLAGS)
233b25a566dSRuslan Ermilovinstall.debug:
2342cbc81ffSRuslan Ermilov	cd ${.CURDIR}; ${MAKE} -DINSTALL_DEBUG install
2352cbc81ffSRuslan Ermilov.endif
236a4c00586SDag-Erling Smørgrav
2372b06260dSRuslan Ermilov.if !target(realinstall)
2382b06260dSRuslan Ermilovrealinstall: _kmodinstall
2392b06260dSRuslan Ermilov.ORDER: beforeinstall _kmodinstall
2402b06260dSRuslan Ermilov_kmodinstall:
241817b59bfSRuslan Ermilov.if defined(DEBUG_FLAGS) && defined(INSTALL_DEBUG)
242d2893b16SRuslan Ermilov	${INSTALL} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \
2432b06260dSRuslan Ermilov	    ${_INSTALLFLAGS} ${FULLPROG} ${DESTDIR}${KMODDIR}
2442cbc81ffSRuslan Ermilov.else
245d2893b16SRuslan Ermilov	${INSTALL} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \
2462b06260dSRuslan Ermilov	    ${_INSTALLFLAGS} ${PROG} ${DESTDIR}${KMODDIR}
2472b06260dSRuslan Ermilov
2482b06260dSRuslan Ermilov.include <bsd.links.mk>
2492b06260dSRuslan Ermilov
2504875819cSJake Burkholder.if !defined(NO_XREF)
2512b06260dSRuslan Ermilovafterinstall: _kldxref
2522b06260dSRuslan Ermilov.ORDER: realinstall _kldxref
2532b06260dSRuslan Ermilov.ORDER: _installlinks _kldxref
2542b06260dSRuslan Ermilov_kldxref:
255be1d673dSRuslan Ermilov	@if type kldxref >/dev/null 2>&1; then \
256be1d673dSRuslan Ermilov		${ECHO} kldxref ${DESTDIR}${KMODDIR}; \
257be1d673dSRuslan Ermilov		kldxref ${DESTDIR}${KMODDIR}; \
258be1d673dSRuslan Ermilov	fi
259505222d3SPeter Wemm.endif
2602cbc81ffSRuslan Ermilov.endif
2612b06260dSRuslan Ermilov.endif !target(realinstall)
262639a2e50SGarrett Wollman
2632b06260dSRuslan Ermilov.endif !target(install)
264639a2e50SGarrett Wollman
265639a2e50SGarrett Wollman.if !target(load)
2669a8631b3SWarner Loshload: ${PROG}
2671f089616SRuslan Ermilov	${KMODLOAD} -v ${.OBJDIR}/${PROG}
268639a2e50SGarrett Wollman.endif
269639a2e50SGarrett Wollman
270639a2e50SGarrett Wollman.if !target(unload)
271fe3cac87SNick Hibmaunload:
2721f089616SRuslan Ermilov	${KMODUNLOAD} -v ${PROG}
27308a04a89SPeter Wemm.endif
2741aa57be3SGarrett Wollman
2756b1bb559SWarner Losh.if defined(KERNBUILDDIR)
2766b1bb559SWarner Losh.PATH: ${KERNBUILDDIR}
2776b1bb559SWarner LoshCFLAGS+=	-I${KERNBUILDDIR}
2786b1bb559SWarner Losh.for _src in ${SRCS:Mopt_*.h}
2796b1bb559SWarner LoshCLEANFILES+=	${_src}
2806b1bb559SWarner Losh.if !target(${_src})
2816b1bb559SWarner Losh${_src}:
28231e81ae4SJoerg Wunsch	ln -s ${KERNBUILDDIR}/${_src} ${.TARGET}
2836b1bb559SWarner Losh.endif
2846b1bb559SWarner Losh.endfor
2856b1bb559SWarner Losh.else
2864fea6704SBruce Evans.for _src in ${SRCS:Mopt_*.h}
2874fea6704SBruce EvansCLEANFILES+=	${_src}
2884fea6704SBruce Evans.if !target(${_src})
2894fea6704SBruce Evans${_src}:
2904fea6704SBruce Evans	touch ${.TARGET}
2914fea6704SBruce Evans.endif
2924fea6704SBruce Evans.endfor
2936b1bb559SWarner Losh.endif
2944fea6704SBruce Evans
295268597acSMarcel MoolenaarMFILES?= dev/acpica/acpi_if.m dev/eisa/eisa_if.m dev/iicbus/iicbb_if.m \
296268597acSMarcel Moolenaar	dev/iicbus/iicbus_if.m dev/mii/miibus_if.m dev/ofw/ofw_bus_if.m \
2977e820aaaSMike Smith	dev/pccard/card_if.m dev/pccard/power_if.m dev/pci/pci_if.m \
2987e820aaaSMike Smith	dev/pci/pcib_if.m dev/ppbus/ppbus_if.m dev/smbus/smbus_if.m \
299268597acSMarcel Moolenaar	dev/sound/pcm/ac97_if.m dev/sound/pcm/channel_if.m \
300268597acSMarcel Moolenaar	dev/sound/pcm/feeder_if.m dev/sound/pcm/mixer_if.m dev/uart/uart_if.m \
301268597acSMarcel Moolenaar	dev/usb/usb_if.m isa/isa_if.m kern/bus_if.m kern/device_if.m \
302268597acSMarcel Moolenaar	libkern/iconv_converter_if.m opencrypto/crypto_if.m \
30321a0216eSMarius Strobl	pc98/pc98/canbus_if.m pci/agp_if.m
3047fecffecSDoug Rabson
3057fecffecSDoug Rabson.for _srcsrc in ${MFILES}
3064fea6704SBruce Evans.for _ext in c h
3074fea6704SBruce Evans.for _src in ${SRCS:M${_srcsrc:T:R}.${_ext}}
3084fea6704SBruce EvansCLEANFILES+=	${_src}
3094fea6704SBruce Evans.if !target(${_src})
310f3cc9575SWarner Losh.if !exists(@)
3114fea6704SBruce Evans${_src}: @
3129f73f0e8SRuslan Ermilov.else
3139fa411aeSDavid E. O'Brien${_src}: @/tools/makeobjops.awk @/${_srcsrc}
3144fea6704SBruce Evans.endif
3159fa411aeSDavid E. O'Brien	${AWK} -f @/tools/makeobjops.awk @/${_srcsrc} -${_ext}
3164fea6704SBruce Evans.endif
3174fea6704SBruce Evans.endfor # _src
3184fea6704SBruce Evans.endfor # _ext
3194fea6704SBruce Evans.endfor # _srcsrc
3204fea6704SBruce Evans
32178b2c868SBrian Feldman.if ${SRCS:Mvnode_if.c} != ""
32278b2c868SBrian FeldmanCLEANFILES+=	vnode_if.c
323f3cc9575SWarner Losh.if !exists(@)
32478b2c868SBrian Feldmanvnode_if.c: @
3259f73f0e8SRuslan Ermilov.else
32678b2c868SBrian Feldmanvnode_if.c: @/tools/vnode_if.awk @/kern/vnode_if.src
3274fea6704SBruce Evans.endif
32878b2c868SBrian Feldman	${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -c
3294fea6704SBruce Evans.endif
33078b2c868SBrian Feldman
33178b2c868SBrian Feldman.if ${SRCS:Mvnode_if.h} != ""
3329f73f0e8SRuslan ErmilovCLEANFILES+=	vnode_if.h vnode_if_newproto.h vnode_if_typedef.h
33378b2c868SBrian Feldman.if !exists(@)
3349f73f0e8SRuslan Ermilovvnode_if.h vnode_if_newproto.h vnode_if_typedef.h: @
3359f73f0e8SRuslan Ermilov.else
3369f73f0e8SRuslan Ermilovvnode_if.h vnode_if_newproto.h vnode_if_typedef.h: @/tools/vnode_if.awk \
3379f73f0e8SRuslan Ermilov    @/kern/vnode_if.src
33878b2c868SBrian Feldman.endif
3399f73f0e8SRuslan Ermilovvnode_if.h: vnode_if_newproto.h vnode_if_typedef.h
34078b2c868SBrian Feldman	${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -h
3419f73f0e8SRuslan Ermilovvnode_if_newproto.h:
34278b2c868SBrian Feldman	${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -p
3439f73f0e8SRuslan Ermilovvnode_if_typedef.h:
34478b2c868SBrian Feldman	${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -q
34578b2c868SBrian Feldman.endif
3461aa57be3SGarrett Wollman
3474e91eaf2SWarner Losh.for _i in mii pccard
348dba6dd17SWarner Losh.if ${SRCS:M${_i}devs.h} != ""
349dba6dd17SWarner LoshCLEANFILES+=	${_i}devs.h
3502d3ce713SDavid E. O'Brien.if !exists(@)
351dba6dd17SWarner Losh${_i}devs.h: @
3529f73f0e8SRuslan Ermilov.else
353dba6dd17SWarner Losh${_i}devs.h: @/tools/${_i}devs2h.awk @/dev/${_i}/${_i}devs
3542d3ce713SDavid E. O'Brien.endif
355dba6dd17SWarner Losh	${AWK} -f @/tools/${_i}devs2h.awk @/dev/${_i}/${_i}devs
3562d3ce713SDavid E. O'Brien.endif
357dba6dd17SWarner Losh.endfor # _i
3582d3ce713SDavid E. O'Brien
3594e91eaf2SWarner Losh.if ${SRCS:Musbdevs.h} != ""
3604e91eaf2SWarner LoshCLEANFILES+=	usbdevs.h
3614e91eaf2SWarner Losh.if !exists(@)
3624e91eaf2SWarner Loshusbdevs.h: @
3634e91eaf2SWarner Losh.else
3644e91eaf2SWarner Loshusbdevs.h: @/tools/usbdevs2h.awk @/dev/usb/usbdevs
3654e91eaf2SWarner Losh.endif
3664e91eaf2SWarner Losh	${AWK} -f @/tools/usbdevs2h.awk @/dev/usb/usbdevs -h
3674e91eaf2SWarner Losh.endif
3684e91eaf2SWarner Losh
3694e91eaf2SWarner Losh.if ${SRCS:Musbdevs_data.h} != ""
3704e91eaf2SWarner LoshCLEANFILES+=	usbdevs_data.h
3714e91eaf2SWarner Losh.if !exists(@)
3724e91eaf2SWarner Loshusbdevs_data.h: @
3734e91eaf2SWarner Losh.else
3744e91eaf2SWarner Loshusbdevs_data.h: @/tools/usbdevs2h.awk @/dev/usb/usbdevs
3754e91eaf2SWarner Losh.endif
3764e91eaf2SWarner Losh	${AWK} -f @/tools/usbdevs2h.awk @/dev/usb/usbdevs -d
3774e91eaf2SWarner Losh.endif
3784e91eaf2SWarner Losh
379684c1c1dSNate Lawson.if ${SRCS:Macpi_quirks.h} != ""
380684c1c1dSNate LawsonCLEANFILES+=	acpi_quirks.h
381684c1c1dSNate Lawson.if !exists(@)
382684c1c1dSNate Lawsonacpi_quirks.h: @
3839f73f0e8SRuslan Ermilov.else
384684c1c1dSNate Lawsonacpi_quirks.h: @/tools/acpi_quirks2h.awk @/dev/acpica/acpi_quirks
385684c1c1dSNate Lawson.endif
386684c1c1dSNate Lawson	${AWK} -f @/tools/acpi_quirks2h.awk @/dev/acpica/acpi_quirks
387684c1c1dSNate Lawson.endif
388684c1c1dSNate Lawson
389766f7d6eSMark Murraylint: ${SRCS}
390bbb467cdSRuslan Ermilov	${LINT} ${LINTKERNFLAGS} ${CFLAGS:M-[DILU]*} ${.ALLSRC:M*.c}
391766f7d6eSMark Murray
39268e00b92SJordan K. Hubbard.include <bsd.dep.mk>
39347da63c3SBruce Evans
394f2bffe0fSRuslan Ermilov.if !exists(${.OBJDIR}/${DEPENDFILE})
395589d9341SBruce Evans${OBJS}: ${SRCS:M*.h}
39647da63c3SBruce Evans.endif
39747da63c3SBruce Evans
398afba897fSBruce Evans.include <bsd.obj.mk>
399ddc474a8SRuslan Ermilov.include "kern.mk"
400