kmod.mk revision 25323
1#	From: @(#)bsd.prog.mk	5.26 (Berkeley) 6/25/91
2#	$Id: bsd.kmod.mk,v 1.33 1997/04/30 06:04:17 ache 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# A temporary fix to survive SMP changes.   
98#
99CFLAGS+=	-I.
100CLEANFILES=	${SMPHDRS}
101SMPHDRS=	opt_smp.h opt_smp_invltlb.h
102
103beforedepend: ${SMPHDRS}
104
105${SMPHDRS}:
106	touch ${.TARGET}
107
108#
109# Assume that we are in /usr/src/foo/bar, so /sys is
110# ${.CURDIR}/../../sys.  We don't bother adding a .PATH since nothing
111# actually lives in /sys directly.
112#
113CFLAGS+=${COPTS} -DKERNEL -DACTUALLY_LKM_NOT_KERNEL -I${.CURDIR}/../../sys \
114	${CWARNFLAGS}
115
116EXPORT_SYMS?= _${KMOD}
117
118.if defined(VFS_LKM)
119CFLAGS+= -DVFS_LKM -DMODVNOPS=${KMOD}vnops -I.
120SRCS+=	vnode_if.h
121CLEANFILES+=	vnode_if.h vnode_if.c
122.endif
123
124.if defined(PSEUDO_LKM)
125CFLAGS+= -DPSEUDO_LKM
126.endif
127
128DPSRCS+= ${SRCS:M*.h}
129OBJS+=  ${SRCS:N*.h:R:S/$/.o/g}
130
131.if !defined(PROG)
132PROG=	${KMOD}.o
133.endif
134
135${PROG}: ${DPSRCS} ${OBJS} ${DPADD} 
136	${LD} -r ${LDFLAGS} -o tmp.o ${OBJS}
137.if defined(EXPORT_SYMS)
138	@rm -f symb.tmp
139	@for i in ${EXPORT_SYMS} ; do echo $$i >> symb.tmp ; done
140	symorder -c symb.tmp tmp.o
141	@rm -f symb.tmp
142.endif
143	mv tmp.o ${.TARGET}
144
145# Temporary SMP fix continued.
146${OBJS}: ${SMPHDRS}
147
148.if !defined(NOMAN)
149.include <bsd.man.mk>
150.if !defined(_MANPAGES) || empty(_MANPAGES)
151MAN1=	${KMOD}.4
152.endif
153
154.elif !target(maninstall)
155maninstall: _SUBDIR
156all-man:
157.endif
158
159.MAIN: all
160all: objwarn ${PROG} all-man _SUBDIR
161
162CLEANFILES+=${PROG} ${OBJS} 
163
164.if !target(install)
165.if !target(beforeinstall)
166beforeinstall:
167.endif
168.if !target(afterinstall)
169afterinstall:
170.endif
171
172realinstall: _SUBDIR
173	${INSTALL} ${COPY} -o ${KMODOWN} -g ${KMODGRP} -m ${KMODMODE} \
174	    ${INSTALLFLAGS} ${PROG} ${DESTDIR}${KMODDIR}
175.if defined(LINKS) && !empty(LINKS)
176	@set ${LINKS}; \
177	while test $$# -ge 2; do \
178		l=${DESTDIR}$$1; \
179		shift; \
180		t=${DESTDIR}$$1; \
181		shift; \
182		${ECHO} $$t -\> $$l; \
183		rm -f $$t; \
184		ln ${LN_FLAGS} $$l $$t; \
185	done; true
186.endif
187
188install: afterinstall _SUBDIR
189.if !defined(NOMAN)
190afterinstall: realinstall maninstall
191.else
192afterinstall: realinstall
193.endif
194realinstall: beforeinstall
195.endif
196
197DISTRIBUTION?=	bin
198.if !target(distribute)
199distribute: _SUBDIR
200	cd ${.CURDIR} ; $(MAKE) install DESTDIR=${DISTDIR}/${DISTRIBUTION} SHARED=copies
201.endif
202
203.if defined(NOTAGS)
204tags:
205.endif
206
207.if !target(tags)
208tags: ${SRCS} _SUBDIR
209.if defined(PROG)
210	@cd ${.CURDIR} && gtags ${GTAGSFLAGS}
211.if defined(HTML)
212	@cd ${.CURDIR} && htags ${HTAGSFLAGS}
213.endif
214.endif
215.endif
216
217
218.if !target(load)
219load:	${PROG}
220	${MODLOAD} -o ${KMOD} -e${KMOD} ${PROG}
221.endif
222
223.if !target(unload)
224unload:	${PROG}
225	${MODUNLOAD} -n ${KMOD}
226.endif
227
228KERN=	${.CURDIR}/../../sys/kern
229
230vnode_if.h:	${KERN}/vnode_if.sh ${KERN}/vnode_if.src
231	sh ${KERN}/vnode_if.sh ${KERN}/vnode_if.src
232
233./vnode_if.h:	vnode_if.h
234
235.include <bsd.obj.mk>
236.include <bsd.dep.mk>
237.include <bsd.kern.mk>
238