Print this page
4029 remove tonic build bits
Split |
Close |
Expand all |
Collapse all |
--- old/usr/src/Makefile.master
+++ new/usr/src/Makefile.master
1 1 #
2 2 # CDDL HEADER START
3 3 #
4 4 # The contents of this file are subject to the terms of the
5 5 # Common Development and Distribution License (the "License").
6 6 # You may not use this file except in compliance with the License.
7 7 #
8 8 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 9 # or http://www.opensolaris.org/os/licensing.
10 10 # See the License for the specific language governing permissions
11 11 # and limitations under the License.
12 12 #
13 13 # When distributing Covered Code, include this CDDL HEADER in each
14 14 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 15 # If applicable, add the following below this CDDL HEADER, with the
16 16 # fields enclosed by brackets "[]" replaced with your own identifying
17 17 # information: Portions Copyright [yyyy] [name of copyright owner]
18 18 #
19 19 # CDDL HEADER END
20 20 #
21 21
22 22 #
23 23 # Copyright (c) 1989, 2010, Oracle and/or its affiliates. All rights reserved.
24 24 # Copyright (c) 2012 by Delphix. All rights reserved.
25 25 #
26 26
27 27 #
28 28 # Makefile.master, global definitions for system source
29 29 #
30 30 ROOT= /proto
31 31
32 32 #
33 33 # RELEASE_BUILD should be cleared for final release builds.
34 34 # NOT_RELEASE_BUILD is exactly what the name implies.
35 35 #
36 36 # INTERNAL_RELEASE_BUILD is a subset of RELEASE_BUILD. It mostly controls
37 37 # identification strings. Enabling RELEASE_BUILD automatically enables
38 38 # INTERNAL_RELEASE_BUILD.
39 39 #
40 40 # STRIP_COMMENTS toggles comment section striping. Generally the same setting
41 41 # as INTERNAL_RELEASE_BUILD.
42 42 #
43 43 # __GNUC toggles the building of ON components using gcc and related tools.
44 44 # Normally set to `#', set it to `' to do gcc build.
45 45 #
46 46 # The declaration POUND_SIGN is always '#'. This is needed to get around the
47 47 # make feature that '#' is always a comment delimiter, even when escaped or
48 48 # quoted. We use this macro expansion method to get POUND_SIGN rather than
49 49 # always breaking out a shell because the general case can cause a noticable
50 50 # slowdown in build times when so many Makefiles include Makefile.master.
51 51 #
52 52 # While the majority of users are expected to override the setting below
53 53 # with an env file (via nightly or bldenv), if you aren't building that way
54 54 # (ie, you're using "ws" or some other bootstrapping method) then you need
55 55 # this definition in order to avoid the subshell invocation mentioned above.
56 56 #
57 57
58 58 PRE_POUND= pre\#
59 59 POUND_SIGN= $(PRE_POUND:pre\%=%)
60 60
61 61 NOT_RELEASE_BUILD=
62 62 INTERNAL_RELEASE_BUILD= $(POUND_SIGN)
63 63 RELEASE_BUILD= $(POUND_SIGN)
64 64 $(RELEASE_BUILD)NOT_RELEASE_BUILD= $(POUND_SIGN)
65 65 $(RELEASE_BUILD)INTERNAL_RELEASE_BUILD=
66 66 PATCH_BUILD= $(POUND_SIGN)
↓ open down ↓ |
66 lines elided |
↑ open up ↑ |
67 67
68 68 # SPARC_BLD is '#' for an Intel build.
69 69 # INTEL_BLD is '#' for a Sparc build.
70 70 SPARC_BLD_1= $(MACH:i386=$(POUND_SIGN))
71 71 SPARC_BLD= $(SPARC_BLD_1:sparc=)
72 72 INTEL_BLD_1= $(MACH:sparc=$(POUND_SIGN))
73 73 INTEL_BLD= $(INTEL_BLD_1:i386=)
74 74
75 75 STRIP_COMMENTS= $(INTERNAL_RELEASE_BUILD)
76 76
77 -# Are we building tonic closedbins? Unless you have used the
78 -# -O flag to nightly or bldenv, leave the definition of TONICBUILD
79 -# as $(POUND_SIGN).
80 -#
81 -# IF YOU CHANGE CLOSEDROOT, you MUST change install.bin
82 -# to match the new definition.
83 -TONICBUILD= $(POUND_SIGN)
84 -$(TONICBUILD)CLOSEDROOT= $(ROOT)-closed
85 -
86 -
87 77 # The variables below control the compilers used during the build.
88 78 # There are a number of permutations.
89 79 #
90 80 # __GNUC and __SUNC control (and indicate) the primary compiler. Whichever
91 81 # one is not POUND_SIGN is the primary, with the other as the shadow. They
92 82 # may also be used to control entirely compiler-specific Makefile assignments.
93 83 # __SUNC and Sun Studio are the default.
94 84 #
95 85 # __GNUC64 indicates that the 64bit build should use the GNU C compiler.
96 86 # There is no Sun C analogue.
97 87 #
98 88 # The following version-specific options are operative regardless of which
99 89 # compiler is primary, and control the versions of the given compilers to be
100 90 # used. They also allow compiler-version specific Makefile fragments.
101 91 #
102 92
103 93 __GNUC= $(POUND_SIGN)
104 94 $(__GNUC)__SUNC= $(POUND_SIGN)
105 95 __GNUC64= $(__GNUC)
106 96
107 97 # CLOSED is the root of the tree that contains source which isn't released
108 98 # as open source
109 99 CLOSED= $(SRC)/../closed
110 100
111 101 # BUILD_TOOLS is the root of all tools including compilers.
112 102 # ONBLD_TOOLS is the root of all the tools that are part of SUNWonbld.
113 103
114 104 BUILD_TOOLS= /ws/onnv-tools
115 105 ONBLD_TOOLS= $(BUILD_TOOLS)/onbld
116 106
117 107 JAVA_ROOT= /usr/java
118 108
119 109 SFW_ROOT= /usr/sfw
120 110 SFWINCDIR= $(SFW_ROOT)/include
121 111 SFWLIBDIR= $(SFW_ROOT)/lib
122 112 SFWLIBDIR64= $(SFW_ROOT)/lib/$(MACH64)
123 113
124 114 GCC_ROOT= /opt/gcc/4.4.4
125 115 GCCLIBDIR= $(GCC_ROOT)/lib
126 116 GCCLIBDIR64= $(GCC_ROOT)/lib/$(MACH64)
127 117
128 118 DOCBOOK_XSL_ROOT= /usr/share/sgml/docbook/xsl-stylesheets
129 119
130 120 RPCGEN= /usr/bin/rpcgen
131 121 STABS= $(ONBLD_TOOLS)/bin/$(MACH)/stabs
132 122 ELFEXTRACT= $(ONBLD_TOOLS)/bin/$(MACH)/elfextract
133 123 MBH_PATCH= $(ONBLD_TOOLS)/bin/$(MACH)/mbh_patch
134 124 ECHO= echo
135 125 INS= install
136 126 TRUE= true
137 127 SYMLINK= /usr/bin/ln -s
138 128 LN= /usr/bin/ln
139 129 CHMOD= /usr/bin/chmod
140 130 MV= /usr/bin/mv -f
141 131 RM= /usr/bin/rm -f
142 132 CUT= /usr/bin/cut
143 133 NM= /usr/ccs/bin/nm
144 134 DIFF= /usr/bin/diff
145 135 GREP= /usr/bin/grep
146 136 EGREP= /usr/bin/egrep
147 137 ELFWRAP= /usr/bin/elfwrap
148 138 KSH93= /usr/bin/ksh93
149 139 SED= /usr/bin/sed
150 140 NAWK= /usr/bin/nawk
151 141 CP= /usr/bin/cp -f
152 142 MCS= /usr/ccs/bin/mcs
153 143 CAT= /usr/bin/cat
154 144 ELFDUMP= /usr/ccs/bin/elfdump
155 145 M4= /usr/ccs/bin/m4
156 146 STRIP= /usr/ccs/bin/strip
157 147 LEX= /usr/ccs/bin/lex
158 148 FLEX= $(SFW_ROOT)/bin/flex
159 149 YACC= /usr/ccs/bin/yacc
160 150 CPP= /usr/lib/cpp
161 151 JAVAC= $(JAVA_ROOT)/bin/javac
162 152 JAVAH= $(JAVA_ROOT)/bin/javah
163 153 JAVADOC= $(JAVA_ROOT)/bin/javadoc
164 154 RMIC= $(JAVA_ROOT)/bin/rmic
165 155 JAR= $(JAVA_ROOT)/bin/jar
166 156 CTFCONVERT= $(ONBLD_TOOLS)/bin/$(MACH)/ctfconvert
167 157 CTFMERGE= $(ONBLD_TOOLS)/bin/$(MACH)/ctfmerge
168 158 CTFSTABS= $(ONBLD_TOOLS)/bin/$(MACH)/ctfstabs
169 159 CTFSTRIP= $(ONBLD_TOOLS)/bin/$(MACH)/ctfstrip
170 160 NDRGEN= $(ONBLD_TOOLS)/bin/$(MACH)/ndrgen
171 161 GENOFFSETS= $(ONBLD_TOOLS)/bin/genoffsets
172 162 CTFCVTPTBL= $(ONBLD_TOOLS)/bin/ctfcvtptbl
173 163 CTFFINDMOD= $(ONBLD_TOOLS)/bin/ctffindmod
174 164 XREF= $(ONBLD_TOOLS)/bin/xref
175 165 FIND= /usr/bin/find
176 166 PERL= /usr/bin/perl
177 167 PYTHON_26= /usr/bin/python2.6
178 168 PYTHON= $(PYTHON_26)
179 169 SORT= /usr/bin/sort
180 170 TOUCH= /usr/bin/touch
181 171 WC= /usr/bin/wc
182 172 XARGS= /usr/bin/xargs
183 173 ELFEDIT= /usr/bin/elfedit
184 174 ELFSIGN= /usr/bin/elfsign
185 175 DTRACE= /usr/sbin/dtrace -xnolibs
186 176 UNIQ= /usr/bin/uniq
187 177 TAR= /usr/bin/tar
188 178
189 179 FILEMODE= 644
190 180 DIRMODE= 755
191 181
192 182 #
193 183 # The version of the patch makeup table optimized for build-time use. Used
194 184 # during patch builds only.
195 185 $(PATCH_BUILD)PMTMO_FILE=$(SRC)/patch_makeup_table.mo
196 186
197 187 # Declare that nothing should be built in parallel.
198 188 # Individual Makefiles can use the .PARALLEL target to declare otherwise.
199 189 .NO_PARALLEL:
200 190
201 191 # For stylistic checks
202 192 #
203 193 # Note that the X and C checks are not used at this time and may need
204 194 # modification when they are actually used.
205 195 #
206 196 CSTYLE= $(ONBLD_TOOLS)/bin/cstyle
207 197 CSTYLE_TAIL=
208 198 HDRCHK= $(ONBLD_TOOLS)/bin/hdrchk
209 199 HDRCHK_TAIL=
210 200 JSTYLE= $(ONBLD_TOOLS)/bin/jstyle
211 201
212 202 DOT_H_CHECK= \
213 203 @$(ECHO) "checking $<"; $(CSTYLE) $< $(CSTYLE_TAIL); \
214 204 $(HDRCHK) $< $(HDRCHK_TAIL)
215 205
216 206 DOT_X_CHECK= \
217 207 @$(ECHO) "checking $<"; $(RPCGEN) -C -h $< | $(CSTYLE) $(CSTYLE_TAIL); \
218 208 $(RPCGEN) -C -h $< | $(HDRCHK) $< $(HDRCHK_TAIL)
219 209
↓ open down ↓ |
123 lines elided |
↑ open up ↑ |
220 210 DOT_C_CHECK= \
221 211 @$(ECHO) "checking $<"; $(CSTYLE) $< $(CSTYLE_TAIL)
222 212
223 213 MANIFEST_CHECK= \
224 214 @$(ECHO) "checking $<"; \
225 215 SVCCFG_DTD=$(SRC)/cmd/svc/dtd/service_bundle.dtd.1 \
226 216 SVCCFG_REPOSITORY=$(SRC)/cmd/svc/seed/global.db \
227 217 SVCCFG_CONFIGD_PATH=$(SRC)/cmd/svc/configd/svc.configd-native \
228 218 $(SRC)/cmd/svc/svccfg/svccfg-native validate $<
229 219
230 -#
231 -# IMPORTANT:: If you change any of INS.file, INS.dir, INS.rename,
232 -# INS.link or INS.symlink here, then you must also change the
233 -# corresponding override definitions in $CLOSED/Makefile.tonic.
234 -# If you do not do this, then the closedbins build for the OpenSolaris
235 -# community will break. PS, the gatekeepers will be upset too.
236 220 INS.file= $(RM) $@; $(INS) -s -m $(FILEMODE) -f $(@D) $<
237 221 INS.dir= $(INS) -s -d -m $(DIRMODE) $@
238 222 # installs and renames at once
239 223 #
240 224 INS.rename= $(INS.file); $(MV) $(@D)/$(<F) $@
241 225
242 226 # install a link
243 227 INSLINKTARGET= $<
244 228 INS.link= $(RM) $@; $(LN) $(INSLINKTARGET) $@
245 229 INS.symlink= $(RM) $@; $(SYMLINK) $(INSLINKTARGET) $@
246 230
247 231 #
248 232 # Python bakes the mtime of the .py file into the compiled .pyc and
249 233 # rebuilds if the baked-in mtime != the mtime of the source file
250 234 # (rather than only if it's less than), thus when installing python
251 235 # files we must make certain to not adjust the mtime of the source
252 236 # (.py) file.
253 237 #
254 238 INS.pyfile= $(INS.file); $(TOUCH) -r $< $@
255 239
256 240 # MACH must be set in the shell environment per uname -p on the build host
257 241 # More specific architecture variables should be set in lower makefiles.
258 242 #
259 243 # MACH64 is derived from MACH, and BUILD64 is set to `#' for
260 244 # architectures on which we do not build 64-bit versions.
261 245 # (There are no such architectures at the moment.)
262 246 #
263 247 # Set BUILD64=# in the environment to disable 64-bit amd64
264 248 # builds on i386 machines.
265 249
266 250 MACH64_1= $(MACH:sparc=sparcv9)
267 251 MACH64= $(MACH64_1:i386=amd64)
268 252
269 253 MACH32_1= $(MACH:sparc=sparcv7)
270 254 MACH32= $(MACH32_1:i386=i86)
271 255
272 256 sparc_BUILD64=
273 257 i386_BUILD64=
274 258 BUILD64= $($(MACH)_BUILD64)
275 259
276 260 #
277 261 # C compiler mode. Future compilers may change the default on us,
278 262 # so force extended ANSI mode globally. Lower level makefiles can
279 263 # override this by setting CCMODE.
280 264 #
281 265 CCMODE= -Xa
282 266 CCMODE64= -Xa
283 267
284 268 #
285 269 # C compiler verbose mode. This is so we can enable it globally,
286 270 # but turn it off in the lower level makefiles of things we cannot
287 271 # (or aren't going to) fix.
288 272 #
289 273 CCVERBOSE= -v
290 274
291 275 # set this to the secret flag "-Wc,-Qiselect-v9abiwarn=1" to get warnings
292 276 # from the compiler about places the -xarch=v9 may differ from -xarch=v9c.
293 277 V9ABIWARN=
294 278
295 279 # set this to the secret flag "-Wc,-Qiselect-regsym=0" to disable register
296 280 # symbols (used to detect conflicts between objects that use global registers)
297 281 # we disable this now for safety, and because genunix doesn't link with
298 282 # this feature (the v9 default) enabled.
299 283 #
300 284 # REGSYM is separate since the C++ driver syntax is different.
301 285 CCREGSYM= -Wc,-Qiselect-regsym=0
302 286 CCCREGSYM= -Qoption cg -Qiselect-regsym=0
303 287
304 288 # Prevent the removal of static symbols by the SPARC code generator (cg).
305 289 # The x86 code generator (ube) does not remove such symbols and as such
306 290 # using this workaround is not applicable for x86.
307 291 #
308 292 CCSTATICSYM= -Wc,-Qassembler-ounrefsym=0
309 293 #
310 294 # generate 32-bit addresses in the v9 kernel. Saves memory.
311 295 CCABS32= -Wc,-xcode=abs32
312 296 #
313 297 # generate v9 code which tolerates callers using the v7 ABI, for the sake of
314 298 # system calls.
315 299 CC32BITCALLERS= -_gcc=-massume-32bit-callers
316 300
317 301 # GCC, especially, is increasingly beginning to auto-inline functions and
318 302 # sadly does so separately not under the general -fno-inline-functions
319 303 # Additionally, we wish to prevent optimisations which cause GCC to clone
320 304 # functions -- in particular, these may cause unhelpful symbols to be
321 305 # emitted instead of function names
322 306 CCNOAUTOINLINE= -_gcc=-fno-inline-small-functions \
323 307 -_gcc=-fno-inline-functions-called-once \
324 308 -_gcc=-fno-ipa-cp
325 309
326 310 # One optimization the compiler might perform is to turn this:
327 311 # #pragma weak foo
328 312 # extern int foo;
329 313 # if (&foo)
330 314 # foo = 5;
331 315 # into
332 316 # foo = 5;
333 317 # Since we do some of this (foo might be referenced in common kernel code
334 318 # but provided only for some cpu modules or platforms), we disable this
335 319 # optimization.
336 320 #
337 321 sparc_CCUNBOUND = -Wd,-xsafe=unboundsym
338 322 i386_CCUNBOUND =
339 323 CCUNBOUND = $($(MACH)_CCUNBOUND)
340 324
341 325 #
342 326 # compiler '-xarch' flag. This is here to centralize it and make it
343 327 # overridable for testing.
344 328 sparc_XARCH= -m32
345 329 sparcv9_XARCH= -m64
346 330 i386_XARCH=
347 331 amd64_XARCH= -m64 -Ui386 -U__i386
348 332
349 333 # assembler '-xarch' flag. Different from compiler '-xarch' flag.
350 334 sparc_AS_XARCH= -xarch=v8plus
351 335 sparcv9_AS_XARCH= -xarch=v9
352 336 i386_AS_XARCH=
353 337 amd64_AS_XARCH= -xarch=amd64 -P -Ui386 -U__i386
354 338
355 339 #
356 340 # These flags define what we need to be 'standalone' i.e. -not- part
357 341 # of the rather more cosy userland environment. This basically means
358 342 # the kernel.
359 343 #
360 344 # XX64 future versions of gcc will make -mcmodel=kernel imply -mno-red-zone
361 345 #
362 346 sparc_STAND_FLAGS= -_gcc=-ffreestanding
363 347 sparcv9_STAND_FLAGS= -_gcc=-ffreestanding
364 348 # Disabling MMX also disables 3DNow, disabling SSE also disables all later
365 349 # additions to SSE (SSE2, AVX ,etc.)
366 350 NO_SIMD= -_gcc=-mno-mmx -_gcc=-mno-sse
367 351 i386_STAND_FLAGS= -_gcc=-ffreestanding $(NO_SIMD)
368 352 amd64_STAND_FLAGS= -xmodel=kernel $(NO_SIMD)
369 353
370 354 SAVEARGS= -Wu,-save_args
371 355 amd64_STAND_FLAGS += $(SAVEARGS)
372 356
373 357 STAND_FLAGS_32 = $($(MACH)_STAND_FLAGS)
374 358 STAND_FLAGS_64 = $($(MACH64)_STAND_FLAGS)
375 359
376 360 #
377 361 # disable the incremental linker
378 362 ILDOFF= -xildoff
379 363 #
380 364 XDEPEND= -xdepend
381 365 XFFLAG= -xF=%all
382 366 XESS= -xs
383 367 XSTRCONST= -xstrconst
384 368
385 369 #
386 370 # turn warnings into errors (C)
387 371 CERRWARN = -errtags=yes -errwarn=%all
388 372 CERRWARN += -erroff=E_EMPTY_TRANSLATION_UNIT
389 373 CERRWARN += -erroff=E_STATEMENT_NOT_REACHED
390 374
391 375 CERRWARN += -_gcc=-Wno-missing-braces
392 376 CERRWARN += -_gcc=-Wno-sign-compare
393 377 CERRWARN += -_gcc=-Wno-unknown-pragmas
394 378 CERRWARN += -_gcc=-Wno-unused-parameter
395 379 CERRWARN += -_gcc=-Wno-missing-field-initializers
396 380
397 381 # Unfortunately, this option can misfire very easily and unfixably.
398 382 CERRWARN += -_gcc=-Wno-array-bounds
399 383
400 384 # DEBUG v. -nd make for frequent unused variables, empty conditions, etc. in
401 385 # -nd builds
402 386 $(RELEASE_BUILD)CERRWARN += -_gcc=-Wno-unused
403 387 $(RELEASE_BUILD)CERRWARN += -_gcc=-Wno-empty-body
404 388
405 389 #
406 390 # turn warnings into errors (C++)
407 391 CCERRWARN= -xwe
408 392
409 393 # C99 mode
410 394 C99_ENABLE= -xc99=%all
411 395 C99_DISABLE= -xc99=%none
412 396 C99MODE= $(C99_DISABLE)
413 397 C99LMODE= $(C99MODE:-xc99%=-Xc99%)
414 398
415 399 # In most places, assignments to these macros should be appended with +=
416 400 # (CPPFLAGS.master allows values to be prepended to CPPFLAGS).
417 401 sparc_CFLAGS= $(sparc_XARCH) $(CCSTATICSYM)
418 402 sparcv9_CFLAGS= $(sparcv9_XARCH) -dalign $(CCVERBOSE) $(V9ABIWARN) $(CCREGSYM) \
419 403 $(CCSTATICSYM)
420 404 i386_CFLAGS= $(i386_XARCH)
421 405 amd64_CFLAGS= $(amd64_XARCH)
422 406
423 407 sparc_ASFLAGS= $(sparc_AS_XARCH)
424 408 sparcv9_ASFLAGS=$(sparcv9_AS_XARCH)
425 409 i386_ASFLAGS= $(i386_AS_XARCH)
426 410 amd64_ASFLAGS= $(amd64_AS_XARCH)
427 411
428 412 #
429 413 sparc_COPTFLAG= -xO3
430 414 sparcv9_COPTFLAG= -xO3
431 415 i386_COPTFLAG= -O
432 416 amd64_COPTFLAG= -xO3
433 417
434 418 COPTFLAG= $($(MACH)_COPTFLAG)
435 419 COPTFLAG64= $($(MACH64)_COPTFLAG)
436 420
437 421 # When -g is used, the compiler globalizes static objects
438 422 # (gives them a unique prefix). Disable that.
439 423 CNOGLOBAL= -W0,-noglobal
440 424
441 425 # Direct the Sun Studio compiler to use a static globalization prefix based on the
442 426 # name of the module rather than something unique. Otherwise, objects
443 427 # will not build deterministically, as subsequent compilations of identical
444 428 # source will yeild objects that always look different.
445 429 #
446 430 # In the same spirit, this will also remove the date from the N_OPT stab.
447 431 CGLOBALSTATIC= -W0,-xglobalstatic
448 432
449 433 # Sometimes we want all symbols and types in debugging information even
450 434 # if they aren't used.
451 435 CALLSYMS= -W0,-xdbggen=no%usedonly
452 436
453 437 #
454 438 # Default debug format for Sun Studio 11 is dwarf, so force it to
455 439 # generate stabs.
456 440 #
457 441 DEBUGFORMAT= -xdebugformat=stabs
458 442
459 443 #
460 444 # Flags used to build in debug mode for ctf generation. Bugs in the Devpro
461 445 # compilers currently prevent us from building with cc-emitted DWARF.
462 446 #
463 447 CTF_FLAGS_sparc = -g -Wc,-Qiselect-T1 $(C99MODE) $(CNOGLOBAL) $(CDWARFSTR)
464 448 CTF_FLAGS_i386 = -g $(C99MODE) $(CNOGLOBAL) $(CDWARFSTR)
465 449
466 450 CTF_FLAGS_sparcv9 = $(CTF_FLAGS_sparc)
467 451 CTF_FLAGS_amd64 = $(CTF_FLAGS_i386)
468 452
469 453 # Sun Studio produces broken userland code when saving arguments.
470 454 $(__GNUC)CTF_FLAGS_amd64 += $(SAVEARGS)
471 455
472 456 CTF_FLAGS_32 = $(CTF_FLAGS_$(MACH)) $(DEBUGFORMAT)
473 457 CTF_FLAGS_64 = $(CTF_FLAGS_$(MACH64)) $(DEBUGFORMAT)
474 458 CTF_FLAGS = $(CTF_FLAGS_32)
475 459
476 460 #
477 461 # Flags used with genoffsets
478 462 #
479 463 GOFLAGS = -_noecho \
480 464 $(CALLSYMS) \
481 465 $(CDWARFSTR)
482 466
483 467 OFFSETS_CREATE = $(GENOFFSETS) -s $(CTFSTABS) -r $(CTFCONVERT) \
484 468 $(CC) $(GOFLAGS) $(CFLAGS) $(CPPFLAGS)
485 469
486 470 OFFSETS_CREATE64 = $(GENOFFSETS) -s $(CTFSTABS) -r $(CTFCONVERT) \
487 471 $(CC) $(GOFLAGS) $(CFLAGS64) $(CPPFLAGS)
488 472
489 473 #
490 474 # tradeoff time for space (smaller is better)
491 475 #
492 476 sparc_SPACEFLAG = -xspace -W0,-Lt
493 477 sparcv9_SPACEFLAG = -xspace -W0,-Lt
494 478 i386_SPACEFLAG = -xspace
495 479 amd64_SPACEFLAG =
496 480
497 481 SPACEFLAG = $($(MACH)_SPACEFLAG)
498 482 SPACEFLAG64 = $($(MACH64)_SPACEFLAG)
499 483
500 484 #
501 485 # The Sun Studio 11 compiler has changed the behaviour of integer
502 486 # wrap arounds and so a flag is needed to use the legacy behaviour
503 487 # (without this flag panics/hangs could be exposed within the source).
504 488 #
505 489 sparc_IROPTFLAG = -W2,-xwrap_int
506 490 sparcv9_IROPTFLAG = -W2,-xwrap_int
507 491 i386_IROPTFLAG =
508 492 amd64_IROPTFLAG =
509 493
510 494 IROPTFLAG = $($(MACH)_IROPTFLAG)
511 495 IROPTFLAG64 = $($(MACH64)_IROPTFLAG)
512 496
513 497 sparc_XREGSFLAG = -xregs=no%appl
514 498 sparcv9_XREGSFLAG = -xregs=no%appl
515 499 i386_XREGSFLAG =
516 500 amd64_XREGSFLAG =
517 501
518 502 XREGSFLAG = $($(MACH)_XREGSFLAG)
519 503 XREGSFLAG64 = $($(MACH64)_XREGSFLAG)
520 504
521 505 # dmake SOURCEDEBUG=yes ... enables source-level debugging information, and
522 506 # avoids stripping it.
523 507 SOURCEDEBUG = $(POUND_SIGN)
524 508 SRCDBGBLD = $(SOURCEDEBUG:yes=)
525 509
526 510 #
527 511 # These variables are intended ONLY for use by developers to safely pass extra
528 512 # flags to the compilers without unintentionally overriding Makefile-set
529 513 # flags. They should NEVER be set to any value in a Makefile.
530 514 #
531 515 # They come last in the associated FLAGS variable such that they can
532 516 # explicitly override things if necessary, there are gaps in this, but it's
533 517 # the best we can manage.
534 518 #
535 519 CUSERFLAGS =
536 520 CUSERFLAGS64 = $(CUSERFLAGS)
537 521 CCUSERFLAGS =
538 522 CCUSERFLAGS64 = $(CCUSERFLAGS)
539 523
540 524 CSOURCEDEBUGFLAGS =
541 525 CCSOURCEDEBUGFLAGS =
542 526 $(SRCDBGBLD)CSOURCEDEBUGFLAGS = -g -xs
543 527 $(SRCDBGBLD)CCSOURCEDEBUGFLAGS = -g -xs
544 528
545 529 CFLAGS= $(COPTFLAG) $($(MACH)_CFLAGS) $(SPACEFLAG) $(CCMODE) \
546 530 $(ILDOFF) $(CERRWARN) $(C99MODE) $(CCUNBOUND) $(IROPTFLAG) \
547 531 $(CGLOBALSTATIC) $(CCNOAUTOINLINE) $(CSOURCEDEBUGFLAGS) \
548 532 $(CUSERFLAGS)
549 533 CFLAGS64= $(COPTFLAG64) $($(MACH64)_CFLAGS) $(SPACEFLAG64) $(CCMODE64) \
550 534 $(ILDOFF) $(CERRWARN) $(C99MODE) $(CCUNBOUND) $(IROPTFLAG64) \
551 535 $(CGLOBALSTATIC) $(CCNOAUTOINLINE) $(CSOURCEDEBUGFLAGS) \
552 536 $(CUSERFLAGS64)
553 537 #
554 538 # Flags that are used to build parts of the code that are subsequently
555 539 # run on the build machine (also known as the NATIVE_BUILD).
556 540 #
557 541 NATIVE_CFLAGS= $(COPTFLAG) $($(NATIVE_MACH)_CFLAGS) $(CCMODE) \
558 542 $(ILDOFF) $(CERRWARN) $(C99MODE) $($(NATIVE_MACH)_CCUNBOUND) \
559 543 $(IROPTFLAG) $(CGLOBALSTATIC) $(CCNOAUTOINLINE) \
560 544 $(CSOURCEDEBUGFLAGS) $(CUSERFLAGS)
561 545
562 546 DTEXTDOM=-DTEXT_DOMAIN=\"$(TEXT_DOMAIN)\" # For messaging.
563 547 DTS_ERRNO=-D_TS_ERRNO
564 548 CPPFLAGS.master=$(DTEXTDOM) $(DTS_ERRNO) \
565 549 $(ENVCPPFLAGS1) $(ENVCPPFLAGS2) $(ENVCPPFLAGS3) $(ENVCPPFLAGS4)
566 550 CPPFLAGS.native=$(ENVCPPFLAGS1) $(ENVCPPFLAGS2) $(ENVCPPFLAGS3) $(ENVCPPFLAGS4)
567 551 CPPFLAGS= $(CPPFLAGS.master)
568 552 AS_CPPFLAGS= $(CPPFLAGS.master)
569 553 JAVAFLAGS= -deprecation
570 554
571 555 #
572 556 # For source message catalogue
573 557 #
574 558 .SUFFIXES: $(SUFFIXES) .i .po
575 559 MSGROOT= $(ROOT)/catalog
576 560 MSGDOMAIN= $(MSGROOT)/$(TEXT_DOMAIN)
577 561 MSGDOMAINPOFILE = $(MSGDOMAIN)/$(POFILE)
578 562 DCMSGDOMAIN= $(MSGROOT)/LC_TIME/$(TEXT_DOMAIN)
579 563 DCMSGDOMAINPOFILE = $(DCMSGDOMAIN)/$(DCFILE:.dc=.po)
580 564
581 565 CLOBBERFILES += $(POFILE) $(POFILES)
582 566 COMPILE.cpp= $(CC) -E -C $(CFLAGS) $(CPPFLAGS)
583 567 XGETTEXT= /usr/bin/xgettext
584 568 XGETFLAGS= -c TRANSLATION_NOTE
585 569 GNUXGETTEXT= /usr/gnu/bin/xgettext
586 570 GNUXGETFLAGS= --add-comments=TRANSLATION_NOTE --keyword=_ \
587 571 --strict --no-location --omit-header
588 572 BUILD.po= $(XGETTEXT) $(XGETFLAGS) -d $(<F) $<.i ;\
589 573 $(RM) $@ ;\
590 574 $(SED) "/^domain/d" < $(<F).po > $@ ;\
591 575 $(RM) $(<F).po $<.i
592 576
593 577 #
594 578 # This is overwritten by local Makefile when PROG is a list.
595 579 #
596 580 POFILE= $(PROG).po
597 581
598 582 sparc_CCFLAGS= -cg92 -compat=4 \
599 583 -Qoption ccfe -messages=no%anachronism \
600 584 $(CCERRWARN)
601 585 sparcv9_CCFLAGS= $(sparcv9_XARCH) -dalign -compat=5 \
602 586 -Qoption ccfe -messages=no%anachronism \
603 587 -Qoption ccfe -features=no%conststrings \
604 588 $(CCCREGSYM) \
605 589 $(CCERRWARN)
606 590 i386_CCFLAGS= -compat=4 \
607 591 -Qoption ccfe -messages=no%anachronism \
608 592 -Qoption ccfe -features=no%conststrings \
609 593 $(CCERRWARN)
610 594 amd64_CCFLAGS= $(amd64_XARCH) -compat=5 \
611 595 -Qoption ccfe -messages=no%anachronism \
612 596 -Qoption ccfe -features=no%conststrings \
613 597 $(CCERRWARN)
614 598
615 599 sparc_CCOPTFLAG= -O
616 600 sparcv9_CCOPTFLAG= -O
617 601 i386_CCOPTFLAG= -O
618 602 amd64_CCOPTFLAG= -O
619 603
620 604 CCOPTFLAG= $($(MACH)_CCOPTFLAG)
621 605 CCOPTFLAG64= $($(MACH64)_CCOPTFLAG)
622 606 CCFLAGS= $(CCOPTFLAG) $($(MACH)_CCFLAGS) $(CCSOURCEDEBUGFLAGS) \
623 607 $(CCUSERFLAGS)
624 608 CCFLAGS64= $(CCOPTFLAG64) $($(MACH64)_CCFLAGS) $(CCSOURCEDEBUGFLAGS) \
625 609 $(CCUSERFLAGS64)
626 610
627 611 #
628 612 #
629 613 #
630 614 ELFWRAP_FLAGS =
631 615 ELFWRAP_FLAGS64 = -64
632 616
633 617 #
634 618 # Various mapfiles that are used throughout the build, and delivered to
635 619 # /usr/lib/ld.
636 620 #
637 621 MAPFILE.NED_i386 = $(SRC)/common/mapfiles/common/map.noexdata
638 622 MAPFILE.NED_sparc =
639 623 MAPFILE.NED = $(MAPFILE.NED_$(MACH))
640 624 MAPFILE.PGA = $(SRC)/common/mapfiles/common/map.pagealign
641 625 MAPFILE.NES = $(SRC)/common/mapfiles/common/map.noexstk
642 626 MAPFILE.FLT = $(SRC)/common/mapfiles/common/map.filter
643 627 MAPFILE.LEX = $(SRC)/common/mapfiles/common/map.lex.yy
644 628
645 629 #
646 630 # Generated mapfiles that are compiler specific, and used throughout the
647 631 # build. These mapfiles are not delivered in /usr/lib/ld.
648 632 #
649 633 MAPFILE.NGB_sparc= $(SRC)/common/mapfiles/gen/sparc_cc_map.noexeglobs
650 634 $(__GNUC64)MAPFILE.NGB_sparc= \
651 635 $(SRC)/common/mapfiles/gen/sparc_gcc_map.noexeglobs
652 636 MAPFILE.NGB_sparcv9= $(SRC)/common/mapfiles/gen/sparcv9_cc_map.noexeglobs
653 637 $(__GNUC64)MAPFILE.NGB_sparcv9= \
654 638 $(SRC)/common/mapfiles/gen/sparcv9_gcc_map.noexeglobs
655 639 MAPFILE.NGB_i386= $(SRC)/common/mapfiles/gen/i386_cc_map.noexeglobs
656 640 $(__GNUC64)MAPFILE.NGB_i386= \
657 641 $(SRC)/common/mapfiles/gen/i386_gcc_map.noexeglobs
658 642 MAPFILE.NGB_amd64= $(SRC)/common/mapfiles/gen/amd64_cc_map.noexeglobs
659 643 $(__GNUC64)MAPFILE.NGB_amd64= \
660 644 $(SRC)/common/mapfiles/gen/amd64_gcc_map.noexeglobs
661 645 MAPFILE.NGB = $(MAPFILE.NGB_$(MACH))
662 646
663 647 #
664 648 # A generic interface mapfile name, used by various dynamic objects to define
665 649 # the interfaces and interposers the object must export.
666 650 #
667 651 MAPFILE.INT = mapfile-intf
668 652
669 653 #
670 654 # LDLIBS32 can be set in the environment to override the following assignment.
671 655 # LDLIBS64 can be set to override the assignment made in Makefile.master.64.
672 656 # These environment settings make sure that no libraries are searched outside
673 657 # of the local workspace proto area:
674 658 # LDLIBS32=-YP,$ROOT/lib:$ROOT/usr/lib
675 659 # LDLIBS64=-YP,$ROOT/lib/$MACH64:$ROOT/usr/lib/$MACH64
676 660 #
677 661 LDLIBS32 = $(ENVLDLIBS1) $(ENVLDLIBS2) $(ENVLDLIBS3)
678 662 LDLIBS.cmd = $(LDLIBS32)
679 663 LDLIBS.lib = $(LDLIBS32)
680 664 #
681 665 # Define compilation macros.
682 666 #
683 667 COMPILE.c= $(CC) $(CFLAGS) $(CPPFLAGS) -c
684 668 COMPILE64.c= $(CC) $(CFLAGS64) $(CPPFLAGS) -c
685 669 COMPILE.cc= $(CCC) $(CCFLAGS) $(CPPFLAGS) -c
686 670 COMPILE64.cc= $(CCC) $(CCFLAGS64) $(CPPFLAGS) -c
687 671 COMPILE.s= $(AS) $(ASFLAGS) $(AS_CPPFLAGS)
688 672 COMPILE64.s= $(AS) $(ASFLAGS) $($(MACH64)_AS_XARCH) $(AS_CPPFLAGS)
689 673 COMPILE.d= $(DTRACE) -G -32
690 674 COMPILE64.d= $(DTRACE) -G -64
691 675 COMPILE.b= $(ELFWRAP) $(ELFWRAP_FLAGS$(CLASS))
692 676 COMPILE64.b= $(ELFWRAP) $(ELFWRAP_FLAGS$(CLASS))
693 677
694 678 CLASSPATH= .
695 679 COMPILE.java= $(JAVAC) $(JAVAFLAGS) -classpath $(CLASSPATH)
696 680
697 681 #
698 682 # Link time macros
699 683 #
700 684 CCNEEDED = -lC
701 685 CCEXTNEEDED = -lCrun -lCstd
702 686 $(__GNUC)CCNEEDED = -L$(GCCLIBDIR) -R$(GCCLIBDIR) -lstdc++ -lgcc_s
703 687 $(__GNUC)CCEXTNEEDED = $(CCNEEDED)
704 688
705 689 LINK.c= $(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS)
706 690 LINK64.c= $(CC) $(CFLAGS64) $(CPPFLAGS) $(LDFLAGS)
707 691 NORUNPATH= -norunpath -nolib
708 692 LINK.cc= $(CCC) $(CCFLAGS) $(CPPFLAGS) $(NORUNPATH) \
709 693 $(LDFLAGS) $(CCNEEDED)
710 694 LINK64.cc= $(CCC) $(CCFLAGS64) $(CPPFLAGS) $(NORUNPATH) \
711 695 $(LDFLAGS) $(CCNEEDED)
712 696
713 697 #
714 698 # lint macros
715 699 #
716 700 # Note that the undefine of __PRAGMA_REDEFINE_EXTNAME can be removed once
717 701 # ON is built with a version of lint that has the fix for 4484186.
718 702 #
719 703 ALWAYS_LINT_DEFS = -errtags=yes -s
720 704 ALWAYS_LINT_DEFS += -erroff=E_PTRDIFF_OVERFLOW
721 705 ALWAYS_LINT_DEFS += -erroff=E_ASSIGN_NARROW_CONV
722 706 ALWAYS_LINT_DEFS += -U__PRAGMA_REDEFINE_EXTNAME
723 707 ALWAYS_LINT_DEFS += $(C99LMODE)
724 708 ALWAYS_LINT_DEFS += -errsecurity=$(SECLEVEL)
725 709 ALWAYS_LINT_DEFS += -erroff=E_SEC_CREAT_WITHOUT_EXCL
726 710 ALWAYS_LINT_DEFS += -erroff=E_SEC_FORBIDDEN_WARN_CREAT
727 711 # XX64 -- really only needed for amd64 lint
728 712 ALWAYS_LINT_DEFS += -erroff=E_ASSIGN_INT_TO_SMALL_INT
729 713 ALWAYS_LINT_DEFS += -erroff=E_CAST_INT_CONST_TO_SMALL_INT
730 714 ALWAYS_LINT_DEFS += -erroff=E_CAST_INT_TO_SMALL_INT
731 715 ALWAYS_LINT_DEFS += -erroff=E_CAST_TO_PTR_FROM_INT
732 716 ALWAYS_LINT_DEFS += -erroff=E_COMP_INT_WITH_LARGE_INT
733 717 ALWAYS_LINT_DEFS += -erroff=E_INTEGRAL_CONST_EXP_EXPECTED
734 718 ALWAYS_LINT_DEFS += -erroff=E_PASS_INT_TO_SMALL_INT
735 719 ALWAYS_LINT_DEFS += -erroff=E_PTR_CONV_LOSES_BITS
736 720
737 721 # This forces lint to pick up note.h and sys/note.h from Devpro rather than
738 722 # from the proto area. The note.h that ON delivers would disable NOTE().
739 723 ONLY_LINT_DEFS = -I$(SPRO_VROOT)/prod/include/lint
740 724
741 725 SECLEVEL= core
742 726 LINT.c= $(LINT) $(ONLY_LINT_DEFS) $(LINTFLAGS) $(CPPFLAGS) \
743 727 $(ALWAYS_LINT_DEFS)
744 728 LINT64.c= $(LINT) $(ONLY_LINT_DEFS) $(LINTFLAGS64) $(CPPFLAGS) \
745 729 $(ALWAYS_LINT_DEFS)
746 730 LINT.s= $(LINT.c)
747 731
748 732 # For some future builds, NATIVE_MACH and MACH might be different.
749 733 # Therefore, NATIVE_MACH needs to be redefined in the
750 734 # environment as `uname -p` to override this macro.
751 735 #
752 736 # For now at least, we cross-compile amd64 on i386 machines.
753 737 NATIVE_MACH= $(MACH:amd64=i386)
754 738
755 739 # Define native compilation macros
756 740 #
757 741
758 742 # Base directory where compilers are loaded.
759 743 # Defined here so it can be overridden by developer.
760 744 #
761 745 SPRO_ROOT= $(BUILD_TOOLS)/SUNWspro
762 746 SPRO_VROOT= $(SPRO_ROOT)/SS12
763 747 GNU_ROOT= $(SFW_ROOT)
764 748
765 749 # Till SS12u1 formally becomes the NV CBE, LINT is hard
766 750 # coded to be picked up from the $SPRO_ROOT/sunstudio12.1/
767 751 # location. Impacted variables are sparc_LINT, sparcv9_LINT,
768 752 # i386_LINT, amd64_LINT.
769 753 # Reset them when SS12u1 is rolled out.
770 754 #
771 755
772 756 # Specify platform compiler versions for languages
773 757 # that we use (currently only c and c++).
774 758 #
775 759 sparc_CC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_cc
776 760 $(__GNUC)sparc_CC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_gcc
777 761 sparc_CCC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_CC
778 762 $(__GNUC)sparc_CCC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_g++
779 763 sparc_CPP= /usr/ccs/lib/cpp
780 764 sparc_AS= /usr/ccs/bin/as -xregsym=no
781 765 sparc_LD= /usr/ccs/bin/ld
782 766 sparc_LINT= $(SPRO_ROOT)/sunstudio12.1/bin/lint
783 767
784 768 sparcv9_CC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_cc
785 769 $(__GNUC64)sparcv9_CC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_gcc
786 770 sparcv9_CCC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_CC
787 771 $(__GNUC64)sparcv9_CCC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_g++
788 772 sparcv9_CPP= /usr/ccs/lib/cpp
789 773 sparcv9_AS= /usr/ccs/bin/as -xregsym=no
790 774 sparcv9_LD= /usr/ccs/bin/ld
791 775 sparcv9_LINT= $(SPRO_ROOT)/sunstudio12.1/bin/lint
792 776
793 777 i386_CC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_cc
794 778 $(__GNUC)i386_CC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_gcc
795 779 i386_CCC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_CC
796 780 $(__GNUC)i386_CCC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_g++
797 781 i386_CPP= /usr/ccs/lib/cpp
798 782 i386_AS= /usr/ccs/bin/as
799 783 $(__GNUC)i386_AS= $(ONBLD_TOOLS)/bin/$(MACH)/aw
800 784 i386_LD= /usr/ccs/bin/ld
801 785 i386_LINT= $(SPRO_ROOT)/sunstudio12.1/bin/lint
802 786
803 787 amd64_CC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_cc
804 788 $(__GNUC64)amd64_CC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_gcc
805 789 amd64_CCC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_CC
806 790 $(__GNUC64)amd64_CCC= $(ONBLD_TOOLS)/bin/$(MACH)/cw -_g++
807 791 amd64_CPP= /usr/ccs/lib/cpp
808 792 amd64_AS= $(ONBLD_TOOLS)/bin/$(MACH)/aw
809 793 amd64_LD= /usr/ccs/bin/ld
810 794 amd64_LINT= $(SPRO_ROOT)/sunstudio12.1/bin/lint
811 795
812 796 NATIVECC= $($(NATIVE_MACH)_CC)
813 797 NATIVECCC= $($(NATIVE_MACH)_CCC)
814 798 NATIVECPP= $($(NATIVE_MACH)_CPP)
815 799 NATIVEAS= $($(NATIVE_MACH)_AS)
816 800 NATIVELD= $($(NATIVE_MACH)_LD)
817 801 NATIVELINT= $($(NATIVE_MACH)_LINT)
818 802
819 803 #
820 804 # Makefile.master.64 overrides these settings
821 805 #
822 806 CC= $(NATIVECC)
823 807 CCC= $(NATIVECCC)
824 808 CPP= $(NATIVECPP)
825 809 AS= $(NATIVEAS)
826 810 LD= $(NATIVELD)
827 811 LINT= $(NATIVELINT)
828 812
829 813 # The real compilers used for this build
830 814 CW_CC_CMD= $(CC) -_compiler
831 815 CW_CCC_CMD= $(CCC) -_compiler
832 816 REAL_CC= $(CW_CC_CMD:sh)
833 817 REAL_CCC= $(CW_CCC_CMD:sh)
834 818
835 819 # Pass -Y flag to cpp (method of which is release-dependent)
836 820 CCYFLAG= -Y I,
837 821
838 822 BDIRECT= -Bdirect
839 823 BDYNAMIC= -Bdynamic
840 824 BLOCAL= -Blocal
841 825 BNODIRECT= -Bnodirect
842 826 BREDUCE= -Breduce
843 827 BSTATIC= -Bstatic
844 828
845 829 ZDEFS= -zdefs
846 830 ZDIRECT= -zdirect
847 831 ZIGNORE= -zignore
848 832 ZINITFIRST= -zinitfirst
849 833 ZINTERPOSE= -zinterpose
850 834 ZLAZYLOAD= -zlazyload
851 835 ZLOADFLTR= -zloadfltr
852 836 ZMULDEFS= -zmuldefs
853 837 ZNODEFAULTLIB= -znodefaultlib
854 838 ZNODEFS= -znodefs
855 839 ZNODELETE= -znodelete
856 840 ZNODLOPEN= -znodlopen
857 841 ZNODUMP= -znodump
858 842 ZNOLAZYLOAD= -znolazyload
859 843 ZNOLDYNSYM= -znoldynsym
860 844 ZNORELOC= -znoreloc
861 845 ZNOVERSION= -znoversion
862 846 ZRECORD= -zrecord
863 847 ZREDLOCSYM= -zredlocsym
864 848 ZTEXT= -ztext
865 849 ZVERBOSE= -zverbose
866 850
867 851 GSHARED= -G
868 852 CCMT= -mt
869 853
870 854 # Handle different PIC models on different ISAs
871 855 # (May be overridden by lower-level Makefiles)
872 856
873 857 sparc_C_PICFLAGS = -K pic
874 858 sparcv9_C_PICFLAGS = -K pic
875 859 i386_C_PICFLAGS = -K pic
876 860 amd64_C_PICFLAGS = -K pic
877 861 C_PICFLAGS = $($(MACH)_C_PICFLAGS)
878 862 C_PICFLAGS64 = $($(MACH64)_C_PICFLAGS)
879 863
880 864 sparc_C_BIGPICFLAGS = -K PIC
881 865 sparcv9_C_BIGPICFLAGS = -K PIC
882 866 i386_C_BIGPICFLAGS = -K PIC
883 867 amd64_C_BIGPICFLAGS = -K PIC
884 868 C_BIGPICFLAGS = $($(MACH)_C_BIGPICFLAGS)
885 869 C_BIGPICFLAGS64 = $($(MACH64)_C_BIGPICFLAGS)
886 870
887 871 # CC requires there to be no space between '-K' and 'pic' or 'PIC'.
888 872 sparc_CC_PICFLAGS = -Kpic
889 873 sparcv9_CC_PICFLAGS = -KPIC
890 874 i386_CC_PICFLAGS = -Kpic
891 875 amd64_CC_PICFLAGS = -Kpic
892 876 CC_PICFLAGS = $($(MACH)_CC_PICFLAGS)
893 877 CC_PICFLAGS64 = $($(MACH64)_CC_PICFLAGS)
894 878
895 879 AS_PICFLAGS= $(C_PICFLAGS)
896 880 AS_BIGPICFLAGS= $(C_BIGPICFLAGS)
897 881
898 882 #
899 883 # Default label for CTF sections
900 884 #
901 885 CTFCVTFLAGS= -i -L VERSION
902 886 $(SRCDBGBLD)CTFCVTFLAGS += -g
903 887
904 888 #
905 889 # Override to pass module-specific flags to ctfmerge. Currently used only by
906 890 # krtld to turn on fuzzy matching, and source-level debugging to inhibit
907 891 # stripping.
908 892 #
909 893 CTFMRGFLAGS=
910 894 $(SRCDBGBLD)CTFMRGFLAGS += -g
911 895
912 896
913 897 CTFCONVERT_O = $(CTFCONVERT) $(CTFCVTFLAGS) $@
914 898
915 899 ELFSIGN_O= $(TRUE)
916 900 ELFSIGN_CRYPTO= $(ELFSIGN_O)
917 901 ELFSIGN_OBJECT= $(ELFSIGN_O)
918 902
919 903 # Rules (normally from make.rules) and macros which are used for post
920 904 # processing files. Normally, these do stripping of the comment section
921 905 # automatically.
922 906 # RELEASE_CM: Should be editted to reflect the release.
923 907 # POST_PROCESS_O: Post-processing for `.o' files.
924 908 # POST_PROCESS_A: Post-processing for `.a' files (currently null).
925 909 # POST_PROCESS_SO: Post-processing for `.so' files.
926 910 # POST_PROCESS: Post-processing for executable files (no suffix).
927 911 # Note that these macros are not completely generalized as they are to be
928 912 # used with the file name to be processed following.
929 913 #
930 914 # It is left as an exercise to Release Engineering to embellish the generation
931 915 # of the release comment string.
932 916 #
933 917 # If this is a standard development build:
934 918 # compress the comment section (mcs -c)
935 919 # add the standard comment (mcs -a $(RELEASE_CM))
936 920 # add the development specific comment (mcs -a $(DEV_CM))
937 921 #
938 922 # If this is an installation build:
939 923 # delete the comment section (mcs -d)
940 924 # add the standard comment (mcs -a $(RELEASE_CM))
941 925 # add the development specific comment (mcs -a $(DEV_CM))
942 926 #
943 927 # If this is an release build:
944 928 # delete the comment section (mcs -d)
945 929 # add the standard comment (mcs -a $(RELEASE_CM))
946 930 #
947 931 # The following list of macros are used in the definition of RELEASE_CM
948 932 # which is used to label all binaries in the build:
949 933 #
950 934 # RELEASE Specific release of the build, eg: 5.2
951 935 # RELEASE_MAJOR Major version number part of $(RELEASE)
952 936 # RELEASE_MINOR Minor version number part of $(RELEASE)
953 937 # VERSION Version of the build (alpha, beta, Generic)
954 938 # PATCHID If this is a patch this value should contain
955 939 # the patchid value (eg: "Generic 100832-01"), otherwise
956 940 # it will be set to $(VERSION)
957 941 # RELEASE_DATE Date of the Release Build
958 942 # PATCH_DATE Date the patch was created, if this is blank it
959 943 # will default to the RELEASE_DATE
960 944 #
961 945 RELEASE_MAJOR= 5
962 946 RELEASE_MINOR= 11
963 947 RELEASE= $(RELEASE_MAJOR).$(RELEASE_MINOR)
964 948 VERSION= SunOS Development
965 949 PATCHID= $(VERSION)
966 950 RELEASE_DATE= release date not set
967 951 PATCH_DATE= $(RELEASE_DATE)
968 952 RELEASE_CM= "@($(POUND_SIGN))SunOS $(RELEASE) $(PATCHID) $(PATCH_DATE)"
969 953 DEV_CM= "@($(POUND_SIGN))SunOS Internal Development: non-nightly build"
970 954
971 955 PROCESS_COMMENT= @?${MCS} -c -a $(RELEASE_CM) -a $(DEV_CM)
972 956 $(STRIP_COMMENTS)PROCESS_COMMENT= @?${MCS} -d -a $(RELEASE_CM) -a $(DEV_CM)
973 957 $(RELEASE_BUILD)PROCESS_COMMENT= @?${MCS} -d -a $(RELEASE_CM)
974 958
975 959 STRIP_STABS= :
976 960 $(RELEASE_BUILD)STRIP_STABS= $(STRIP) -x $@
977 961 $(SRCDBGBLD)STRIP_STABS= :
978 962
979 963 POST_PROCESS_O= $(PROCESS_COMMENT) $@
980 964 POST_PROCESS_A=
981 965 POST_PROCESS_SO= $(PROCESS_COMMENT) $@ ; $(STRIP_STABS) ; \
982 966 $(ELFSIGN_OBJECT)
983 967 POST_PROCESS= $(PROCESS_COMMENT) $@ ; $(STRIP_STABS) ; \
984 968 $(ELFSIGN_OBJECT)
985 969
986 970 #
987 971 # chk4ubin is a tool that inspects a module for a symbol table
988 972 # ELF section size which can trigger an OBP bug on older platforms.
989 973 # This problem affects only specific sun4u bootable modules.
990 974 #
991 975 CHK4UBIN= $(ONBLD_TOOLS)/bin/$(MACH)/chk4ubin
992 976 CHK4UBINFLAGS=
993 977 CHK4UBINARY= $(CHK4UBIN) $(CHK4UBINFLAGS) $@
994 978
995 979 #
996 980 # PKGARCHIVE specifies the default location where packages should be
997 981 # placed if built.
998 982 #
999 983 $(RELEASE_BUILD)PKGARCHIVESUFFIX= -nd
1000 984 PKGARCHIVE=$(SRC)/../../packages/$(MACH)/nightly$(PKGARCHIVESUFFIX)
1001 985
1002 986 #
1003 987 # The repositories will be created with these publisher settings. To
1004 988 # update an image to the resulting repositories, this must match the
1005 989 # publisher name provided to "pkg set-publisher."
1006 990 #
1007 991 PKGPUBLISHER_REDIST= on-nightly
1008 992 PKGPUBLISHER_NONREDIST= on-extra
1009 993
1010 994 # Default build rules which perform comment section post-processing.
1011 995 #
1012 996 .c:
1013 997 $(LINK.c) -o $@ $< $(LDLIBS)
1014 998 $(POST_PROCESS)
1015 999 .c.o:
1016 1000 $(COMPILE.c) $(OUTPUT_OPTION) $< $(CTFCONVERT_HOOK)
1017 1001 $(POST_PROCESS_O)
1018 1002 .c.a:
1019 1003 $(COMPILE.c) -o $% $<
1020 1004 $(PROCESS_COMMENT) $%
1021 1005 $(AR) $(ARFLAGS) $@ $%
1022 1006 $(RM) $%
1023 1007 .s.o:
1024 1008 $(COMPILE.s) -o $@ $<
1025 1009 $(POST_PROCESS_O)
1026 1010 .s.a:
1027 1011 $(COMPILE.s) -o $% $<
1028 1012 $(PROCESS_COMMENT) $%
1029 1013 $(AR) $(ARFLAGS) $@ $%
1030 1014 $(RM) $%
1031 1015 .cc:
1032 1016 $(LINK.cc) -o $@ $< $(LDLIBS)
1033 1017 $(POST_PROCESS)
1034 1018 .cc.o:
1035 1019 $(COMPILE.cc) $(OUTPUT_OPTION) $<
1036 1020 $(POST_PROCESS_O)
1037 1021 .cc.a:
1038 1022 $(COMPILE.cc) -o $% $<
1039 1023 $(AR) $(ARFLAGS) $@ $%
1040 1024 $(PROCESS_COMMENT) $%
1041 1025 $(RM) $%
1042 1026 .y:
1043 1027 $(YACC.y) $<
1044 1028 $(LINK.c) -o $@ y.tab.c $(LDLIBS)
1045 1029 $(POST_PROCESS)
1046 1030 $(RM) y.tab.c
1047 1031 .y.o:
1048 1032 $(YACC.y) $<
1049 1033 $(COMPILE.c) -o $@ y.tab.c $(CTFCONVERT_HOOK)
1050 1034 $(POST_PROCESS_O)
1051 1035 $(RM) y.tab.c
1052 1036 .l:
1053 1037 $(RM) $*.c
1054 1038 $(LEX.l) $< > $*.c
1055 1039 $(LINK.c) -o $@ $*.c -ll $(LDLIBS)
1056 1040 $(POST_PROCESS)
1057 1041 $(RM) $*.c
1058 1042 .l.o:
1059 1043 $(RM) $*.c
1060 1044 $(LEX.l) $< > $*.c
1061 1045 $(COMPILE.c) -o $@ $*.c $(CTFCONVERT_HOOK)
1062 1046 $(POST_PROCESS_O)
1063 1047 $(RM) $*.c
1064 1048
1065 1049 .bin.o:
1066 1050 $(COMPILE.b) -o $@ $<
1067 1051 $(POST_PROCESS_O)
1068 1052
1069 1053 .java.class:
1070 1054 $(COMPILE.java) $<
1071 1055
1072 1056 # Bourne and Korn shell script message catalog build rules.
1073 1057 # We extract all gettext strings with sed(1) (being careful to permit
1074 1058 # multiple gettext strings on the same line), weed out the dups, and
1075 1059 # build the catalogue with awk(1).
1076 1060
1077 1061 .sh.po .ksh.po:
1078 1062 $(SED) -n -e ":a" \
1079 1063 -e "h" \
1080 1064 -e "s/.*gettext *\(\"[^\"]*\"\).*/\1/p" \
1081 1065 -e "x" \
1082 1066 -e "s/\(.*\)gettext *\"[^\"]*\"\(.*\)/\1\2/" \
1083 1067 -e "t a" \
1084 1068 $< | sort -u | awk '{ print "msgid\t" $$0 "\nmsgstr" }' > $@
1085 1069
1086 1070 #
1087 1071 # Python and Perl executable and message catalog build rules.
1088 1072 #
1089 1073 .SUFFIXES: .pl .pm .py .pyc
1090 1074
1091 1075 .pl:
1092 1076 $(RM) $@;
1093 1077 $(SED) -e "s@TEXT_DOMAIN@\"$(TEXT_DOMAIN)\"@" $< > $@;
1094 1078 $(CHMOD) +x $@
1095 1079
1096 1080 .py:
1097 1081 $(RM) $@; $(CAT) $< > $@; $(CHMOD) +x $@
1098 1082
1099 1083 .py.pyc:
1100 1084 $(RM) $@
1101 1085 $(PYTHON) -mpy_compile $<
1102 1086 @[ $(<)c = $@ ] || $(MV) $(<)c $@
1103 1087
1104 1088 .py.po:
1105 1089 $(GNUXGETTEXT) $(GNUXGETFLAGS) -d $(<F:%.py=%) $< ;
1106 1090
1107 1091 .pl.po .pm.po:
1108 1092 $(XGETTEXT) $(XGETFLAGS) -d $(<F) $< ;
1109 1093 $(RM) $@ ;
1110 1094 $(SED) "/^domain/d" < $(<F).po > $@ ;
1111 1095 $(RM) $(<F).po
1112 1096
1113 1097 #
1114 1098 # When using xgettext, we want messages to go to the default domain,
1115 1099 # rather than the specified one. This special version of the
1116 1100 # COMPILE.cpp macro effectively prevents expansion of TEXT_DOMAIN,
1117 1101 # causing xgettext to put all messages into the default domain.
1118 1102 #
1119 1103 CPPFORPO=$(COMPILE.cpp:\"$(TEXT_DOMAIN)\"=TEXT_DOMAIN)
1120 1104
1121 1105 .c.i:
1122 1106 $(CPPFORPO) $< > $@
1123 1107
1124 1108 .h.i:
1125 1109 $(CPPFORPO) $< > $@
1126 1110
1127 1111 .y.i:
1128 1112 $(YACC) -d $<
1129 1113 $(CPPFORPO) y.tab.c > $@
1130 1114 $(RM) y.tab.c
1131 1115
1132 1116 .l.i:
1133 1117 $(LEX) $<
1134 1118 $(CPPFORPO) lex.yy.c > $@
1135 1119 $(RM) lex.yy.c
1136 1120
1137 1121 .c.po:
1138 1122 $(CPPFORPO) $< > $<.i
1139 1123 $(BUILD.po)
1140 1124
1141 1125 .y.po:
1142 1126 $(YACC) -d $<
1143 1127 $(CPPFORPO) y.tab.c > $<.i
1144 1128 $(BUILD.po)
1145 1129 $(RM) y.tab.c
1146 1130
1147 1131 .l.po:
1148 1132 $(LEX) $<
1149 1133 $(CPPFORPO) lex.yy.c > $<.i
1150 1134 $(BUILD.po)
1151 1135 $(RM) lex.yy.c
1152 1136
1153 1137 #
1154 1138 # Rules to perform stylistic checks
1155 1139 #
1156 1140 .SUFFIXES: .x .xml .check .xmlchk
1157 1141
1158 1142 .h.check:
1159 1143 $(DOT_H_CHECK)
1160 1144
1161 1145 .x.check:
1162 1146 $(DOT_X_CHECK)
1163 1147
1164 1148 .xml.xmlchk:
1165 1149 $(MANIFEST_CHECK)
1166 1150
1167 1151 #
1168 1152 # Include rules to render automated sccs get rules "safe".
1169 1153 #
1170 1154 include $(SRC)/Makefile.noget
↓ open down ↓ |
925 lines elided |
↑ open up ↑ |
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX