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# 1253996fadSWolfram Schneider# DISTRIBUTION Name of distribution. [bin] 1353996fadSWolfram Schneider# 14fe3cac87SNick Hibma# KMOD The name of the kernel module to build. 1553996fadSWolfram Schneider# 163bdfa9e5SDavid E. O'Brien# KMODDIR Base path for kernel modules (see kld(4)). [/boot/kernel] 1753996fadSWolfram Schneider# 18fe3cac87SNick Hibma# KMODOWN KLD owner. [${BINOWN}] 1953996fadSWolfram Schneider# 20fe3cac87SNick Hibma# KMODGRP KLD group. [${BINGRP}] 2153996fadSWolfram Schneider# 22fe3cac87SNick Hibma# KMODMODE KLD mode. [${BINMODE}] 2353996fadSWolfram Schneider# 24fe3cac87SNick Hibma# LINKS The list of KLD links; should be full pathnames, the 2553996fadSWolfram Schneider# linked-to file coming first, followed by the linked 2653996fadSWolfram Schneider# file. The files are hard-linked. For example, to link 2771395925SPeter Wemm# /modules/master and /modules/meister, use: 2853996fadSWolfram Schneider# 2971395925SPeter Wemm# LINKS= /modules/master /modules/meister 3053996fadSWolfram Schneider# 31fe3cac87SNick Hibma# KMODLOAD Command to load a kernel module [/sbin/kldload] 327bc830bbSWolfram Schneider# 33fe3cac87SNick Hibma# KMODUNLOAD Command to unload a kernel module [/sbin/kldunload] 347bc830bbSWolfram Schneider# 35fe3cac87SNick Hibma# PROG The name of the kernel module to build. 367bc830bbSWolfram Schneider# If not supplied, ${KMOD}.o is used. 3753996fadSWolfram Schneider# 3853996fadSWolfram Schneider# SRCS List of source files 3953996fadSWolfram Schneider# 4053996fadSWolfram Schneider# SUBDIR A list of subdirectories that should be built as well. 4153996fadSWolfram Schneider# Each of the targets will execute the same target in the 4253996fadSWolfram Schneider# subdirectories. 4353996fadSWolfram Schneider# 442336a7eaSBruce Evans# SYMLINKS Same as LINKS, except it creates symlinks and the 452336a7eaSBruce Evans# linked-to pathname may be relative. 462336a7eaSBruce Evans# 4753996fadSWolfram Schneider# DESTDIR, DISTDIR are set by other Makefiles (e.g. bsd.own.mk) 4853996fadSWolfram Schneider# 497fecffecSDoug Rabson# MFILES Optionally a list of interfaces used by the module. 507fecffecSDoug Rabson# This file contains a default list of interfaces. 5153996fadSWolfram Schneider# 520b3178a4SMike Smith# EXPORT_SYMS A list of symbols that should be exported from the module, 5393f03548SMike Smith# or the name of a file containing a list of symbols, or YES 5493f03548SMike Smith# to export all symbols. If not defined, no symbols are 550b3178a4SMike Smith# exported. 560b3178a4SMike Smith# 5753996fadSWolfram Schneider# +++ targets +++ 5853996fadSWolfram Schneider# 5953996fadSWolfram Schneider# distribute: 6053996fadSWolfram Schneider# This is a variant of install, which will 6153996fadSWolfram Schneider# put the stuff into the right "distribution". 6253996fadSWolfram Schneider# 6353996fadSWolfram Schneider# install: 6417d6c636SRuslan Ermilov# install the kernel module; if the Makefile 6553996fadSWolfram Schneider# does not itself define the target install, the targets 6653996fadSWolfram Schneider# beforeinstall and afterinstall may also be used to cause 6753996fadSWolfram Schneider# actions immediately before and after the install target 6853996fadSWolfram Schneider# is executed. 6953996fadSWolfram Schneider# 7053996fadSWolfram Schneider# load: 71fe3cac87SNick Hibma# Load KLD. 7253996fadSWolfram Schneider# 7353996fadSWolfram Schneider# unload: 74fe3cac87SNick Hibma# Unload KLD. 7553996fadSWolfram Schneider# 7653996fadSWolfram Schneider# bsd.obj.mk: clean, cleandir and obj 77161e8999SBruce Evans# bsd.dep.mk: cleandepend, depend and tags 7853996fadSWolfram Schneider# 79639a2e50SGarrett Wollman 80fe3cac87SNick HibmaKMODLOAD?= /sbin/kldload 81fe3cac87SNick HibmaKMODUNLOAD?= /sbin/kldunload 82f6611608SSheldon HearnOBJCOPY?= objcopy 837bc830bbSWolfram Schneider 840d2e2e23SDavid E. O'BrienTARGET_ARCH?= ${MACHINE_ARCH} 850d2e2e23SDavid E. O'Brien 86e0301e5dSPeter Wemm.if !target(__initialized__) 87e0301e5dSPeter Wemm__initialized__: 88639a2e50SGarrett Wollman.if exists(${.CURDIR}/../Makefile.inc) 89639a2e50SGarrett Wollman.include "${.CURDIR}/../Makefile.inc" 90639a2e50SGarrett Wollman.endif 91e0301e5dSPeter Wemm.endif 92639a2e50SGarrett Wollman 93639a2e50SGarrett Wollman.SUFFIXES: .out .o .c .cc .cxx .C .y .l .s .S 94639a2e50SGarrett Wollman 95c4473420SPeter WemmCFLAGS+= ${COPTS} -D_KERNEL ${CWARNFLAGS} 968fe644b2SMike SmithCFLAGS+= -DKLD_MODULE 974a2d2630SBruce Evans 98021886ffSBruce Evans# Don't use any standard or source-relative include directories. 99021886ffSBruce Evans# Since -nostdinc will annull any previous -I paths, we repeat all 100021886ffSBruce Evans# such paths after -nostdinc. It doesn't seem to be possible to 101021886ffSBruce Evans# add to the front of `make' variable. 102021886ffSBruce Evans_ICFLAGS:= ${CFLAGS:M-I*} 10326dac111SPoul-Henning KampCFLAGS+= -nostdinc -I- ${INCLMAGIC} ${_ICFLAGS} 104021886ffSBruce Evans 105fe3cac87SNick Hibma# Add -I paths for system headers. Individual KLD makefiles don't 106021886ffSBruce Evans# need any -I paths for this. Similar defaults for .PATH can't be 107021886ffSBruce Evans# set because there are no standard paths for non-headers. 1087e820aaaSMike SmithCFLAGS+= -I. -I@ -I@/dev 1094a2d2630SBruce Evans 110a0b845feSBruce Evans# Add a -I path to standard headers like <stddef.h>. Use a relative 111a0b845feSBruce Evans# path to src/include if possible. If the @ symlink hasn't been built 112a0b845feSBruce Evans# yet, then we can't tell if the relative path exists. Add both the 113a0b845feSBruce Evans# potential relative path and an absolute path in that case. 114a0b845feSBruce Evans.if exists(@) 115a0b845feSBruce Evans.if exists(@/../include) 116a0b845feSBruce EvansCFLAGS+= -I@/../include 117a0b845feSBruce Evans.else 118b3e17ba2SSatoshi AsamiCFLAGS+= -I${DESTDIR}/usr/include 119b3e17ba2SSatoshi Asami.endif 120a0b845feSBruce Evans.else # !@ 121a0b845feSBruce EvansCFLAGS+= -I@/../include -I${DESTDIR}/usr/include 122a0b845feSBruce Evans.endif # @ 12356bac51bSPoul-Henning Kamp 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. 1260b3178a4SMike SmithCFLAGS+= -fno-common 1270b3178a4SMike SmithLDFLAGS+= -d -warn-common 1280b3178a4SMike Smith 1299e4be63dSBruce EvansCFLAGS+= ${DEBUG_FLAGS} 1309e4be63dSBruce Evans 13171395925SPeter Wemm.if ${OBJFORMAT} == elf 132fdbdd3a0SPeter WemmCLEANFILES+= setdef0.c setdef1.c setdefs.h 133fdbdd3a0SPeter WemmCLEANFILES+= setdef0.o setdef1.o 134fdbdd3a0SPeter Wemm.endif 135fdbdd3a0SPeter Wemm 136639a2e50SGarrett WollmanOBJS+= ${SRCS:N*.h:R:S/$/.o/g} 137639a2e50SGarrett Wollman 138639a2e50SGarrett Wollman.if !defined(PROG) 13990f60fc9SMike SmithPROG= ${KMOD}.ko 14090f60fc9SMike Smith.endif 141639a2e50SGarrett Wollman 142f6611608SSheldon Hearn.if !defined(DEBUG) 143f6611608SSheldon HearnFULLPROG= ${PROG} 144f6611608SSheldon Hearn.else 145f6611608SSheldon HearnFULLPROG= ${PROG}.debug 146f6611608SSheldon Hearn${PROG}: ${FULLPROG} 147f6611608SSheldon Hearn ${OBJCOPY} --strip-debug ${FULLPROG} ${PROG} 148f6611608SSheldon Hearn.endif 149f6611608SSheldon Hearn 150f6611608SSheldon Hearn${FULLPROG}: ${KMOD}.kld 15109be11baSPeter Wemm ${LD} -Bshareable ${LDFLAGS} -o ${.TARGET} ${KMOD}.kld 15209be11baSPeter Wemm 15393f03548SMike SmithEXPORT_SYMS?= NO 15493f03548SMike Smith.if ${EXPORT_SYMS} != YES 1550b3178a4SMike SmithCLEANFILES+= ${.OBJDIR}/export_syms 1560b3178a4SMike Smith.endif 1570b3178a4SMike Smith 15809be11baSPeter Wemm${KMOD}.kld: ${OBJS} 1590b3178a4SMike Smith ${LD} ${LDFLAGS} -r -d -o ${.TARGET} ${OBJS} 1600b3178a4SMike Smith.if defined(EXPORT_SYMS) 16193f03548SMike Smith.if ${EXPORT_SYMS} != YES 1620b3178a4SMike Smith.if ${EXPORT_SYMS} == NO 1630b3178a4SMike Smith touch ${.OBJDIR}/export_syms 1640b3178a4SMike Smith.elif !exists(${.CURDIR}/${EXPORT_SYMS}) 1650b3178a4SMike Smith echo ${EXPORT_SYMS} > ${.OBJDIR}/export_syms 1660b3178a4SMike Smith.else 1670b3178a4SMike Smith grep -v '^#' < ${EXPORT_SYMS} > ${.OBJDIR}/export_syms 1680b3178a4SMike Smith.endif 1690b3178a4SMike Smith awk -f ${SYSDIR}/conf/kmod_syms.awk ${.TARGET} \ 1700b3178a4SMike Smith ${.OBJDIR}/export_syms | \ 17193f03548SMike Smith xargs -J% ${OBJCOPY} % ${.TARGET} 17293f03548SMike Smith.endif 1730b3178a4SMike Smith.endif 1740b3178a4SMike Smith 175fdbdd3a0SPeter Wemm 1767da4bd3bSRuslan Ermilov.if !target(all-man) 1777da4bd3bSRuslan Ermilovall-man: _SUBDIR 1787da4bd3bSRuslan Ermilov.endif 1797da4bd3bSRuslan Ermilov.if !target(maninstall) 180cd9a2f5cSJordan K. Hubbardmaninstall: _SUBDIR 1817da4bd3bSRuslan Ermilov.endif 1825ce6c3cfSWolfram Schneider 1834a2d2630SBruce Evans_ILINKS=@ machine 184639a2e50SGarrett Wollman 1854a2d2630SBruce Evans.MAIN: all 18617d6c636SRuslan Ermilovall: objwarn ${PROG} _SUBDIR 1874a2d2630SBruce Evans 188985f41afSWarner Loshbeforedepend: ${_ILINKS} 189985f41afSWarner Losh @rm -f .depend 190985f41afSWarner Losh 191f3cc9575SWarner Losh# Ensure that the links exist without depending on it when it exists which 192f3cc9575SWarner Losh# causes all the modules to be rebuilt when the directory pointed to changes. 193f3cc9575SWarner Losh.for _link in ${_ILINKS} 194f3cc9575SWarner Losh.if !exists(${.OBJDIR}/${_link}) 195f3cc9575SWarner Losh${OBJS}: ${_link} 196f3cc9575SWarner Losh.endif 197f3cc9575SWarner Losh.endfor 1984a2d2630SBruce Evans 1999a8631b3SWarner Losh# Search for kernel source tree in standard places. 2009a8631b3SWarner Losh.for _dir in ${.CURDIR}/../.. ${.CURDIR}/../../.. /sys /usr/src/sys 2019a8631b3SWarner Losh.if !defined(SYSDIR) && exists(${_dir}/kern/) 2029a8631b3SWarner LoshSYSDIR= ${_dir} 2039a8631b3SWarner Losh.endif 2049a8631b3SWarner Losh.endfor 205aabafca0SJason Evans.if !defined(SYSDIR) || !exists(${SYSDIR}/kern) 2069a8631b3SWarner Losh.error "can't find kernel source tree" 2079a8631b3SWarner Losh.endif 2089a8631b3SWarner Losh 2094a2d2630SBruce Evans${_ILINKS}: 2109a8631b3SWarner Losh @case ${.TARGET} in \ 21108a04a89SPeter Wemm machine) \ 2129a8631b3SWarner Losh path=${SYSDIR}/${MACHINE_ARCH}/include ;; \ 21308a04a89SPeter Wemm @) \ 2149a8631b3SWarner Losh path=${SYSDIR} ;; \ 21508a04a89SPeter Wemm esac ; \ 21608a04a89SPeter Wemm path=`(cd $$path && /bin/pwd)` ; \ 21708a04a89SPeter Wemm ${ECHO} ${.TARGET} "->" $$path ; \ 21808a04a89SPeter Wemm ln -s $$path ${.TARGET} 2194a2d2630SBruce Evans 220f6611608SSheldon HearnCLEANFILES+= ${PROG} ${FULLPROG} ${KMOD}.kld ${OBJS} ${_ILINKS} symb.tmp tmp.o 221639a2e50SGarrett Wollman 222639a2e50SGarrett Wollman.if !target(install) 223639a2e50SGarrett Wollman.if !target(beforeinstall) 224639a2e50SGarrett Wollmanbeforeinstall: 225639a2e50SGarrett Wollman.endif 226639a2e50SGarrett Wollman.if !target(afterinstall) 227639a2e50SGarrett Wollmanafterinstall: 228639a2e50SGarrett Wollman.endif 229639a2e50SGarrett Wollman 230ea87b3cbSDavid E. O'Brien_INSTALLFLAGS:= ${INSTALLFLAGS} 231e902c1bbSTim Vanderhoek.for ie in ${INSTALLFLAGS_EDIT} 232e902c1bbSTim Vanderhoek_INSTALLFLAGS:= ${_INSTALLFLAGS${ie}} 233e902c1bbSTim Vanderhoek.endfor 234e902c1bbSTim Vanderhoek 235a4c00586SDag-Erling Smørgravinstall.debug: _SUBDIR 236a4c00586SDag-Erling Smørgrav ${INSTALL} ${COPY} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \ 237a4c00586SDag-Erling Smørgrav ${_INSTALLFLAGS} ${FULLPROG} ${DESTDIR}${KMODDIR}/ 238a4c00586SDag-Erling Smørgrav 239cd9a2f5cSJordan K. Hubbardrealinstall: _SUBDIR 2405ce6c3cfSWolfram Schneider ${INSTALL} ${COPY} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \ 2412f7538d6SPeter Pentchev ${_INSTALLFLAGS} ${PROG} ${DESTDIR}${KMODDIR}/ 242639a2e50SGarrett Wollman.if defined(LINKS) && !empty(LINKS) 243639a2e50SGarrett Wollman @set ${LINKS}; \ 244639a2e50SGarrett Wollman while test $$# -ge 2; do \ 245639a2e50SGarrett Wollman l=${DESTDIR}$$1; \ 246639a2e50SGarrett Wollman shift; \ 247639a2e50SGarrett Wollman t=${DESTDIR}$$1; \ 248639a2e50SGarrett Wollman shift; \ 249639a2e50SGarrett Wollman ${ECHO} $$t -\> $$l; \ 2502336a7eaSBruce Evans ln -f $$l $$t; \ 2512336a7eaSBruce Evans done; true 2522336a7eaSBruce Evans.endif 2532336a7eaSBruce Evans.if defined(SYMLINKS) && !empty(SYMLINKS) 2542336a7eaSBruce Evans @set ${SYMLINKS}; \ 2552336a7eaSBruce Evans while test $$# -ge 2; do \ 2562336a7eaSBruce Evans l=$$1; \ 2572336a7eaSBruce Evans shift; \ 2582336a7eaSBruce Evans t=${DESTDIR}$$1; \ 2592336a7eaSBruce Evans shift; \ 2602336a7eaSBruce Evans ${ECHO} $$t -\> $$l; \ 2612336a7eaSBruce Evans ln -fs $$l $$t; \ 262639a2e50SGarrett Wollman done; true 263639a2e50SGarrett Wollman.endif 264505222d3SPeter Wemm.if !defined(NO_XREF) 265ad7da9b4SPeter Wemm -kldxref ${DESTDIR}${KMODDIR} 266505222d3SPeter Wemm.endif 267639a2e50SGarrett Wollman 268cd9a2f5cSJordan K. Hubbardinstall: afterinstall _SUBDIR 269639a2e50SGarrett Wollmanafterinstall: realinstall 270639a2e50SGarrett Wollmanrealinstall: beforeinstall 271639a2e50SGarrett Wollman.endif 272639a2e50SGarrett Wollman 273d9584d76SJordan K. HubbardDISTRIBUTION?= bin 27455ff8fb1SPoul-Henning Kamp.if !target(distribute) 275cd9a2f5cSJordan K. Hubbarddistribute: _SUBDIR 276398ac038SJordan K. Hubbard.for dist in ${DISTRIBUTION} 277398ac038SJordan K. Hubbard cd ${.CURDIR} ; $(MAKE) install DESTDIR=${DISTDIR}/${dist} SHARED=copies 278398ac038SJordan K. Hubbard.endfor 27955ff8fb1SPoul-Henning Kamp.endif 28055ff8fb1SPoul-Henning Kamp 281639a2e50SGarrett Wollman.if !target(load) 2829a8631b3SWarner Loshload: ${PROG} 28346877fb2SBrian Feldman ${KMODLOAD} -v ${.CURDIR}/${KMOD}.ko 284639a2e50SGarrett Wollman.endif 285639a2e50SGarrett Wollman 286639a2e50SGarrett Wollman.if !target(unload) 287fe3cac87SNick Hibmaunload: 2889a8631b3SWarner Losh ${KMODUNLOAD} -v ${KMOD} 28908a04a89SPeter Wemm.endif 2901aa57be3SGarrett Wollman 2914fea6704SBruce Evans.for _src in ${SRCS:Mopt_*.h} 2924fea6704SBruce EvansCLEANFILES+= ${_src} 2934fea6704SBruce Evans.if !target(${_src}) 2944fea6704SBruce Evans${_src}: 2954fea6704SBruce Evans touch ${.TARGET} 2964fea6704SBruce Evans.endif 2974fea6704SBruce Evans.endfor 2984fea6704SBruce Evans 2997fecffecSDoug RabsonMFILES?= kern/bus_if.m kern/device_if.m dev/iicbus/iicbb_if.m \ 3006f2d8adbSBoris Popov dev/iicbus/iicbus_if.m isa/isa_if.m \ 3016f2d8adbSBoris Popov libkern/iconv_converter_if.m \ 3026f2d8adbSBoris Popov dev/mii/miibus_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 \ 3050f55ac6cSCameron Grant dev/usb/usb_if.m dev/sound/pcm/ac97_if.m dev/sound/pcm/channel_if.m \ 306ed277dc9SPeter Wemm dev/sound/pcm/feeder_if.m dev/sound/pcm/mixer_if.m pci/agp_if.m 3077fecffecSDoug Rabson 3087fecffecSDoug Rabson.for _srcsrc in ${MFILES} 3094fea6704SBruce Evans.for _ext in c h 3104fea6704SBruce Evans.for _src in ${SRCS:M${_srcsrc:T:R}.${_ext}} 3114fea6704SBruce EvansCLEANFILES+= ${_src} 3124fea6704SBruce Evans.if !target(${_src}) 313f3cc9575SWarner Losh.if !exists(@) 3144fea6704SBruce Evans${_src}: @ 315f3cc9575SWarner Losh.endif 3164fea6704SBruce Evans.if exists(@) 317c0de5879SDoug Rabson${_src}: @/kern/makeobjops.pl @/${_srcsrc} 3184fea6704SBruce Evans.endif 319c0de5879SDoug Rabson perl @/kern/makeobjops.pl -${_ext} @/${_srcsrc} 3204fea6704SBruce Evans.endif 3214fea6704SBruce Evans.endfor # _src 3224fea6704SBruce Evans.endfor # _ext 3234fea6704SBruce Evans.endfor # _srcsrc 3244fea6704SBruce Evans 3259029b644SPeter Wemm.for _ext in c h 3269029b644SPeter Wemm.if ${SRCS:Mvnode_if.${_ext}} != "" 3279029b644SPeter WemmCLEANFILES+= vnode_if.${_ext} 328f3cc9575SWarner Losh.if !exists(@) 3299029b644SPeter Wemmvnode_if.${_ext}: @ 330f3cc9575SWarner Losh.endif 3314fea6704SBruce Evans.if exists(@) 3323b073b53SPeter Wemmvnode_if.${_ext}: @/kern/vnode_if.pl @/kern/vnode_if.src 3334fea6704SBruce Evans.endif 3343b073b53SPeter Wemm perl @/kern/vnode_if.pl -${_ext} @/kern/vnode_if.src 3354fea6704SBruce Evans.endif 3369029b644SPeter Wemm.endfor 3371aa57be3SGarrett Wollman 33871395925SPeter Wemmregress: 33969b87d3eSEivind Eklund 34068e00b92SJordan K. Hubbard.include <bsd.dep.mk> 34147da63c3SBruce Evans 34247da63c3SBruce Evans.if !exists(${DEPENDFILE}) 343589d9341SBruce Evans${OBJS}: ${SRCS:M*.h} 34447da63c3SBruce Evans.endif 34547da63c3SBruce Evans 346afba897fSBruce Evans.include <bsd.obj.mk> 347afba897fSBruce Evans 3489e72552fSBruce Evans.include <bsd.kern.mk> 349