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 73c4473420SPeter WemmCFLAGS+= ${COPTS} -D_KERNEL ${CWARNFLAGS} 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*} 8126dac111SPoul-Henning KampCFLAGS+= -nostdinc -I- ${INCLMAGIC} ${_ICFLAGS} 82021886ffSBruce Evans 83fe3cac87SNick Hibma# Add -I paths for system headers. Individual KLD makefiles don't 84021886ffSBruce Evans# need any -I paths for this. Similar defaults for .PATH can't be 85021886ffSBruce Evans# set because there are no standard paths for non-headers. 867e820aaaSMike SmithCFLAGS+= -I. -I@ -I@/dev 874a2d2630SBruce Evans 88a0b845feSBruce Evans# Add a -I path to standard headers like <stddef.h>. Use a relative 89a0b845feSBruce Evans# path to src/include if possible. If the @ symlink hasn't been built 90a0b845feSBruce Evans# yet, then we can't tell if the relative path exists. Add both the 91a0b845feSBruce Evans# potential relative path and an absolute path in that case. 92a0b845feSBruce Evans.if exists(@) 93a0b845feSBruce Evans.if exists(@/../include) 94a0b845feSBruce EvansCFLAGS+= -I@/../include 95a0b845feSBruce Evans.else 96b3e17ba2SSatoshi AsamiCFLAGS+= -I${DESTDIR}/usr/include 97b3e17ba2SSatoshi Asami.endif 98a0b845feSBruce Evans.else # !@ 99a0b845feSBruce EvansCFLAGS+= -I@/../include -I${DESTDIR}/usr/include 100a0b845feSBruce Evans.endif # @ 10156bac51bSPoul-Henning Kamp 1022a51529fSPeter WemmINLINE_LIMIT?= 2500 1032a51529fSPeter WemmCFLAGS+= --param max-inline-insns-single=${INLINE_LIMIT} 1042a51529fSPeter Wemm 1050b3178a4SMike Smith# Disallow common variables, and if we end up with commons from 1060b3178a4SMike Smith# somewhere unexpected, allocate storage for them in the module itself. 1070b3178a4SMike SmithCFLAGS+= -fno-common 1080b3178a4SMike SmithLDFLAGS+= -d -warn-common 1090b3178a4SMike Smith 1109e4be63dSBruce EvansCFLAGS+= ${DEBUG_FLAGS} 1119e4be63dSBruce Evans 112639a2e50SGarrett WollmanOBJS+= ${SRCS:N*.h:R:S/$/.o/g} 113639a2e50SGarrett Wollman 114639a2e50SGarrett Wollman.if !defined(PROG) 11590f60fc9SMike SmithPROG= ${KMOD}.ko 11690f60fc9SMike Smith.endif 117639a2e50SGarrett Wollman 118f6611608SSheldon Hearn.if !defined(DEBUG) 119f6611608SSheldon HearnFULLPROG= ${PROG} 120f6611608SSheldon Hearn.else 121f6611608SSheldon HearnFULLPROG= ${PROG}.debug 122f6611608SSheldon Hearn${PROG}: ${FULLPROG} 123f6611608SSheldon Hearn ${OBJCOPY} --strip-debug ${FULLPROG} ${PROG} 124f6611608SSheldon Hearn.endif 125f6611608SSheldon Hearn 126f6611608SSheldon Hearn${FULLPROG}: ${KMOD}.kld 12709be11baSPeter Wemm ${LD} -Bshareable ${LDFLAGS} -o ${.TARGET} ${KMOD}.kld 12809be11baSPeter Wemm 12993f03548SMike SmithEXPORT_SYMS?= NO 13093f03548SMike Smith.if ${EXPORT_SYMS} != YES 1310b3178a4SMike SmithCLEANFILES+= ${.OBJDIR}/export_syms 1320b3178a4SMike Smith.endif 1330b3178a4SMike Smith 13409be11baSPeter Wemm${KMOD}.kld: ${OBJS} 1350b3178a4SMike Smith ${LD} ${LDFLAGS} -r -d -o ${.TARGET} ${OBJS} 1360b3178a4SMike Smith.if defined(EXPORT_SYMS) 13793f03548SMike Smith.if ${EXPORT_SYMS} != YES 1380b3178a4SMike Smith.if ${EXPORT_SYMS} == NO 1390b3178a4SMike Smith touch ${.OBJDIR}/export_syms 1400b3178a4SMike Smith.elif !exists(${.CURDIR}/${EXPORT_SYMS}) 1410b3178a4SMike Smith echo ${EXPORT_SYMS} > ${.OBJDIR}/export_syms 1420b3178a4SMike Smith.else 1430b3178a4SMike Smith grep -v '^#' < ${EXPORT_SYMS} > ${.OBJDIR}/export_syms 1440b3178a4SMike Smith.endif 1450b3178a4SMike Smith awk -f ${SYSDIR}/conf/kmod_syms.awk ${.TARGET} \ 1460b3178a4SMike Smith ${.OBJDIR}/export_syms | \ 14793f03548SMike Smith xargs -J% ${OBJCOPY} % ${.TARGET} 14893f03548SMike Smith.endif 1490b3178a4SMike Smith.endif 1500b3178a4SMike Smith 1514a2d2630SBruce Evans_ILINKS=@ machine 152639a2e50SGarrett Wollman 153b25a566dSRuslan Ermilovall: objwarn ${PROG} 1544a2d2630SBruce Evans 155985f41afSWarner Loshbeforedepend: ${_ILINKS} 156985f41afSWarner Losh @rm -f .depend 157985f41afSWarner Losh 158f3cc9575SWarner Losh# Ensure that the links exist without depending on it when it exists which 159f3cc9575SWarner Losh# causes all the modules to be rebuilt when the directory pointed to changes. 160f3cc9575SWarner Losh.for _link in ${_ILINKS} 161f3cc9575SWarner Losh.if !exists(${.OBJDIR}/${_link}) 162f3cc9575SWarner Losh${OBJS}: ${_link} 163f3cc9575SWarner Losh.endif 164f3cc9575SWarner Losh.endfor 1654a2d2630SBruce Evans 1669a8631b3SWarner Losh# Search for kernel source tree in standard places. 1679a8631b3SWarner Losh.for _dir in ${.CURDIR}/../.. ${.CURDIR}/../../.. /sys /usr/src/sys 1689a8631b3SWarner Losh.if !defined(SYSDIR) && exists(${_dir}/kern/) 1699a8631b3SWarner LoshSYSDIR= ${_dir} 1709a8631b3SWarner Losh.endif 1719a8631b3SWarner Losh.endfor 172aabafca0SJason Evans.if !defined(SYSDIR) || !exists(${SYSDIR}/kern) 1739a8631b3SWarner Losh.error "can't find kernel source tree" 1749a8631b3SWarner Losh.endif 1759a8631b3SWarner Losh 1764a2d2630SBruce Evans${_ILINKS}: 1779a8631b3SWarner Losh @case ${.TARGET} in \ 17808a04a89SPeter Wemm machine) \ 1799a8631b3SWarner Losh path=${SYSDIR}/${MACHINE_ARCH}/include ;; \ 18008a04a89SPeter Wemm @) \ 1819a8631b3SWarner Losh path=${SYSDIR} ;; \ 18208a04a89SPeter Wemm esac ; \ 18308a04a89SPeter Wemm path=`(cd $$path && /bin/pwd)` ; \ 18408a04a89SPeter Wemm ${ECHO} ${.TARGET} "->" $$path ; \ 18508a04a89SPeter Wemm ln -s $$path ${.TARGET} 1864a2d2630SBruce Evans 187361186e5SMaxime HenrionCLEANFILES+= ${PROG} ${KMOD}.kld ${OBJS} ${_ILINKS} symb.tmp tmp.o 188361186e5SMaxime Henrion 189361186e5SMaxime Henrion.if defined(DEBUG) 190361186e5SMaxime HenrionCLEANFILES+= ${FULLPROG} 191361186e5SMaxime Henrion.endif 192639a2e50SGarrett Wollman 193639a2e50SGarrett Wollman.if !target(install) 194639a2e50SGarrett Wollman 195ea87b3cbSDavid E. O'Brien_INSTALLFLAGS:= ${INSTALLFLAGS} 196e902c1bbSTim Vanderhoek.for ie in ${INSTALLFLAGS_EDIT} 197e902c1bbSTim Vanderhoek_INSTALLFLAGS:= ${_INSTALLFLAGS${ie}} 198e902c1bbSTim Vanderhoek.endfor 199e902c1bbSTim Vanderhoek 2002cbc81ffSRuslan Ermilov.if defined(DEBUG) 201b25a566dSRuslan Ermilovinstall.debug: 2022cbc81ffSRuslan Ermilov cd ${.CURDIR}; ${MAKE} -DINSTALL_DEBUG install 2032cbc81ffSRuslan Ermilov.endif 204a4c00586SDag-Erling Smørgrav 2052b06260dSRuslan Ermilov.if !target(realinstall) 2062b06260dSRuslan Ermilovrealinstall: _kmodinstall 2072b06260dSRuslan Ermilov.ORDER: beforeinstall _kmodinstall 2082cbc81ffSRuslan Ermilov.if defined(DEBUG) && defined(INSTALL_DEBUG) 2092b06260dSRuslan Ermilov_kmodinstall: 210d2893b16SRuslan Ermilov ${INSTALL} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \ 2112b06260dSRuslan Ermilov ${_INSTALLFLAGS} ${FULLPROG} ${DESTDIR}${KMODDIR} 2122cbc81ffSRuslan Ermilov.else 2132b06260dSRuslan Ermilov_kmodinstall: 214d2893b16SRuslan Ermilov ${INSTALL} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \ 2152b06260dSRuslan Ermilov ${_INSTALLFLAGS} ${PROG} ${DESTDIR}${KMODDIR} 2162b06260dSRuslan Ermilov 2172b06260dSRuslan Ermilov.include <bsd.links.mk> 2182b06260dSRuslan Ermilov 2194875819cSJake Burkholder.if !defined(NO_XREF) 2202b06260dSRuslan Ermilovafterinstall: _kldxref 2212b06260dSRuslan Ermilov.ORDER: realinstall _kldxref 2222b06260dSRuslan Ermilov.ORDER: _installlinks _kldxref 2232b06260dSRuslan Ermilov_kldxref: 224be1d673dSRuslan Ermilov @if type kldxref >/dev/null 2>&1; then \ 225be1d673dSRuslan Ermilov ${ECHO} kldxref ${DESTDIR}${KMODDIR}; \ 226be1d673dSRuslan Ermilov kldxref ${DESTDIR}${KMODDIR}; \ 227be1d673dSRuslan Ermilov fi 228505222d3SPeter Wemm.endif 2292cbc81ffSRuslan Ermilov.endif 2302b06260dSRuslan Ermilov.endif !target(realinstall) 231639a2e50SGarrett Wollman 2322b06260dSRuslan Ermilov.endif !target(install) 233639a2e50SGarrett Wollman 234639a2e50SGarrett Wollman.if !target(load) 2359a8631b3SWarner Loshload: ${PROG} 236dba3dc7bSNick Hibma ${KMODLOAD} -v ${.OBJDIR}/${KMOD}.ko 237639a2e50SGarrett Wollman.endif 238639a2e50SGarrett Wollman 239639a2e50SGarrett Wollman.if !target(unload) 240fe3cac87SNick Hibmaunload: 2419a8631b3SWarner Losh ${KMODUNLOAD} -v ${KMOD} 24208a04a89SPeter Wemm.endif 2431aa57be3SGarrett Wollman 2444fea6704SBruce Evans.for _src in ${SRCS:Mopt_*.h} 2454fea6704SBruce EvansCLEANFILES+= ${_src} 2464fea6704SBruce Evans.if !target(${_src}) 2474fea6704SBruce Evans${_src}: 2484fea6704SBruce Evans touch ${.TARGET} 2494fea6704SBruce Evans.endif 2504fea6704SBruce Evans.endfor 2514fea6704SBruce Evans 2527fecffecSDoug RabsonMFILES?= kern/bus_if.m kern/device_if.m dev/iicbus/iicbb_if.m \ 2536f2d8adbSBoris Popov dev/iicbus/iicbus_if.m isa/isa_if.m \ 2546f2d8adbSBoris Popov libkern/iconv_converter_if.m \ 2556f2d8adbSBoris Popov dev/mii/miibus_if.m \ 2567e820aaaSMike Smith dev/pccard/card_if.m dev/pccard/power_if.m dev/pci/pci_if.m \ 2577e820aaaSMike Smith dev/pci/pcib_if.m dev/ppbus/ppbus_if.m dev/smbus/smbus_if.m \ 2580f55ac6cSCameron Grant dev/usb/usb_if.m dev/sound/pcm/ac97_if.m dev/sound/pcm/channel_if.m \ 259c4f9e3aeSSam Leffler dev/sound/pcm/feeder_if.m dev/sound/pcm/mixer_if.m pci/agp_if.m \ 26083536948SYoshihiro Takahashi opencrypto/crypto_if.m pc98/pc98/canbus_if.m 2617fecffecSDoug Rabson 2627fecffecSDoug Rabson.for _srcsrc in ${MFILES} 2634fea6704SBruce Evans.for _ext in c h 2644fea6704SBruce Evans.for _src in ${SRCS:M${_srcsrc:T:R}.${_ext}} 2654fea6704SBruce EvansCLEANFILES+= ${_src} 2664fea6704SBruce Evans.if !target(${_src}) 267f3cc9575SWarner Losh.if !exists(@) 2684fea6704SBruce Evans${_src}: @ 269f3cc9575SWarner Losh.endif 2704fea6704SBruce Evans.if exists(@) 2719fa411aeSDavid E. O'Brien${_src}: @/tools/makeobjops.awk @/${_srcsrc} 2724fea6704SBruce Evans.endif 2739fa411aeSDavid E. O'Brien ${AWK} -f @/tools/makeobjops.awk @/${_srcsrc} -${_ext} 2744fea6704SBruce Evans.endif 2754fea6704SBruce Evans.endfor # _src 2764fea6704SBruce Evans.endfor # _ext 2774fea6704SBruce Evans.endfor # _srcsrc 2784fea6704SBruce Evans 2799029b644SPeter Wemm.for _ext in c h 2809029b644SPeter Wemm.if ${SRCS:Mvnode_if.${_ext}} != "" 2819029b644SPeter WemmCLEANFILES+= vnode_if.${_ext} 282f3cc9575SWarner Losh.if !exists(@) 2839029b644SPeter Wemmvnode_if.${_ext}: @ 284f3cc9575SWarner Losh.endif 2854fea6704SBruce Evans.if exists(@) 286b7bbb709SDavid E. O'Brienvnode_if.${_ext}: @/tools/vnode_if.awk @/kern/vnode_if.src 2874fea6704SBruce Evans.endif 288b7bbb709SDavid E. O'Brien ${AWK} -f @/tools/vnode_if.awk @/kern/vnode_if.src -${_ext} 2894fea6704SBruce Evans.endif 2909029b644SPeter Wemm.endfor 2911aa57be3SGarrett Wollman 2922d3ce713SDavid E. O'Brien.if ${SRCS:Mmiidevs.h} != "" 2932d3ce713SDavid E. O'BrienCLEANFILES+= miidevs.h 2942d3ce713SDavid E. O'Brien.if !exists(@) 2952d3ce713SDavid E. O'Brienmiidevs.h: @ 2962d3ce713SDavid E. O'Brien.endif 2972d3ce713SDavid E. O'Brien.if exists(@) 2982d3ce713SDavid E. O'Brienmiidevs.h: @/tools/devlist2h.awk @/dev/mii/miidevs 2992d3ce713SDavid E. O'Brien.endif 3002d3ce713SDavid E. O'Brien ${AWK} -f @/tools/devlist2h.awk @/dev/mii/miidevs 3012d3ce713SDavid E. O'Brien.endif 3022d3ce713SDavid E. O'Brien 30371395925SPeter Wemmregress: 30469b87d3eSEivind Eklund 305766f7d6eSMark Murraylint: ${SRCS} 306bbb467cdSRuslan Ermilov ${LINT} ${LINTKERNFLAGS} ${CFLAGS:M-[DILU]*} ${.ALLSRC:M*.c} 307766f7d6eSMark Murray 30868e00b92SJordan K. Hubbard.include <bsd.dep.mk> 30947da63c3SBruce Evans 310f2bffe0fSRuslan Ermilov.if !exists(${.OBJDIR}/${DEPENDFILE}) 311589d9341SBruce Evans${OBJS}: ${SRCS:M*.h} 31247da63c3SBruce Evans.endif 31347da63c3SBruce Evans 314afba897fSBruce Evans.include <bsd.obj.mk> 315ddc474a8SRuslan Ermilov.include "kern.mk" 316