1639a2e50SGarrett Wollman# From: @(#)bsd.prog.mk 5.26 (Berkeley) 6/25/91 27f3dea24SPeter Wemm# $FreeBSD$ 353996fadSWolfram Schneider# 4fe3cac87SNick Hibma# The include file <bsd.kmod.mk> handles installing Kernel Loadable Device 5fe3cac87SNick Hibma# drivers (KLD's). 653996fadSWolfram Schneider# 753996fadSWolfram Schneider# 853996fadSWolfram Schneider# +++ variables +++ 953996fadSWolfram Schneider# 1053996fadSWolfram Schneider# CLEANFILES Additional files to remove for the clean and cleandir targets. 1153996fadSWolfram Schneider# 12fe3cac87SNick Hibma# KMOD The name of the kernel module to build. 1353996fadSWolfram Schneider# 143bdfa9e5SDavid E. O'Brien# KMODDIR Base path for kernel modules (see kld(4)). [/boot/kernel] 1553996fadSWolfram Schneider# 16fe3cac87SNick Hibma# KMODOWN KLD owner. [${BINOWN}] 1753996fadSWolfram Schneider# 18fe3cac87SNick Hibma# KMODGRP KLD group. [${BINGRP}] 1953996fadSWolfram Schneider# 20fe3cac87SNick Hibma# KMODMODE KLD mode. [${BINMODE}] 2153996fadSWolfram Schneider# 22fe3cac87SNick Hibma# KMODLOAD Command to load a kernel module [/sbin/kldload] 237bc830bbSWolfram Schneider# 24fe3cac87SNick Hibma# KMODUNLOAD Command to unload a kernel module [/sbin/kldunload] 257bc830bbSWolfram Schneider# 26fe3cac87SNick Hibma# PROG The name of the kernel module to build. 277bc830bbSWolfram Schneider# If not supplied, ${KMOD}.o is used. 2853996fadSWolfram Schneider# 2953996fadSWolfram Schneider# SRCS List of source files 3053996fadSWolfram Schneider# 312b06260dSRuslan Ermilov# DESTDIR Change the tree where the module gets installed. [not set] 3253996fadSWolfram Schneider# 337fecffecSDoug Rabson# MFILES Optionally a list of interfaces used by the module. 347fecffecSDoug Rabson# This file contains a default list of interfaces. 3553996fadSWolfram Schneider# 360b3178a4SMike Smith# EXPORT_SYMS A list of symbols that should be exported from the module, 3793f03548SMike Smith# or the name of a file containing a list of symbols, or YES 3893f03548SMike Smith# to export all symbols. If not defined, no symbols are 390b3178a4SMike Smith# exported. 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: 51fe3cac87SNick Hibma# Load KLD. 5253996fadSWolfram Schneider# 5353996fadSWolfram Schneider# unload: 54fe3cac87SNick Hibma# Unload KLD. 5553996fadSWolfram Schneider# 5653996fadSWolfram Schneider# bsd.obj.mk: clean, cleandir and obj 57161e8999SBruce Evans# bsd.dep.mk: cleandepend, depend and tags 5853996fadSWolfram Schneider# 59639a2e50SGarrett Wollman 60b7bbb709SDavid E. O'BrienAWK?= awk 61fe3cac87SNick HibmaKMODLOAD?= /sbin/kldload 62fe3cac87SNick HibmaKMODUNLOAD?= /sbin/kldunload 63f6611608SSheldon HearnOBJCOPY?= objcopy 647bc830bbSWolfram Schneider 6506639be7SPeter Wemm.if defined(KMODDEPS) 6606639be7SPeter Wemm.error "Do not use KMODDEPS on 5.0+, use MODULE_VERSION/MODULE_DEPEND" 6706639be7SPeter Wemm.endif 6806639be7SPeter Wemm 690ac2fc87SRuslan Ermilov.include <bsd.init.mk> 70639a2e50SGarrett Wollman 71639a2e50SGarrett Wollman.SUFFIXES: .out .o .c .cc .cxx .C .y .l .s .S 72639a2e50SGarrett Wollman 7306d6e4fcSTom Rhodes.if ${CC} == "icc" 7406d6e4fcSTom Rhodes_ICC_CFLAGS:= ${CFLAGS:C/(-x[^M^K^W]+)[MKW]+|-x[MKW]+/\1/} 7506d6e4fcSTom RhodesCFLAGS= ${_ICC_CFLAGS} 7606d6e4fcSTom Rhodes.endif 77e0dd77fdSRuslan ErmilovCFLAGS+= ${COPTS} -D_KERNEL 788fe644b2SMike SmithCFLAGS+= -DKLD_MODULE 794a2d2630SBruce Evans 80021886ffSBruce Evans# Don't use any standard or source-relative include directories. 81021886ffSBruce Evans# Since -nostdinc will annull any previous -I paths, we repeat all 82021886ffSBruce Evans# such paths after -nostdinc. It doesn't seem to be possible to 83021886ffSBruce Evans# add to the front of `make' variable. 84021886ffSBruce Evans_ICFLAGS:= ${CFLAGS:M-I*} 8506d6e4fcSTom Rhodes.if ${CC} == "icc" 8606d6e4fcSTom RhodesNOSTDINC= -X 8706d6e4fcSTom Rhodes.else 8806d6e4fcSTom RhodesNOSTDINC= -nostdinc 8906d6e4fcSTom Rhodes.endif 9006d6e4fcSTom RhodesCFLAGS+= ${NOSTDINC} -I- ${INCLMAGIC} ${_ICFLAGS} 918fa793d0SBrian Feldman.if defined(KERNBUILDDIR) 9275504450SBrian FeldmanCFLAGS+= -include ${KERNBUILDDIR}/opt_global.h 938fa793d0SBrian Feldman.endif 94021886ffSBruce Evans 95fe3cac87SNick Hibma# Add -I paths for system headers. Individual KLD makefiles don't 96021886ffSBruce Evans# need any -I paths for this. Similar defaults for .PATH can't be 97021886ffSBruce Evans# set because there are no standard paths for non-headers. 9874455e55SWarner LoshCFLAGS+= -I. -I@ 994a2d2630SBruce Evans 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} 1269e4be63dSBruce Evans 127639a2e50SGarrett WollmanOBJS+= ${SRCS:N*.h:R:S/$/.o/g} 128639a2e50SGarrett Wollman 129639a2e50SGarrett Wollman.if !defined(PROG) 13090f60fc9SMike SmithPROG= ${KMOD}.ko 13190f60fc9SMike Smith.endif 132639a2e50SGarrett Wollman 133817b59bfSRuslan Ermilov.if !defined(DEBUG_FLAGS) 134f6611608SSheldon HearnFULLPROG= ${PROG} 135f6611608SSheldon Hearn.else 136f6611608SSheldon HearnFULLPROG= ${PROG}.debug 137f6611608SSheldon Hearn${PROG}: ${FULLPROG} 138f6611608SSheldon Hearn ${OBJCOPY} --strip-debug ${FULLPROG} ${PROG} 139f6611608SSheldon Hearn.endif 140f6611608SSheldon Hearn 141f6611608SSheldon Hearn${FULLPROG}: ${KMOD}.kld 14209be11baSPeter Wemm ${LD} -Bshareable ${LDFLAGS} -o ${.TARGET} ${KMOD}.kld 143817b59bfSRuslan Ermilov.if !defined(DEBUG_FLAGS) 144817b59bfSRuslan Ermilov ${OBJCOPY} --strip-debug ${.TARGET} 1454c293d35SRuslan Ermilov.endif 14609be11baSPeter Wemm 14793f03548SMike SmithEXPORT_SYMS?= NO 14893f03548SMike Smith.if ${EXPORT_SYMS} != YES 1490b3178a4SMike SmithCLEANFILES+= ${.OBJDIR}/export_syms 1500b3178a4SMike Smith.endif 1510b3178a4SMike Smith 15209be11baSPeter Wemm${KMOD}.kld: ${OBJS} 1530b3178a4SMike Smith ${LD} ${LDFLAGS} -r -d -o ${.TARGET} ${OBJS} 1540b3178a4SMike Smith.if defined(EXPORT_SYMS) 15593f03548SMike Smith.if ${EXPORT_SYMS} != YES 1560b3178a4SMike Smith.if ${EXPORT_SYMS} == NO 1570b3178a4SMike Smith touch ${.OBJDIR}/export_syms 1580b3178a4SMike Smith.elif !exists(${.CURDIR}/${EXPORT_SYMS}) 1590b3178a4SMike Smith echo ${EXPORT_SYMS} > ${.OBJDIR}/export_syms 1600b3178a4SMike Smith.else 1610b3178a4SMike Smith grep -v '^#' < ${EXPORT_SYMS} > ${.OBJDIR}/export_syms 1620b3178a4SMike Smith.endif 1630b3178a4SMike Smith awk -f ${SYSDIR}/conf/kmod_syms.awk ${.TARGET} \ 1640b3178a4SMike Smith ${.OBJDIR}/export_syms | \ 16593f03548SMike Smith xargs -J% ${OBJCOPY} % ${.TARGET} 16693f03548SMike Smith.endif 1670b3178a4SMike Smith.endif 1680b3178a4SMike Smith 1694a2d2630SBruce Evans_ILINKS=@ machine 170639a2e50SGarrett Wollman 171b25a566dSRuslan Ermilovall: objwarn ${PROG} 1724a2d2630SBruce Evans 173985f41afSWarner Loshbeforedepend: ${_ILINKS} 174985f41afSWarner Losh @rm -f .depend 175985f41afSWarner Losh 176f3cc9575SWarner Losh# Ensure that the links exist without depending on it when it exists which 177f3cc9575SWarner Losh# causes all the modules to be rebuilt when the directory pointed to changes. 178f3cc9575SWarner Losh.for _link in ${_ILINKS} 179f3cc9575SWarner Losh.if !exists(${.OBJDIR}/${_link}) 180f3cc9575SWarner Losh${OBJS}: ${_link} 181f3cc9575SWarner Losh.endif 182f3cc9575SWarner Losh.endfor 1834a2d2630SBruce Evans 1849a8631b3SWarner Losh# Search for kernel source tree in standard places. 1859a8631b3SWarner Losh.for _dir in ${.CURDIR}/../.. ${.CURDIR}/../../.. /sys /usr/src/sys 186776f50b9SRuslan Ermilov.if !defined(SYSDIR) && exists(${_dir}/kern/) 1879a8631b3SWarner LoshSYSDIR= ${_dir} 1889a8631b3SWarner Losh.endif 1899a8631b3SWarner Losh.endfor 190776f50b9SRuslan Ermilov.if !defined(SYSDIR) || !exists(${SYSDIR}/kern/) 1919a8631b3SWarner Losh.error "can't find kernel source tree" 1929a8631b3SWarner Losh.endif 1939a8631b3SWarner Losh 1944a2d2630SBruce Evans${_ILINKS}: 1959a8631b3SWarner Losh @case ${.TARGET} in \ 19608a04a89SPeter Wemm machine) \ 1979a8631b3SWarner Losh path=${SYSDIR}/${MACHINE_ARCH}/include ;; \ 19808a04a89SPeter Wemm @) \ 1999a8631b3SWarner Losh path=${SYSDIR} ;; \ 20008a04a89SPeter Wemm esac ; \ 20108a04a89SPeter Wemm path=`(cd $$path && /bin/pwd)` ; \ 20208a04a89SPeter Wemm ${ECHO} ${.TARGET} "->" $$path ; \ 20308a04a89SPeter Wemm ln -s $$path ${.TARGET} 2044a2d2630SBruce Evans 205361186e5SMaxime HenrionCLEANFILES+= ${PROG} ${KMOD}.kld ${OBJS} ${_ILINKS} symb.tmp tmp.o 206361186e5SMaxime Henrion 207817b59bfSRuslan Ermilov.if defined(DEBUG_FLAGS) 208361186e5SMaxime HenrionCLEANFILES+= ${FULLPROG} 209361186e5SMaxime Henrion.endif 210639a2e50SGarrett Wollman 211639a2e50SGarrett Wollman.if !target(install) 212639a2e50SGarrett Wollman 213ea87b3cbSDavid E. O'Brien_INSTALLFLAGS:= ${INSTALLFLAGS} 214e902c1bbSTim Vanderhoek.for ie in ${INSTALLFLAGS_EDIT} 215e902c1bbSTim Vanderhoek_INSTALLFLAGS:= ${_INSTALLFLAGS${ie}} 216e902c1bbSTim Vanderhoek.endfor 217e902c1bbSTim Vanderhoek 218817b59bfSRuslan Ermilov.if defined(DEBUG_FLAGS) 219b25a566dSRuslan Ermilovinstall.debug: 2202cbc81ffSRuslan Ermilov cd ${.CURDIR}; ${MAKE} -DINSTALL_DEBUG install 2212cbc81ffSRuslan Ermilov.endif 222a4c00586SDag-Erling Smørgrav 2232b06260dSRuslan Ermilov.if !target(realinstall) 2242b06260dSRuslan Ermilovrealinstall: _kmodinstall 2252b06260dSRuslan Ermilov.ORDER: beforeinstall _kmodinstall 2262b06260dSRuslan Ermilov_kmodinstall: 227817b59bfSRuslan Ermilov.if defined(DEBUG_FLAGS) && defined(INSTALL_DEBUG) 228d2893b16SRuslan Ermilov ${INSTALL} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \ 2292b06260dSRuslan Ermilov ${_INSTALLFLAGS} ${FULLPROG} ${DESTDIR}${KMODDIR} 2302cbc81ffSRuslan Ermilov.else 231d2893b16SRuslan Ermilov ${INSTALL} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \ 2322b06260dSRuslan Ermilov ${_INSTALLFLAGS} ${PROG} ${DESTDIR}${KMODDIR} 2332b06260dSRuslan Ermilov 2342b06260dSRuslan Ermilov.include <bsd.links.mk> 2352b06260dSRuslan Ermilov 2364875819cSJake Burkholder.if !defined(NO_XREF) 2372b06260dSRuslan Ermilovafterinstall: _kldxref 2382b06260dSRuslan Ermilov.ORDER: realinstall _kldxref 2392b06260dSRuslan Ermilov.ORDER: _installlinks _kldxref 2402b06260dSRuslan Ermilov_kldxref: 241be1d673dSRuslan Ermilov @if type kldxref >/dev/null 2>&1; then \ 242be1d673dSRuslan Ermilov ${ECHO} kldxref ${DESTDIR}${KMODDIR}; \ 243be1d673dSRuslan Ermilov kldxref ${DESTDIR}${KMODDIR}; \ 244be1d673dSRuslan Ermilov fi 245505222d3SPeter Wemm.endif 2462cbc81ffSRuslan Ermilov.endif 2472b06260dSRuslan Ermilov.endif !target(realinstall) 248639a2e50SGarrett Wollman 2492b06260dSRuslan Ermilov.endif !target(install) 250639a2e50SGarrett Wollman 251639a2e50SGarrett Wollman.if !target(load) 2529a8631b3SWarner Loshload: ${PROG} 253dba3dc7bSNick Hibma ${KMODLOAD} -v ${.OBJDIR}/${KMOD}.ko 254639a2e50SGarrett Wollman.endif 255639a2e50SGarrett Wollman 256639a2e50SGarrett Wollman.if !target(unload) 257fe3cac87SNick Hibmaunload: 2589a8631b3SWarner Losh ${KMODUNLOAD} -v ${KMOD} 25908a04a89SPeter Wemm.endif 2601aa57be3SGarrett Wollman 2616b1bb559SWarner Losh.if defined(KERNBUILDDIR) 2626b1bb559SWarner Losh.PATH: ${KERNBUILDDIR} 2636b1bb559SWarner LoshCFLAGS += -I${KERNBUILDDIR} 2646b1bb559SWarner Losh.for _src in ${SRCS:Mopt_*.h} 2656b1bb559SWarner LoshCLEANFILES+= ${_src} 2666b1bb559SWarner Losh.if !target(${_src}) 2676b1bb559SWarner Losh${_src}: 2683193579bSWarner Losh ln -s ${KERNBUILDDIR}/${_src} ${.TARGET} 2696b1bb559SWarner Losh.endif 2706b1bb559SWarner Losh.endfor 2716b1bb559SWarner Losh.else 2724fea6704SBruce Evans.for _src in ${SRCS:Mopt_*.h} 2734fea6704SBruce EvansCLEANFILES+= ${_src} 2744fea6704SBruce Evans.if !target(${_src}) 2754fea6704SBruce Evans${_src}: 2764fea6704SBruce Evans touch ${.TARGET} 2774fea6704SBruce Evans.endif 2784fea6704SBruce Evans.endfor 2796b1bb559SWarner Losh.endif 2804fea6704SBruce Evans 2817fecffecSDoug RabsonMFILES?= kern/bus_if.m kern/device_if.m dev/iicbus/iicbb_if.m \ 2826f2d8adbSBoris Popov dev/iicbus/iicbus_if.m isa/isa_if.m \ 2836f2d8adbSBoris Popov libkern/iconv_converter_if.m \ 2846f2d8adbSBoris Popov dev/mii/miibus_if.m \ 2857e820aaaSMike Smith dev/pccard/card_if.m dev/pccard/power_if.m dev/pci/pci_if.m \ 2867e820aaaSMike Smith dev/pci/pcib_if.m dev/ppbus/ppbus_if.m dev/smbus/smbus_if.m \ 2870f55ac6cSCameron Grant dev/usb/usb_if.m dev/sound/pcm/ac97_if.m dev/sound/pcm/channel_if.m \ 288c4f9e3aeSSam Leffler dev/sound/pcm/feeder_if.m dev/sound/pcm/mixer_if.m pci/agp_if.m \ 2892bec1c89SMarcel Moolenaar opencrypto/crypto_if.m pc98/pc98/canbus_if.m dev/uart/uart_if.m 2907fecffecSDoug Rabson 2917fecffecSDoug Rabson.for _srcsrc in ${MFILES} 2924fea6704SBruce Evans.for _ext in c h 2934fea6704SBruce Evans.for _src in ${SRCS:M${_srcsrc:T:R}.${_ext}} 2944fea6704SBruce EvansCLEANFILES+= ${_src} 2954fea6704SBruce Evans.if !target(${_src}) 296f3cc9575SWarner Losh.if !exists(@) 2974fea6704SBruce Evans${_src}: @ 298f3cc9575SWarner Losh.endif 2994fea6704SBruce Evans.if exists(@) 3009fa411aeSDavid E. O'Brien${_src}: @/tools/makeobjops.awk @/${_srcsrc} 3014fea6704SBruce Evans.endif 3029fa411aeSDavid E. O'Brien ${AWK} -f @/tools/makeobjops.awk @/${_srcsrc} -${_ext} 3034fea6704SBruce Evans.endif 3044fea6704SBruce Evans.endfor # _src 3054fea6704SBruce Evans.endfor # _ext 3064fea6704SBruce Evans.endfor # _srcsrc 3074fea6704SBruce Evans 3089029b644SPeter Wemm.for _ext in c h 3099029b644SPeter Wemm.if ${SRCS:Mvnode_if.${_ext}} != "" 3109029b644SPeter WemmCLEANFILES+= vnode_if.${_ext} 311f3cc9575SWarner Losh.if !exists(@) 3129029b644SPeter Wemmvnode_if.${_ext}: @ 313f3cc9575SWarner Losh.endif 3144fea6704SBruce Evans.if exists(@) 315b7bbb709SDavid E. O'Brienvnode_if.${_ext}: @/tools/vnode_if.awk @/kern/vnode_if.src 3164fea6704SBruce Evans.endif 317b7bbb709SDavid E. O'Brien ${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -${_ext} 3184fea6704SBruce Evans.endif 3199029b644SPeter Wemm.endfor 3201aa57be3SGarrett Wollman 3212d3ce713SDavid E. O'Brien.if ${SRCS:Mmiidevs.h} != "" 3222d3ce713SDavid E. O'BrienCLEANFILES+= miidevs.h 3232d3ce713SDavid E. O'Brien.if !exists(@) 3242d3ce713SDavid E. O'Brienmiidevs.h: @ 3252d3ce713SDavid E. O'Brien.endif 3262d3ce713SDavid E. O'Brien.if exists(@) 3272d3ce713SDavid E. O'Brienmiidevs.h: @/tools/devlist2h.awk @/dev/mii/miidevs 3282d3ce713SDavid E. O'Brien.endif 3292d3ce713SDavid E. O'Brien ${AWK} -f @/tools/devlist2h.awk @/dev/mii/miidevs 3302d3ce713SDavid E. O'Brien.endif 3312d3ce713SDavid E. O'Brien 33271395925SPeter Wemmregress: 33369b87d3eSEivind Eklund 334766f7d6eSMark Murraylint: ${SRCS} 335bbb467cdSRuslan Ermilov ${LINT} ${LINTKERNFLAGS} ${CFLAGS:M-[DILU]*} ${.ALLSRC:M*.c} 336766f7d6eSMark Murray 33768e00b92SJordan K. Hubbard.include <bsd.dep.mk> 33847da63c3SBruce Evans 339f2bffe0fSRuslan Ermilov.if !exists(${.OBJDIR}/${DEPENDFILE}) 340589d9341SBruce Evans${OBJS}: ${SRCS:M*.h} 34147da63c3SBruce Evans.endif 34247da63c3SBruce Evans 343afba897fSBruce Evans.include <bsd.obj.mk> 344ddc474a8SRuslan Ermilov.include "kern.mk" 345