make/linux/makefiles/buildtree.make

Tue, 08 Feb 2011 17:20:45 -0500

author
kamg
date
Tue, 08 Feb 2011 17:20:45 -0500
changeset 2515
d8a72fbc4be7
parent 2508
b92c45f2bc75
child 3150
da0999c4b733
permissions
-rw-r--r--

7003401: Implement VM error-reporting functionality on erroneous termination
Summary: Add support for distribution-specific error reporting
Reviewed-by: coleenp, phh, jcoomes, ohair

duke@435 1 #
kamg@2515 2 # Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved.
duke@435 3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@435 4 #
duke@435 5 # This code is free software; you can redistribute it and/or modify it
duke@435 6 # under the terms of the GNU General Public License version 2 only, as
duke@435 7 # published by the Free Software Foundation.
duke@435 8 #
duke@435 9 # This code is distributed in the hope that it will be useful, but WITHOUT
duke@435 10 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@435 11 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@435 12 # version 2 for more details (a copy is included in the LICENSE file that
duke@435 13 # accompanied this code).
duke@435 14 #
duke@435 15 # You should have received a copy of the GNU General Public License version
duke@435 16 # 2 along with this work; if not, write to the Free Software Foundation,
duke@435 17 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@435 18 #
trims@1907 19 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
trims@1907 20 # or visit www.oracle.com if you need additional information or have any
trims@1907 21 # questions.
duke@435 22 #
duke@435 23 #
duke@435 24
duke@435 25 # Usage:
duke@435 26 #
bobv@2508 27 # $(MAKE) -f buildtree.make SRCARCH=srcarch BUILDARCH=buildarch LIBARCH=libarch
duke@435 28 # GAMMADIR=dir OS_FAMILY=os VARIANT=variant
duke@435 29 #
duke@435 30 # The macros ARCH, GAMMADIR, OS_FAMILY and VARIANT must be defined in the
duke@435 31 # environment or on the command-line:
duke@435 32 #
duke@435 33 # ARCH - sparc, i486, ... HotSpot cpu and os_cpu source directory
duke@435 34 # BUILDARCH - build directory
duke@435 35 # LIBARCH - the corresponding directory in JDK/JRE
duke@435 36 # GAMMADIR - top of workspace
duke@435 37 # OS_FAMILY - operating system
duke@435 38 # VARIANT - core, compiler1, compiler2, or tiered
duke@435 39 # HOTSPOT_RELEASE_VERSION - <major>.<minor>-b<nn> (11.0-b07)
ohair@2319 40 # HOTSPOT_BUILD_VERSION - internal, internal-$(USER_RELEASE_SUFFIX) or empty
duke@435 41 # JRE_RELEASE_VERSION - <major>.<minor>.<micro> (1.7.0)
duke@435 42 #
duke@435 43 # Builds the directory trees with makefiles plus some convenience files in
duke@435 44 # each directory:
duke@435 45 #
duke@435 46 # Makefile - for "make foo"
duke@435 47 # flags.make - with macro settings
duke@435 48 # vm.make - to support making "$(MAKE) -v vm.make" in makefiles
duke@435 49 # adlc.make -
duke@435 50 # jvmti.make - generate JVMTI bindings from the spec (JSR-163)
duke@435 51 # sa.make - generate SA jar file and natives
duke@435 52 # env.[ck]sh - environment settings
duke@435 53 # test_gamma - script to run the Queens program
duke@435 54 #
duke@435 55 # The makefiles are split this way so that "make foo" will run faster by not
duke@435 56 # having to read the dependency files for the vm.
duke@435 57
duke@435 58 include $(GAMMADIR)/make/scm.make
kamg@2515 59 include $(GAMMADIR)/make/altsrc.make
bobv@2508 60
duke@435 61
duke@435 62 # 'gmake MAKE_VERBOSE=y' or 'gmake QUIETLY=' gives all the gory details.
duke@435 63 QUIETLY$(MAKE_VERBOSE) = @
duke@435 64
duke@435 65 # For now, until the compiler is less wobbly:
duke@435 66 TESTFLAGS = -Xbatch -showversion
duke@435 67
never@1445 68 ifeq ($(ZERO_BUILD), true)
never@1445 69 PLATFORM_FILE = $(shell dirname $(shell dirname $(shell pwd)))/platform_zero
dcubed@485 70 else
never@1445 71 ifdef USE_SUNCC
never@1445 72 PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH).suncc
never@1445 73 else
never@1445 74 PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH)
never@1445 75 endif
never@1445 76 endif
never@1445 77
never@1445 78 # Allow overriding of the arch part of the directory but default
never@1445 79 # to BUILDARCH if nothing is specified
never@1445 80 ifeq ($(VARIANTARCH),)
never@1445 81 VARIANTARCH=$(BUILDARCH)
dcubed@485 82 endif
duke@435 83
duke@435 84 ifdef FORCE_TIERED
duke@435 85 ifeq ($(VARIANT),tiered)
never@1445 86 PLATFORM_DIR = $(OS_FAMILY)_$(VARIANTARCH)_compiler2
duke@435 87 else
never@1445 88 PLATFORM_DIR = $(OS_FAMILY)_$(VARIANTARCH)_$(VARIANT)
duke@435 89 endif
duke@435 90 else
never@1445 91 PLATFORM_DIR = $(OS_FAMILY)_$(VARIANTARCH)_$(VARIANT)
duke@435 92 endif
duke@435 93
duke@435 94 #
duke@435 95 # We do two levels of exclusion in the shared directory.
duke@435 96 # TOPLEVEL excludes are pruned, they are not recursively searched,
duke@435 97 # but lower level directories can be named without fear of collision.
duke@435 98 # ALWAYS excludes are excluded at any level in the directory tree.
duke@435 99 #
duke@435 100
duke@435 101 ALWAYS_EXCLUDE_DIRS = $(SCM_DIRS)
duke@435 102
duke@435 103 ifeq ($(VARIANT),tiered)
duke@435 104 TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name agent
duke@435 105 else
duke@435 106 ifeq ($(VARIANT),compiler2)
duke@435 107 TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name c1 -o -name agent
duke@435 108 else
duke@435 109 # compiler1 and core use the same exclude list
duke@435 110 TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name opto -o -name libadt -o -name agent
duke@435 111 endif
duke@435 112 endif
duke@435 113
duke@435 114 # Get things from the platform file.
duke@435 115 COMPILER = $(shell sed -n 's/^compiler[ ]*=[ ]*//p' $(PLATFORM_FILE))
duke@435 116
duke@435 117 SIMPLE_DIRS = \
stefank@2314 118 $(PLATFORM_DIR)/generated/dependencies \
duke@435 119 $(PLATFORM_DIR)/generated/adfiles \
duke@435 120 $(PLATFORM_DIR)/generated/jvmtifiles
duke@435 121
duke@435 122 TARGETS = debug fastdebug jvmg optimized product profiled
duke@435 123 SUBMAKE_DIRS = $(addprefix $(PLATFORM_DIR)/,$(TARGETS))
duke@435 124
duke@435 125 # For dependencies and recursive makes.
kamg@526 126 BUILDTREE_MAKE = $(GAMMADIR)/make/$(OS_FAMILY)/makefiles/buildtree.make
duke@435 127
duke@435 128 BUILDTREE_TARGETS = Makefile flags.make flags_vm.make vm.make adlc.make jvmti.make sa.make \
sla@2369 129 env.sh env.csh jdkpath.sh .dbxrc test_gamma
duke@435 130
duke@435 131 BUILDTREE_VARS = GAMMADIR=$(GAMMADIR) OS_FAMILY=$(OS_FAMILY) \
bobv@2508 132 SRCARCH=$(SRCARCH) BUILDARCH=$(BUILDARCH) LIBARCH=$(LIBARCH) VARIANT=$(VARIANT)
duke@435 133
duke@435 134 # Define variables to be set in flags.make.
duke@435 135 # Default values are set in make/defs.make.
duke@435 136 ifeq ($(HOTSPOT_BUILD_VERSION),)
duke@435 137 HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION)
duke@435 138 else
duke@435 139 HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION)-$(HOTSPOT_BUILD_VERSION)
duke@435 140 endif
duke@435 141 # Set BUILD_USER from system-dependent hints: $LOGNAME, $(whoami)
duke@435 142 ifndef HOTSPOT_BUILD_USER
duke@435 143 HOTSPOT_BUILD_USER := $(shell echo $$LOGNAME)
duke@435 144 endif
duke@435 145 ifndef HOTSPOT_BUILD_USER
duke@435 146 HOTSPOT_BUILD_USER := $(shell whoami)
duke@435 147 endif
kamg@526 148 # Define HOTSPOT_VM_DISTRO based on settings in make/openjdk_distro
kamg@526 149 # or make/hotspot_distro.
duke@435 150 ifndef HOTSPOT_VM_DISTRO
kamg@2515 151 ifeq ($(call if-has-altsrc,$(HS_COMMON_SRC)/,true,false),true)
kamg@526 152 include $(GAMMADIR)/make/hotspot_distro
duke@435 153 else
kamg@526 154 include $(GAMMADIR)/make/openjdk_distro
duke@435 155 endif
duke@435 156 endif
duke@435 157
duke@435 158 BUILDTREE_VARS += HOTSPOT_RELEASE_VERSION=$(HS_BUILD_VER) HOTSPOT_BUILD_VERSION= JRE_RELEASE_VERSION=$(JRE_RELEASE_VERSION)
duke@435 159
duke@435 160 BUILDTREE = \
duke@435 161 $(MAKE) -f $(BUILDTREE_MAKE) $(BUILDTREE_TARGETS) $(BUILDTREE_VARS)
duke@435 162
duke@435 163 BUILDTREE_COMMENT = echo "\# Generated by $(BUILDTREE_MAKE)"
duke@435 164
duke@435 165 all: $(SUBMAKE_DIRS)
duke@435 166
duke@435 167 # Run make in each subdirectory recursively.
duke@435 168 $(SUBMAKE_DIRS): $(SIMPLE_DIRS) FORCE
duke@435 169 $(QUIETLY) [ -d $@ ] || { mkdir -p $@; }
duke@435 170 $(QUIETLY) cd $@ && $(BUILDTREE) TARGET=$(@F)
duke@435 171 $(QUIETLY) touch $@
duke@435 172
duke@435 173 $(SIMPLE_DIRS):
duke@435 174 $(QUIETLY) mkdir -p $@
duke@435 175
kamg@2515 176 # Convenience macro which takes a source relative path, applies $(1) to the
kamg@2515 177 # absolute path, and then replaces $(GAMMADIR) in the result with a
kamg@2515 178 # literal "$(GAMMADIR)/" suitable for inclusion in a Makefile.
kamg@2515 179 gamma-path=$(subst $(GAMMADIR),\$$(GAMMADIR),$(call $(1),$(HS_COMMON_SRC)/$(2)))
kamg@2515 180
duke@435 181 flags.make: $(BUILDTREE_MAKE) ../shared_dirs.lst
duke@435 182 @echo Creating $@ ...
duke@435 183 $(QUIETLY) ( \
duke@435 184 $(BUILDTREE_COMMENT); \
duke@435 185 echo; \
duke@435 186 echo "Platform_file = $(PLATFORM_FILE)" | sed 's|$(GAMMADIR)|$$(GAMMADIR)|'; \
duke@435 187 sed -n '/=/s/^ */Platform_/p' < $(PLATFORM_FILE); \
duke@435 188 echo; \
duke@435 189 echo "GAMMADIR = $(GAMMADIR)"; \
duke@435 190 echo "SYSDEFS = \$$(Platform_sysdefs)"; \
bobv@2508 191 echo "SRCARCH = $(SRCARCH)"; \
duke@435 192 echo "BUILDARCH = $(BUILDARCH)"; \
duke@435 193 echo "LIBARCH = $(LIBARCH)"; \
duke@435 194 echo "TARGET = $(TARGET)"; \
duke@435 195 echo "HS_BUILD_VER = $(HS_BUILD_VER)"; \
duke@435 196 echo "JRE_RELEASE_VER = $(JRE_RELEASE_VERSION)"; \
duke@435 197 echo "SA_BUILD_VERSION = $(HS_BUILD_VER)"; \
duke@435 198 echo "HOTSPOT_BUILD_USER = $(HOTSPOT_BUILD_USER)"; \
duke@435 199 echo "HOTSPOT_VM_DISTRO = $(HOTSPOT_VM_DISTRO)"; \
duke@435 200 echo; \
stefank@2314 201 echo "# Used for platform dispatching"; \
stefank@2314 202 echo "TARGET_DEFINES = -DTARGET_OS_FAMILY_\$$(Platform_os_family)"; \
stefank@2314 203 echo "TARGET_DEFINES += -DTARGET_ARCH_\$$(Platform_arch)"; \
stefank@2314 204 echo "TARGET_DEFINES += -DTARGET_ARCH_MODEL_\$$(Platform_arch_model)"; \
stefank@2314 205 echo "TARGET_DEFINES += -DTARGET_OS_ARCH_\$$(Platform_os_arch)"; \
stefank@2314 206 echo "TARGET_DEFINES += -DTARGET_OS_ARCH_MODEL_\$$(Platform_os_arch_model)"; \
stefank@2314 207 echo "TARGET_DEFINES += -DTARGET_COMPILER_\$$(Platform_compiler)"; \
stefank@2314 208 echo "CFLAGS += \$$(TARGET_DEFINES)"; \
stefank@2314 209 echo; \
stefank@2314 210 echo "Src_Dirs_V = \\"; \
duke@435 211 sed 's/$$/ \\/;s|$(GAMMADIR)|$$(GAMMADIR)|' ../shared_dirs.lst; \
kamg@2515 212 echo "$(call gamma-path,altsrc,cpu/$(SRCARCH)/vm) \\"; \
kamg@2515 213 echo "$(call gamma-path,commonsrc,cpu/$(SRCARCH)/vm) \\"; \
kamg@2515 214 echo "$(call gamma-path,altsrc,os_cpu/$(OS_FAMILY)_$(SRCARCH)/vm) \\"; \
kamg@2515 215 echo "$(call gamma-path,commonsrc,os_cpu/$(OS_FAMILY)_$(SRCARCH)/vm) \\"; \
kamg@2515 216 echo "$(call gamma-path,altsrc,os/$(OS_FAMILY)/vm) \\"; \
kamg@2515 217 echo "$(call gamma-path,commonsrc,os/$(OS_FAMILY)/vm) \\"; \
kamg@2515 218 echo "$(call gamma-path,altsrc,os/posix/vm) \\"; \
kamg@2515 219 echo "$(call gamma-path,commonsrc,os/posix/vm)"; \
stefank@2314 220 echo; \
stefank@2314 221 echo "Src_Dirs_I = \\"; \
kamg@2515 222 echo "$(call gamma-path,altsrc,share/vm/prims) \\"; \
kamg@2515 223 echo "$(call gamma-path,commonsrc,share/vm/prims) \\"; \
kamg@2515 224 echo "$(call gamma-path,altsrc,share/vm) \\"; \
kamg@2515 225 echo "$(call gamma-path,commonsrc,share/vm) \\"; \
kamg@2515 226 echo "$(call gamma-path,altsrc,cpu/$(SRCARCH)/vm) \\"; \
kamg@2515 227 echo "$(call gamma-path,commonsrc,cpu/$(SRCARCH)/vm) \\"; \
kamg@2515 228 echo "$(call gamma-path,altsrc,os_cpu/$(OS_FAMILY)_$(SRCARCH)/vm) \\"; \
kamg@2515 229 echo "$(call gamma-path,commonsrc,os_cpu/$(OS_FAMILY)_$(SRCARCH)/vm) \\"; \
kamg@2515 230 echo "$(call gamma-path,altsrc,os/$(OS_FAMILY)/vm) \\"; \
kamg@2515 231 echo "$(call gamma-path,commonsrc,os/$(OS_FAMILY)/vm) \\"; \
kamg@2515 232 echo "$(call gamma-path,altsrc,os/posix/vm) \\"; \
kamg@2515 233 echo "$(call gamma-path,commonsrc,os/posix/vm)"; \
duke@435 234 [ -n "$(CFLAGS_BROWSE)" ] && \
duke@435 235 echo && echo "CFLAGS_BROWSE = $(CFLAGS_BROWSE)"; \
duke@435 236 [ -n "$(HOTSPOT_EXTRA_SYSDEFS)" ] && \
duke@435 237 echo && \
duke@435 238 echo "HOTSPOT_EXTRA_SYSDEFS\$$(HOTSPOT_EXTRA_SYSDEFS) = $(HOTSPOT_EXTRA_SYSDEFS)" && \
duke@435 239 echo "SYSDEFS += \$$(HOTSPOT_EXTRA_SYSDEFS)"; \
duke@435 240 echo; \
kamg@526 241 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(VARIANT).make"; \
kamg@526 242 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(COMPILER).make"; \
duke@435 243 ) > $@
duke@435 244
duke@435 245 flags_vm.make: $(BUILDTREE_MAKE) ../shared_dirs.lst
duke@435 246 @echo Creating $@ ...
duke@435 247 $(QUIETLY) ( \
duke@435 248 $(BUILDTREE_COMMENT); \
duke@435 249 echo; \
duke@435 250 [ "$(TARGET)" = profiled ] && \
kamg@526 251 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/optimized.make"; \
kamg@526 252 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(TARGET).make"; \
duke@435 253 ) > $@
duke@435 254
duke@435 255 ../shared_dirs.lst: $(BUILDTREE_MAKE) $(GAMMADIR)/src/share/vm
duke@435 256 @echo Creating directory list $@
kamg@2515 257 $(QUIETLY) if [ -d $(HS_ALT_SRC)/share/vm ]; then \
kamg@2515 258 find $(HS_ALT_SRC)/share/vm/* -prune \
kamg@2515 259 -type d \! \( $(TOPLEVEL_EXCLUDE_DIRS) \) -exec find {} \
kamg@2515 260 \( $(ALWAYS_EXCLUDE_DIRS) \) -prune -o -type d -print \; > $@; \
kamg@2515 261 fi;
kamg@2515 262 $(QUIETLY) find $(HS_COMMON_SRC)/share/vm/* -prune \
duke@435 263 -type d \! \( $(TOPLEVEL_EXCLUDE_DIRS) \) -exec find {} \
kamg@2515 264 \( $(ALWAYS_EXCLUDE_DIRS) \) -prune -o -type d -print \; >> $@
duke@435 265
duke@435 266 Makefile: $(BUILDTREE_MAKE)
duke@435 267 @echo Creating $@ ...
duke@435 268 $(QUIETLY) ( \
duke@435 269 $(BUILDTREE_COMMENT); \
duke@435 270 echo; \
duke@435 271 echo include flags.make; \
duke@435 272 echo; \
kamg@526 273 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/top.make"; \
duke@435 274 ) > $@
duke@435 275
duke@435 276 vm.make: $(BUILDTREE_MAKE)
duke@435 277 @echo Creating $@ ...
duke@435 278 $(QUIETLY) ( \
duke@435 279 $(BUILDTREE_COMMENT); \
duke@435 280 echo; \
duke@435 281 echo include flags.make; \
duke@435 282 echo include flags_vm.make; \
duke@435 283 echo; \
kamg@526 284 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \
duke@435 285 ) > $@
duke@435 286
duke@435 287 adlc.make: $(BUILDTREE_MAKE)
duke@435 288 @echo Creating $@ ...
duke@435 289 $(QUIETLY) ( \
duke@435 290 $(BUILDTREE_COMMENT); \
duke@435 291 echo; \
duke@435 292 echo include flags.make; \
duke@435 293 echo; \
kamg@526 294 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \
duke@435 295 ) > $@
duke@435 296
duke@435 297 jvmti.make: $(BUILDTREE_MAKE)
duke@435 298 @echo Creating $@ ...
duke@435 299 $(QUIETLY) ( \
duke@435 300 $(BUILDTREE_COMMENT); \
duke@435 301 echo; \
duke@435 302 echo include flags.make; \
duke@435 303 echo; \
kamg@526 304 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \
duke@435 305 ) > $@
duke@435 306
duke@435 307 sa.make: $(BUILDTREE_MAKE)
duke@435 308 @echo Creating $@ ...
duke@435 309 $(QUIETLY) ( \
duke@435 310 $(BUILDTREE_COMMENT); \
duke@435 311 echo; \
duke@435 312 echo include flags.make; \
duke@435 313 echo; \
kamg@526 314 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \
duke@435 315 ) > $@
duke@435 316
duke@435 317 env.sh: $(BUILDTREE_MAKE)
duke@435 318 @echo Creating $@ ...
duke@435 319 $(QUIETLY) ( \
duke@435 320 $(BUILDTREE_COMMENT); \
duke@435 321 [ -n "$$JAVA_HOME" ] && { echo ": \$${JAVA_HOME:=$${JAVA_HOME}}"; }; \
duke@435 322 { \
duke@435 323 echo "LD_LIBRARY_PATH=.:$${LD_LIBRARY_PATH:+$$LD_LIBRARY_PATH:}\$${JAVA_HOME}/jre/lib/${LIBARCH}/native_threads:\$${JAVA_HOME}/jre/lib/${LIBARCH}:${GCC_LIB}"; \
duke@435 324 echo "CLASSPATH=$${CLASSPATH:+$$CLASSPATH:}.:\$${JAVA_HOME}/jre/lib/rt.jar:\$${JAVA_HOME}/jre/lib/i18n.jar"; \
duke@435 325 } | sed s:$${JAVA_HOME:--------}:\$${JAVA_HOME}:g; \
duke@435 326 echo "HOTSPOT_BUILD_USER=\"$${LOGNAME:-$$USER} in `basename $(GAMMADIR)`\""; \
duke@435 327 echo "export JAVA_HOME LD_LIBRARY_PATH CLASSPATH HOTSPOT_BUILD_USER"; \
duke@435 328 ) > $@
duke@435 329
duke@435 330 env.csh: env.sh
duke@435 331 @echo Creating $@ ...
duke@435 332 $(QUIETLY) ( \
duke@435 333 $(BUILDTREE_COMMENT); \
duke@435 334 [ -n "$$JAVA_HOME" ] && \
duke@435 335 { echo "if (! \$$?JAVA_HOME) setenv JAVA_HOME \"$$JAVA_HOME\""; }; \
duke@435 336 sed -n 's/^\([A-Za-z_][A-Za-z0-9_]*\)=/setenv \1 /p' $?; \
duke@435 337 ) > $@
duke@435 338
sla@2369 339 jdkpath.sh: $(BUILDTREE_MAKE)
sla@2369 340 @echo Creating $@ ...
sla@2369 341 $(QUIETLY) ( \
sla@2369 342 $(BUILDTREE_COMMENT); \
sla@2369 343 echo "JDK=${JAVA_HOME}"; \
sla@2369 344 ) > $@
sla@2369 345
duke@435 346 .dbxrc: $(BUILDTREE_MAKE)
duke@435 347 @echo Creating $@ ...
duke@435 348 $(QUIETLY) ( \
duke@435 349 echo "echo '# Loading $(PLATFORM_DIR)/$(TARGET)/.dbxrc'"; \
duke@435 350 echo "if [ -f \"\$${HOTSPOT_DBXWARE}\" ]"; \
duke@435 351 echo "then"; \
duke@435 352 echo " source \"\$${HOTSPOT_DBXWARE}\""; \
duke@435 353 echo "elif [ -f \"\$$HOME/.dbxrc\" ]"; \
duke@435 354 echo "then"; \
duke@435 355 echo " source \"\$$HOME/.dbxrc\""; \
duke@435 356 echo "fi"; \
duke@435 357 ) > $@
duke@435 358
duke@435 359 # Skip the test for product builds (which only work when installed in a JDK), to
duke@435 360 # avoid exiting with an error and causing make to halt.
duke@435 361 NO_TEST_MSG = \
duke@435 362 echo "$@: skipping the test--this build must be tested in a JDK."
duke@435 363
duke@435 364 NO_JAVA_HOME_MSG = \
duke@435 365 echo "JAVA_HOME must be set to run this test."
duke@435 366
duke@435 367 DATA_MODE = $(DATA_MODE/$(BUILDARCH))
duke@435 368 JAVA_FLAG = $(JAVA_FLAG/$(DATA_MODE))
duke@435 369
duke@435 370 DATA_MODE/i486 = 32
duke@435 371 DATA_MODE/sparc = 32
duke@435 372 DATA_MODE/sparcv9 = 64
duke@435 373 DATA_MODE/amd64 = 64
duke@435 374 DATA_MODE/ia64 = 64
never@1445 375 DATA_MODE/zero = $(ARCH_DATA_MODEL)
duke@435 376
duke@435 377 JAVA_FLAG/32 = -d32
duke@435 378 JAVA_FLAG/64 = -d64
duke@435 379
duke@435 380 WRONG_DATA_MODE_MSG = \
duke@435 381 echo "JAVA_HOME must point to $(DATA_MODE)bit JDK."
duke@435 382
bobv@2036 383 CROSS_COMPILING_MSG = \
bobv@2036 384 echo "Cross compiling for ARCH $(CROSS_COMPILE_ARCH), skipping gamma run."
bobv@2036 385
ohair@667 386 test_gamma: $(BUILDTREE_MAKE) $(GAMMADIR)/make/test/Queens.java
duke@435 387 @echo Creating $@ ...
duke@435 388 $(QUIETLY) ( \
duke@435 389 echo '#!/bin/sh'; \
duke@435 390 $(BUILDTREE_COMMENT); \
duke@435 391 echo '. ./env.sh'; \
bobv@2036 392 echo "if [ \"$(CROSS_COMPILE_ARCH)\" != \"\" ]; then { $(CROSS_COMPILING_MSG); exit 0; }; fi"; \
duke@435 393 echo "if [ -z \$$JAVA_HOME ]; then { $(NO_JAVA_HOME_MSG); exit 0; }; fi"; \
ohair@668 394 echo "if ! \$${JAVA_HOME}/bin/java $(JAVA_FLAG) -fullversion 2>&1 > /dev/null"; \
duke@435 395 echo "then"; \
duke@435 396 echo " $(WRONG_DATA_MODE_MSG); exit 0;"; \
duke@435 397 echo "fi"; \
ohair@667 398 echo "rm -f Queens.class"; \
ohair@667 399 echo "\$${JAVA_HOME}/bin/javac -d . $(GAMMADIR)/make/test/Queens.java"; \
duke@435 400 echo '[ -f gamma_g ] && { gamma=gamma_g; }'; \
duke@435 401 echo './$${gamma:-gamma} $(TESTFLAGS) Queens < /dev/null'; \
duke@435 402 ) > $@
duke@435 403 $(QUIETLY) chmod +x $@
duke@435 404
duke@435 405 FORCE:
duke@435 406
duke@435 407 .PHONY: all FORCE

mercurial