Makefile revision 1.235
1#	$NetBSD: Makefile,v 1.235 2004/07/30 07:05:11 lukem Exp $
2
3#
4# This is the top-level makefile for building NetBSD. For an outline of
5# how to build a snapshot or release, as well as other release engineering
6# information, see http://www.NetBSD.org/developers/releng/index.html
7#
8# Not everything you can set or do is documented in this makefile. In
9# particular, you should review the files in /usr/share/mk (especially
10# bsd.README) for general information on building programs and writing
11# Makefiles within this structure, and see the comments in src/etc/Makefile
12# for further information on installation and release set options.
13#
14# Variables listed below can be set on the make command line (highest
15# priority), in /etc/mk.conf (middle priority), or in the environment
16# (lowest priority).
17#
18# Variables:
19#   DESTDIR is the target directory for installation of the compiled
20#	software. It defaults to /. Note that programs are built against
21#	libraries installed in DESTDIR.
22#   MKMAN, if `no', will prevent building of manual pages.
23#   MKOBJDIRS, if not `no', will build object directories at
24#	an appropriate point in a build.
25#   MKSHARE, if `no', will prevent building and installing
26#	anything in /usr/share.
27#   MKUPDATE, if not `no', will avoid a `make cleandir' at the start of
28#	`make build', as well as having the effects listed in
29#	/usr/share/mk/bsd.README.
30#   NOCLEANDIR, if defined, will avoid a `make cleandir' at the start
31#	of the `make build'.
32#   NOINCLUDES will avoid the `make includes' usually done by `make build'.
33#
34#   See mk.conf(5) for more details.
35#
36#
37# Targets:
38#   build:
39#	Builds a full release of NetBSD in DESTDIR, except for the
40#	/etc configuration files.
41#	If BUILD_DONE is set, this is an empty target.
42#   distribution:
43#	Builds a full release of NetBSD in DESTDIR, including the /etc
44#	configuration files.
45#   buildworld:
46#	As per `make distribution', except that it ensures that DESTDIR
47#	is not the root directory.
48#   installworld:
49#	Install the distribution from DESTDIR to INSTALLWORLDDIR (which
50#	defaults to the root directory).  Ensures that INSTALLWORLDDIR
51#	is the not root directory if cross compiling.
52#   release:
53#	Does a `make build', and then tars up the DESTDIR files
54#	into RELEASEDIR/${MACHINE}, in release(7) format.
55#	(See etc/Makefile for more information on this.)
56#   regression-tests:
57#	Runs the regression tests in "regress" on this host.
58#   sets:
59#	Populate ${RELEASEDIR}/${MACHINE}/binary/sets from ${DESTDIR}
60#   sourcesets:
61#	Populate ${RELEASEDIR}/source/sets from ${NETBSDSRCDIR}
62#
63# Targets invoked by `make build,' in order:
64#   cleandir:        cleans the tree.
65#   obj:             creates object directories.
66#   do-tools:        builds host toolchain.
67#   do-distrib-dirs: creates the distribution directories.
68#   includes:        installs include files.
69#   do-tools-compat: builds the "libnbcompat" library; needed for some
70#                    random host tool programs in the source tree.
71#   do-gnu-lib-libgcc3: builds and installs prerequisites from gnu/lib/libgcc3
72#   do-lib-csu:      builds and installs prerequisites from lib/csu.
73#   do-lib-libc:     builds and installs prerequisites from lib/libc.
74#   do-lib:          builds and installs prerequisites from lib.
75#   do-gnu-lib:      builds and installs prerequisites from gnu/lib.
76#   do-ld.so:        builds and installs prerequisites from libexec/ld.*_so.
77#   do-build:        builds and installs the entire system.
78#   do-x11:          builds and installs X11R6 from src/x11 if ${MKX11} != "no"
79#   do-obsolete:     installs the obsolete sets (for the postinstall-* targets).
80#
81
82.if ${.MAKEFLAGS:M${.CURDIR}/share/mk} == ""
83.MAKEFLAGS: -m ${.CURDIR}/share/mk
84.endif
85
86#
87# If _SRC_TOP_OBJ_ gets set here, we will end up with a directory that may
88# not be the top level objdir, because "make obj" can happen in the *middle*
89# of "make build" (long after <bsd.own.mk> is calculated it).  So, pre-set
90# _SRC_TOP_OBJ_ here so it will not be added to ${.MAKEOVERRIDES}.
91#
92_SRC_TOP_OBJ_=
93
94.include <bsd.own.mk>
95
96#
97# Sanity check: make sure that "make build" is not invoked simultaneously
98# with a standard recursive target.
99#
100
101.if make(build) || make(release) || make(snapshot)
102.for targ in ${TARGETS:Nobj:Ncleandir}
103.if make(${targ}) && !target(.BEGIN)
104.BEGIN:
105	@echo 'BUILD ABORTED: "make build" and "make ${targ}" are mutually exclusive.'
106	@false
107.endif
108.endfor
109.endif
110
111_SUBDIR=	tools lib include gnu bin games libexec sbin usr.bin
112_SUBDIR+=	usr.sbin share rescue sys etc .WAIT distrib regress
113
114#
115# Weed out directories that don't exist.
116#
117
118.for dir in ${_SUBDIR}
119.if exists(${dir}/Makefile) && (${BUILD_${dir}:Uyes} != "no")
120SUBDIR+=	${dir}
121.endif
122.endfor
123
124.if exists(regress)
125regression-tests: .PHONY
126	@echo Running regression tests...
127	${MAKEDIRTARGET} regress regress
128.endif
129
130.if ${MKUNPRIVED} != "no"
131NOPOSTINSTALL=	# defined
132.endif
133
134afterinstall: .PHONY
135.if ${MKMAN} != "no"
136	${MAKEDIRTARGET} share/man makedb
137.endif
138.if (${MKUNPRIVED} != "no" && ${MKINFO} != "no")
139	${MAKEDIRTARGET} gnu/usr.bin/texinfo/install-info infodir-meta
140.endif
141.if !defined(NOPOSTINSTALL)
142	${MAKEDIRTARGET} . postinstall-check
143.endif
144
145postinstall-check: .PHONY
146	@echo "   === Post installation checks ==="
147	${HOST_SH} ${.CURDIR}/etc/postinstall -s ${.CURDIR} -d ${DESTDIR}/ check
148	@echo "   ================================"
149
150postinstall-fix: .NOTMAIN .PHONY
151	@echo "   === Post installation fixes ==="
152	${HOST_SH} ${.CURDIR}/etc/postinstall -s ${.CURDIR} -d ${DESTDIR}/ fix
153	@echo "   ==============================="
154
155postinstall-fix-obsolete: .NOTMAIN .PHONY
156	@echo "   === Removing obsolete files ==="
157	${HOST_SH} ${.CURDIR}/etc/postinstall -s ${.CURDIR} -d ${DESTDIR}/ fix obsolete
158	@echo "   ==============================="
159
160
161#
162# Targets (in order!) called by "make build".
163#
164.if ${USE_TOOLS_TOOLCHAIN} == "no"
165LIBGCC_EXT=3
166.else
167LIBGCC_EXT=
168.endif
169
170BUILDTARGETS+=	check-tools
171.if ${MKUPDATE} == "no" && !defined(NOCLEANDIR)
172BUILDTARGETS+=	cleandir
173.endif
174.if ${MKOBJDIRS} != "no"
175BUILDTARGETS+=	obj
176.endif
177.if ${USETOOLS} == "yes"
178BUILDTARGETS+=	do-tools
179.endif
180.if !defined(NODISTRIBDIRS)
181BUILDTARGETS+=	do-distrib-dirs
182.endif
183.if !defined(NOINCLUDES)
184BUILDTARGETS+=	includes
185.endif
186BUILDTARGETS+=	do-tools-compat
187BUILDTARGETS+=	do-lib-csu
188.if ${MKGCC} != "no"
189BUILDTARGETS+=	do-gnu-lib-libgcc${LIBGCC_EXT}
190.endif
191BUILDTARGETS+=	do-lib-libc
192BUILDTARGETS+=	do-lib do-gnu-lib
193BUILDTARGETS+=	do-ld.so
194BUILDTARGETS+=	do-build
195.if ${MKX11} != "no"
196BUILDTARGETS+=	do-x11
197.endif
198BUILDTARGETS+=	do-obsolete
199
200#
201# Enforce proper ordering of some rules.
202#
203
204.ORDER:		${BUILDTARGETS}
205includes-lib:	.PHONY includes-include includes-sys
206includes-gnu:	.PHONY includes-lib
207
208#
209# Build the system and install into DESTDIR.
210#
211
212START_TIME!=	date
213
214build: .PHONY
215.if defined(BUILD_DONE)
216	@echo "Build already installed into ${DESTDIR}"
217.else
218	@echo "Build started at: ${START_TIME}"
219.for tgt in ${BUILDTARGETS}
220	${MAKEDIRTARGET} . ${tgt}
221.endfor
222	${MAKEDIRTARGET} etc install-etc-release
223	@echo   "Build started at:  ${START_TIME}"
224	@printf "Build finished at: " && date
225.endif
226
227#
228# Build a full distribution, but not a release (i.e. no sets into
229# ${RELEASEDIR}).  "buildworld" enforces a build to ${DESTDIR} != /
230#
231
232distribution buildworld: .PHONY
233.if make(buildworld) && \
234    (!defined(DESTDIR) || ${DESTDIR} == "" || ${DESTDIR} == "/")
235	@echo "Won't make ${.TARGET} with DESTDIR=/"
236	@false
237.endif
238	${MAKEDIRTARGET} . build NOPOSTINSTALL=1
239	${MAKEDIRTARGET} etc distribution INSTALL_DONE=1
240.if defined(DESTDIR) && ${DESTDIR} != "" && ${DESTDIR} != "/"
241	${MAKEDIRTARGET} . postinstall-fix-obsolete
242	${MAKEDIRTARGET} distrib/sets checkflist
243.endif
244	@echo   "make ${.TARGET} started at:  ${START_TIME}"
245	@printf "make ${.TARGET} finished at: " && date
246
247#
248# Install the distribution from $DESTDIR to $INSTALLWORLDDIR (defaults to `/')
249# If installing to /, ensures that the host's operating system is NetBSD and
250# the host's `uname -m` == ${MACHINE}.
251#
252
253HOST_UNAME_S!=	uname -s
254HOST_UNAME_M!=	uname -m
255
256installworld: .PHONY
257.if (!defined(DESTDIR) || ${DESTDIR} == "" || ${DESTDIR} == "/")
258	@echo "Can't make ${.TARGET} to DESTDIR=/"
259	@false
260.endif
261.if !defined(INSTALLWORLDDIR) || \
262    ${INSTALLWORLDDIR} == "" || ${INSTALLWORLDDIR} == "/"
263.if (${HOST_UNAME_S} != "NetBSD")
264	@echo "Won't cross-make ${.TARGET} from ${HOST_UNAME_S} to NetBSD with INSTALLWORLDDIR=/"
265	@false
266.endif
267.if (${HOST_UNAME_M} != ${MACHINE})
268	@echo "Won't cross-make ${.TARGET} from ${HOST_UNAME_M} to ${MACHINE} with INSTALLWORLDDIR=/"
269	@false
270.endif
271.endif
272	${MAKEDIRTARGET} distrib/sets installsets \
273	    INSTALLDIR=${INSTALLWORLDDIR:U/} INSTALLSETS=
274	${MAKEDIRTARGET} . postinstall-check DESTDIR=${INSTALLWORLDDIR}
275	@echo   "make ${.TARGET} started at:  ${START_TIME}"
276	@printf "make ${.TARGET} finished at: " && date
277
278#
279# Create sets from $DESTDIR or $NETBSDSRCDIR into $RELEASEDIR
280#
281
282.for tgt in sets sourcesets
283${tgt}: .PHONY
284	${MAKEDIRTARGET} distrib/sets ${tgt}
285.endfor
286
287#
288# Build a release or snapshot (implies "make build").  Note that
289# in this case, the set lists will be checked before the tar files
290# are made.
291#
292
293release snapshot: .PHONY
294	${MAKEDIRTARGET} . build NOPOSTINSTALL=1
295	${MAKEDIRTARGET} etc release INSTALL_DONE=1
296	@echo   "make ${.TARGET} started at:  ${START_TIME}"
297	@printf "make ${.TARGET} finished at: " && date
298
299#
300# Special components of the "make build" process.
301#
302
303check-tools: .PHONY
304.if ${TOOLCHAIN_MISSING} != "no" && !defined(EXTERNAL_TOOLCHAIN)
305	@echo '*** WARNING:  Building on MACHINE=${MACHINE} with missing toolchain.'
306	@echo '*** May result in a failed build or corrupt binaries!'
307.elif defined(EXTERNAL_TOOLCHAIN)
308	@echo '*** Using external toolchain rooted at ${EXTERNAL_TOOLCHAIN}.'
309.endif
310.if defined(NBUILDJOBS)
311	@echo '*** WARNING: NBUILDJOBS is obsolete; use -j directly instead!'
312.endif
313
314do-distrib-dirs: .PHONY
315.if !defined(DESTDIR) || ${DESTDIR} == ""
316	${MAKEDIRTARGET} etc distrib-dirs DESTDIR=/
317.else
318	${MAKEDIRTARGET} etc distrib-dirs DESTDIR=${DESTDIR}
319.endif
320
321.for targ in cleandir obj includes
322do-${targ}: .PHONY ${targ}
323	@true
324.endfor
325
326.for dir in tools tools/compat lib/csu gnu/lib/libgcc${LIBGCC_EXT} lib/libc lib/libdes lib gnu/lib
327do-${dir:S/\//-/g}: .PHONY
328.for targ in dependall install
329	${MAKEDIRTARGET} ${dir} ${targ}
330.endfor
331.endfor
332
333do-ld.so: .PHONY
334.for targ in dependall install
335.if (${OBJECT_FMT} == "a.out")
336	${MAKEDIRTARGET} libexec/ld.aout_so ${targ}
337.endif
338.if (${OBJECT_FMT} == "ELF")
339	${MAKEDIRTARGET} libexec/ld.elf_so ${targ}
340.endif
341.endfor
342
343do-build: .PHONY
344.for targ in dependall install
345	${MAKEDIRTARGET} . ${targ} BUILD_tools=no BUILD_lib=no
346.endfor
347
348do-x11: .PHONY
349	${MAKEDIRTARGET} x11 build
350
351do-obsolete: .PHONY
352	${MAKEDIRTARGET} etc install-obsolete-lists
353
354#
355# Speedup stubs for some subtrees that don't need to run these rules.
356# (Tells <bsd.subdir.mk> not to recurse for them.)
357#
358
359.for dir in bin etc distrib games libexec regress sbin usr.sbin tools
360includes-${dir}: .PHONY
361	@true
362.endfor
363.for dir in etc distrib regress
364install-${dir}: .PHONY
365	@true
366.endfor
367
368#
369# XXX this needs to change when distrib Makefiles are recursion compliant
370# XXX many distrib subdirs need "cd etc && make snap_pre snap_kern" first...
371#
372dependall-distrib depend-distrib all-distrib: .PHONY
373	@true
374
375.include <bsd.sys.mk>
376.include <bsd.obj.mk>
377.include <bsd.kernobj.mk>
378.include <bsd.subdir.mk>
379
380build-docs: .PHONY ${.CURDIR}/BUILDING
381${.CURDIR}/BUILDING: doc/BUILDING.mdoc
382	${_MKMSG_CREATE} ${.TARGET}
383	${TOOL_GROFF} -mdoc -Tascii -P-bou $> >$@
384
385
386#
387# Display current make(1) parameters
388#
389params: .PHONY
390	${MAKEDIRTARGET} etc params
391