Makefile revision 1.170 1 1.170 joerg # $NetBSD: Makefile,v 1.170 2013/09/02 14:34:57 joerg Exp $
2 1.1 tv
3 1.3 tv .include <bsd.own.mk>
4 1.167 matt .include <bsd.endian.mk>
5 1.3 tv
6 1.159 joerg # Make sure that the ordered build/install processing applies when using
7 1.159 joerg # plain make.
8 1.159 joerg .MAIN: build_install
9 1.159 joerg
10 1.164 apb # TOOLDIR must be valid, unless MKTOOLS=no
11 1.164 apb .if ${MKTOOLS:Uyes} != "no"
12 1.164 apb .if "${TOOLDIR}" == ""
13 1.164 apb .error "TOOLDIR is undefined or empty"
14 1.164 apb .elif "${TOOLDIR:tW:M/*}" == ""
15 1.164 apb .error "TOOLDIR is not an absolute path: ${TOOLDIR}"
16 1.164 apb #.elif !exists(TOOLDIR) # XXX .exists fails for directories
17 1.164 apb #.error "TOOLDIR does not exist: ${TOOLDIR}"
18 1.164 apb .endif
19 1.164 apb .endif # MKTOOLS != no
20 1.164 apb
21 1.166 pooka # TOOLS_BUILDRUMP == yes builds only the subset of the tools required
22 1.166 pooka # for building rump kernels and the hypervisor. It is typically used
23 1.166 pooka # when building rump kernels targeted for non-NetBSD systems (via
24 1.166 pooka # buildrump.sh), and should not be set for a regular "make build".
25 1.166 pooka TOOLS_BUILDRUMP?=no
26 1.166 pooka
27 1.160 pooka .if ${TOOLCHAIN_MISSING} == "no"
28 1.160 pooka .if defined(HAVE_GCC)
29 1.94 jmc TOOLCHAIN_BITS= gmake .WAIT
30 1.156 joerg .endif
31 1.156 joerg
32 1.156 joerg .if defined(HAVE_GCC)
33 1.146 mrg .if ${HAVE_GCC} >= 45
34 1.146 mrg TOOLCHAIN_BITS+= gmp .WAIT
35 1.146 mrg TOOLCHAIN_BITS+= mpfr .WAIT
36 1.146 mrg TOOLCHAIN_BITS+= mpc .WAIT
37 1.94 jmc .endif
38 1.156 joerg .endif
39 1.156 joerg .endif
40 1.156 joerg
41 1.156 joerg .if ${TOOLCHAIN_MISSING} == "no"
42 1.94 jmc TOOLCHAIN_BITS+= binutils .WAIT
43 1.156 joerg .endif
44 1.156 joerg
45 1.156 joerg .if defined(HAVE_GCC)
46 1.156 joerg .if ${TOOLCHAIN_MISSING} == "no"
47 1.77 mrg TOOLCHAIN_BITS+= gcc
48 1.169 matt . if ${MKCROSSGDB:Uno} != "no" || make(obj)
49 1.74 cl TOOLCHAIN_BITS+= gdb
50 1.70 mrg . endif
51 1.156 joerg TOOLCHAIN_BITS+= .WAIT
52 1.31 tv .endif
53 1.118 gmcgarry .endif
54 1.118 gmcgarry
55 1.118 gmcgarry .if defined(HAVE_PCC)
56 1.118 gmcgarry .if ${TOOLCHAIN_MISSING} == "no"
57 1.118 gmcgarry TOOLCHAIN_BITS+= pcc
58 1.118 gmcgarry .endif
59 1.118 gmcgarry .endif
60 1.31 tv
61 1.157 pooka .if ${TOOLCHAIN_MISSING} == "no"
62 1.157 pooka # XXX Eventually, we want to be able to build dbsym and mdsetimage
63 1.157 pooka # XXX if EXTERNAL_TOOLCHAIN is set.
64 1.156 joerg TOOLCHAIN_BITS+= dbsym mdsetimage
65 1.157 pooka .endif
66 1.156 joerg
67 1.137 darran DTRACE_BITS=
68 1.137 darran .if ${MKDTRACE} != "no"
69 1.137 darran DTRACE_BITS+= .WAIT libelf
70 1.137 darran DTRACE_BITS+= .WAIT libdwarf
71 1.162 apb DTRACE_BITS+= .WAIT libctf
72 1.137 darran DTRACE_BITS+= .WAIT ctfconvert ctfmerge
73 1.137 darran .endif
74 1.137 darran
75 1.99 mrg LINT_BITS=
76 1.99 mrg .if ${MKLINT} != "no"
77 1.99 mrg LINT_BITS= lint lint2
78 1.99 mrg .endif
79 1.99 mrg
80 1.165 apb # All of host-mkdep, compat, and binstall are needed before anything
81 1.165 apb # else. Within this group, they must be built in a specific order, and
82 1.165 apb # all of them must be built before any of them is installed. They may
83 1.165 apb # be installed in any order. This can't be expressed using the .WAIT
84 1.165 apb # notation inside the SUBDIR list.
85 1.165 apb #
86 1.165 apb # XXX .ORDER does not work when multiple targets are passed on the
87 1.165 apb # make command line without "-j", so use dependencies in addition to .ORDER.
88 1.165 apb #
89 1.165 apb .ORDER: dependall-host-mkdep dependall-compat dependall-binstall
90 1.165 apb .if make(dependall-host-mkdep) && make(dependall-compat)
91 1.165 apb dependall-compat: dependall-host-mkdep
92 1.165 apb .endif
93 1.165 apb .if make(dependall-compat) && make(dependall-binstall)
94 1.165 apb dependall-binstall: dependall-compat
95 1.165 apb .endif
96 1.165 apb
97 1.16 tv # Dependencies in SUBDIR below ordered to maximize parallel ability.
98 1.165 apb # See above for special treatment for host-mkdep, compat, and binstall.
99 1.165 apb #
100 1.165 apb SUBDIR= host-mkdep compat binstall \
101 1.166 pooka .WAIT mktemp .WAIT sed .WAIT
102 1.166 pooka .if ${TOOLS_BUILDRUMP} == "no"
103 1.166 pooka SUBDIR+= cap_mkdb crunchgen ctags genassym gencat hexdump \
104 1.99 mrg ${LINT_BITS} \
105 1.166 pooka makewhatis mtree nbperf .WAIT rpcgen uudecode
106 1.166 pooka .endif
107 1.166 pooka
108 1.166 pooka SUBDIR+= join lorder m4 mkdep tsort .WAIT yacc .WAIT awk .WAIT lex
109 1.166 pooka
110 1.166 pooka .if ${TOOLS_BUILDRUMP} == "no"
111 1.166 pooka SUBDIR += .WAIT texinfo \
112 1.153 christos .WAIT tic \
113 1.132 mrg .WAIT pax \
114 1.132 mrg .WAIT ${TOOLCHAIN_BITS} \
115 1.137 darran ${DTRACE_BITS} \
116 1.166 pooka asn1_compile cat cksum compile_et db \
117 1.145 elric file lint1 slc \
118 1.144 riz makefs .WAIT menuc mkcsmapper mkesdb mklocale mknod msgc \
119 1.132 mrg .WAIT disklabel \
120 1.132 mrg .WAIT paxctl \
121 1.132 mrg .WAIT fdisk \
122 1.132 mrg .WAIT installboot \
123 1.154 njoly pwd_mkdb stat strfile sunlabel zic
124 1.166 pooka .endif
125 1.166 pooka SUBDIR+= .WAIT config
126 1.39 tv
127 1.142 joerg .if ${MKLLVM} != "no"
128 1.142 joerg SUBDIR+= \
129 1.142 joerg llvm .WAIT \
130 1.149 joerg llvm-lib/libLLVMSupport llvm-lib/libLLVMTableGen .WAIT \
131 1.159 joerg llvm-tblgen llvm-clang-tblgen .WAIT \
132 1.142 joerg llvm-include .WAIT \
133 1.142 joerg llvm-lib .WAIT \
134 1.142 joerg llvm-clang
135 1.170 joerg .if ${MKLLD} != "no"
136 1.170 joerg SUBDIR+= llvm-lld
137 1.170 joerg .endif
138 1.168 joerg .if ${MKMCLINKER} != "no"
139 1.168 joerg SUBDIR+= llvm-mcld
140 1.168 joerg .endif
141 1.142 joerg .endif
142 1.142 joerg
143 1.121 dyoung .if ${MKMAN} != "no" || ${MKDOC} != "no" || ${MKHTML} != "no"
144 1.136 joerg . if ${MKGROFF} != "no"
145 1.39 tv SUBDIR+= groff
146 1.136 joerg . endif
147 1.128 joerg SUBDIR+= mandoc
148 1.39 tv .endif
149 1.22 tv
150 1.166 pooka .if ${TOOLS_BUILDRUMP} == "no"
151 1.166 pooka
152 1.22 tv .if ${MKMAINTAINERTOOLS:Uno} != "no"
153 1.103 lukem SUBDIR+= autoconf .WAIT gettext
154 1.72 matt .endif
155 1.72 matt
156 1.140 mrg .if ${USE_PIGZGZIP} != "no"
157 1.140 mrg SUBDIR+= pigz
158 1.140 mrg .endif
159 1.140 mrg
160 1.86 jmc .if ${MACHINE} == "hp700"
161 1.83 skrll SUBDIR+= hp700-mkboot
162 1.83 skrll .endif
163 1.83 skrll
164 1.86 jmc .if ${MACHINE} == "ibmnws"
165 1.72 matt SUBDIR+= ibmnws-ncdcs
166 1.79 matt .endif
167 1.79 matt
168 1.86 jmc .if ${MACHINE} == "macppc"
169 1.79 matt SUBDIR+= macppc-fixcoff
170 1.48 kleink .endif
171 1.48 kleink
172 1.116 garbled .if (${MACHINE} == "prep" || ${MACHINE} == "rs6000" || ${MACHINE} == "bebox")
173 1.115 garbled SUBDIR+= powerpc-mkbootimage
174 1.22 tv .endif
175 1.37 gmcgarry
176 1.148 tsutsui .if ${MACHINE_ARCH} == "m68k"
177 1.148 tsutsui SUBDIR+= m68k-elf2aout
178 1.148 tsutsui .endif
179 1.148 tsutsui
180 1.147 mrg .if (${MACHINE_ARCH} == "mipsel" || ${MACHINE_ARCH} == "mipseb" || \
181 1.147 mrg ${MACHINE_ARCH} == "mips64el" || ${MACHINE_ARCH} == "mips64eb")
182 1.37 gmcgarry SUBDIR+= mips-elf2ecoff
183 1.76 sekiya .endif
184 1.76 sekiya
185 1.76 sekiya .if (${MACHINE} == "sgimips")
186 1.76 sekiya SUBDIR+= sgivol
187 1.51 bjh21 .endif
188 1.51 bjh21
189 1.82 abs .if ${MACHINE} == "acorn32"
190 1.82 abs SUBDIR+= sparkcrc
191 1.82 abs .endif
192 1.82 abs
193 1.125 abs .if (${MACHINE_ARCH} == "sparc" || ${MACHINE_ARCH} == "sparc64")
194 1.51 bjh21 SUBDIR+= fgen
195 1.37 gmcgarry .endif
196 1.37 gmcgarry
197 1.85 jmc .if ${MACHINE} == "amiga"
198 1.85 jmc SUBDIR+= amiga-elf2bb
199 1.85 jmc SUBDIR+= amiga-txlt
200 1.85 jmc .endif
201 1.85 jmc
202 1.86 jmc .if ${MACHINE} == "hp300"
203 1.86 jmc SUBDIR+= hp300-mkboot
204 1.86 jmc .endif
205 1.86 jmc
206 1.167 matt .if ${MACHINE} == "evbarm" \
207 1.167 matt && ${MACHINE_CPU} == "arm" \
208 1.167 matt && ${TARGET_ENDIANNESS} == "1234"
209 1.158 jkunz SUBDIR+= elftosb
210 1.158 jkunz .endif
211 1.158 jkunz
212 1.143 phx .if ${MACHINE} == "evbarm" || ${MACHINE} == "evbmips" || \
213 1.143 phx ${MACHINE} == "evbppc" || ${MACHINE} == "sandpoint"
214 1.139 jmcneill SUBDIR+= mkubootimage
215 1.139 jmcneill .endif
216 1.139 jmcneill
217 1.166 pooka .endif # TOOLCHAIN_BUILDRUMP
218 1.166 pooka
219 1.66 lukem check_MKTOOLS: .PHONY .NOTMAIN
220 1.19 jmc .if ${MKTOOLS:Uyes} == "no"
221 1.17 tv @echo '*** WARNING: "MKTOOLS" is set to "no"; this will prevent building and'
222 1.17 tv @echo '*** updating your host toolchain. This should be used only as a'
223 1.17 tv @echo '*** temporary workaround for toolchain problems, as it will result'
224 1.23 wiz @echo '*** in version skew and build errors over time!'
225 1.18 jmc .endif
226 1.17 tv
227 1.66 lukem .if ${MKTOOLS:Uyes} == "no" || ${USETOOLS} != "yes" # {
228 1.163 apb SUBDIR= # empty
229 1.67 lukem realall realdepend install: check_MKTOOLS
230 1.66 lukem .endif # }
231 1.1 tv
232 1.1 tv .include <bsd.subdir.mk>
233 1.159 joerg .include <bsd.buildinstall.mk>
234 1.11 tv .include <bsd.obj.mk>
235 1.16 tv
236 1.102 tron .if !defined(PREVIOUSTOOLDIR)
237 1.102 tron . if exists(PREVIOUSTOOLDIR)
238 1.66 lukem PREVIOUSTOOLDIR!= cat PREVIOUSTOOLDIR
239 1.102 tron . else
240 1.162 apb PREVIOUSTOOLDIR=
241 1.102 tron . endif
242 1.66 lukem .endif
243 1.66 lukem
244 1.66 lukem CLEANFILES+= PREVIOUSTOOLDIR
245 1.66 lukem
246 1.101 tron realall realdepend: .MAKE
247 1.107 apb .if !empty(PREVIOUSTOOLDIR) && "${PREVIOUSTOOLDIR}" != "${TOOLDIR}"
248 1.66 lukem @echo "*** WARNING: TOOLDIR has moved?"
249 1.66 lukem @echo "*** PREVIOUSTOOLDIR '${PREVIOUSTOOLDIR}'"
250 1.66 lukem @echo "*** != TOOLDIR '${TOOLDIR}'"
251 1.66 lukem @echo "*** Cleaning mis-matched tools"
252 1.66 lukem rm -f PREVIOUSTOOLDIR
253 1.106 freza (cd ${.CURDIR} && ${MAKE} PREVIOUSTOOLDIR=${TOOLDIR} cleandir)
254 1.66 lukem .endif
255 1.102 tron echo ${TOOLDIR} >PREVIOUSTOOLDIR
256 1.66 lukem
257 1.69 tron cleandir:
258 1.69 tron rm -f ${CLEANFILES}
259