kmod.mk revision 18777
1# From: @(#)bsd.prog.mk 5.26 (Berkeley) 6/25/91 2# $Id: bsd.kmod.mk,v 1.26 1996/09/18 06:09:13 swallace Exp $ 3# 4# The include file <bsd.kmod.mk> handles installing Loadable Kernel Modules. 5# <bsd.kmod.mk> includes the file named "../Makefile.inc" if it exists, 6# as well as the include file <bsd.obj.mk>, <bsd.dep.mk>, and 7# may be <bsd.man.mk> 8# 9# 10# +++ variables +++ 11# 12# CLEANFILES Additional files to remove for the clean and cleandir targets. 13# 14# DISTRIBUTION Name of distribution. [bin] 15# 16# EXPORT_SYMS ??? 17# 18# KERN Main Kernel source directory. [${.CURDIR}/../../sys/kern] 19# 20# KMOD The name of the loadable kernel module to build. 21# 22# KMODDIR Base path for loadable kernel modules 23# (see lkm(4)). [/lkm] 24# 25# KMODOWN LKM owner. [${BINOWN}] 26# 27# KMODGRP LKM group. [${BINGRP}] 28# 29# KMODMODE LKM mode. [${BINMODE}] 30# 31# LINKS The list of LKM links; should be full pathnames, the 32# linked-to file coming first, followed by the linked 33# file. The files are hard-linked. For example, to link 34# /lkm/master and /lkm/meister, use: 35# 36# LINKS= /lkm/master /lkm/meister 37# 38# LN_FLAGS Flags for ln(1) (see variable LINKS) 39# 40# MODLOAD Command to load a kernel module [/sbin/modload] 41# 42# MODUNLOAD Command to unload a kernel module [/sbin/modunload] 43# 44# NOMAN LKM does not have a manual page if set. 45# 46# PROG The name of the loadable kernel module to build. 47# If not supplied, ${KMOD}.o is used. 48# 49# PSEUDO_LKM ??? 50# 51# SRCS List of source files 52# 53# SUBDIR A list of subdirectories that should be built as well. 54# Each of the targets will execute the same target in the 55# subdirectories. 56# 57# DESTDIR, DISTDIR are set by other Makefiles (e.g. bsd.own.mk) 58# 59# 60# +++ targets +++ 61# 62# distribute: 63# This is a variant of install, which will 64# put the stuff into the right "distribution". 65# 66# install: 67# install the program and its manual pages; if the Makefile 68# does not itself define the target install, the targets 69# beforeinstall and afterinstall may also be used to cause 70# actions immediately before and after the install target 71# is executed. 72# 73# load: 74# Load LKM. 75# 76# tags: 77# Create a tags file for the source files. 78# 79# unload: 80# Unload LKM. 81# 82# bsd.obj.mk: clean, cleandir and obj 83# bsd.dep.mk: depend 84# bsd.man.mk: maninstall 85# 86 87MODLOAD?= /sbin/modload 88MODUNLOAD?= /sbin/modunload 89 90.if exists(${.CURDIR}/../Makefile.inc) 91.include "${.CURDIR}/../Makefile.inc" 92.endif 93 94.SUFFIXES: .out .o .c .cc .cxx .C .y .l .s .S 95 96# 97# Assume that we are in /usr/src/foo/bar, so /sys is 98# ${.CURDIR}/../../sys. We don't bother adding a .PATH since nothing 99# actually lives in /sys directly. 100# 101CWARNFLAGS?= -W -Wreturn-type -Wcomment -Wredundant-decls -Wimplicit \ 102 -Wnested-externs -Wstrict-prototypes -Wmissing-prototypes \ 103 -Winline -Wunused -Wpointer-arith 104 105CFLAGS+=${COPTS} -DKERNEL -DACTUALLY_LKM_NOT_KERNEL -I${.CURDIR}/../../sys \ 106 ${CWARNFLAGS} 107 108EXPORT_SYMS?= _${KMOD} 109 110.if defined(VFS_LKM) 111CFLAGS+= -DVFS_LKM -DMODVNOPS=${KMOD}vnops -I. 112SRCS+= vnode_if.h 113CLEANFILES+= vnode_if.h vnode_if.c 114.endif 115 116.if defined(PSEUDO_LKM) 117CFLAGS+= -DPSEUDO_LKM 118.endif 119 120DPSRCS+= ${SRCS:M*.h} 121OBJS+= ${SRCS:N*.h:R:S/$/.o/g} 122 123.if !defined(PROG) 124PROG= ${KMOD}.o 125.endif 126 127${PROG}: ${DPSRCS} ${OBJS} ${DPADD} 128 ${LD} -r ${LDFLAGS} -o tmp.o ${OBJS} 129.if defined(EXPORT_SYMS) 130 @rm -f symb.tmp 131 @for i in ${EXPORT_SYMS} ; do echo $$i >> symb.tmp ; done 132 symorder -c symb.tmp tmp.o 133 @rm -f symb.tmp 134.endif 135 mv tmp.o ${.TARGET} 136 137.if !defined(NOMAN) 138.include <bsd.man.mk> 139.if !defined(_MANPAGES) || empty(_MANPAGES) 140MAN1= ${KMOD}.4 141.endif 142 143.elif !target(maninstall) 144maninstall: _SUBDIR 145all-man: 146.endif 147 148.MAIN: all 149all: objwarn ${PROG} all-man _SUBDIR 150 151CLEANFILES+=${PROG} ${OBJS} 152 153.if !target(install) 154.if !target(beforeinstall) 155beforeinstall: 156.endif 157.if !target(afterinstall) 158afterinstall: 159.endif 160 161realinstall: _SUBDIR 162 ${INSTALL} ${COPY} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \ 163 ${INSTALLFLAGS} ${PROG} ${DESTDIR}${KMODDIR} 164.if defined(LINKS) && !empty(LINKS) 165 @set ${LINKS}; \ 166 while test $$# -ge 2; do \ 167 l=${DESTDIR}$$1; \ 168 shift; \ 169 t=${DESTDIR}$$1; \ 170 shift; \ 171 ${ECHO} $$t -\> $$l; \ 172 rm -f $$t; \ 173 ln ${LN_FLAGS} $$l $$t; \ 174 done; true 175.endif 176 177install: afterinstall _SUBDIR 178.if !defined(NOMAN) 179afterinstall: realinstall maninstall 180.else 181afterinstall: realinstall 182.endif 183realinstall: beforeinstall 184.endif 185 186DISTRIBUTION?= bin 187.if !target(distribute) 188distribute: _SUBDIR 189 cd ${.CURDIR} ; $(MAKE) install DESTDIR=${DISTDIR}/${DISTRIBUTION} SHARED=copies 190.endif 191 192.if !target(tags) 193tags: ${SRCS} _SUBDIR 194.if defined(PROG) 195 -cd ${.CURDIR}; ctags -f /dev/stdout ${.ALLSRC} | \ 196 sed "s;\${.CURDIR}/;;" > tags 197.endif 198.endif 199 200 201.if !target(load) 202load: ${PROG} 203 ${MODLOAD} -o ${KMOD} -e${KMOD} ${PROG} 204.endif 205 206.if !target(unload) 207unload: ${PROG} 208 ${MODUNLOAD} -n ${KMOD} 209.endif 210 211KERN= ${.CURDIR}/../../sys/kern 212 213vnode_if.h: ${KERN}/vnode_if.sh ${KERN}/vnode_if.src 214 sh ${KERN}/vnode_if.sh ${KERN}/vnode_if.src 215 216./vnode_if.h: vnode_if.h 217 218.include <bsd.obj.mk> 219.include <bsd.dep.mk> 220