make/solaris/makefiles/buildtree.make

Tue, 30 Nov 2010 18:07:18 -0800

author
ohair
date
Tue, 30 Nov 2010 18:07:18 -0800
changeset 2319
c7db7adb83b4
parent 1907
c18cbe5936b8
child 2320
2ca799d83d3c
permissions
-rw-r--r--

6987107: Add variable to add to but not modify non-fcs version string
Reviewed-by: jcoomes, dholmes, andrew, kvn

duke@435 1 #
trims@1907 2 # Copyright (c) 2000, 2008, 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 #
duke@435 27 # $(MAKE) -f buildtree.make ARCH=arch 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
duke@435 59
duke@435 60 # 'gmake MAKE_VERBOSE=y' or 'gmake QUIETLY=' gives all the gory details.
duke@435 61 QUIETLY$(MAKE_VERBOSE) = @
duke@435 62
duke@435 63 # For now, until the compiler is less wobbly:
duke@435 64 TESTFLAGS = -Xbatch -showversion
duke@435 65
duke@435 66 ### maye ARCH_XXX instead?
duke@435 67 ifdef USE_GCC
kamg@526 68 PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH).gcc
duke@435 69 GCC_LIB = /usr/local/lib
duke@435 70 else
kamg@526 71 PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH)
duke@435 72 GCC_LIB =
duke@435 73 endif
duke@435 74
duke@435 75 ifdef FORCE_TIERED
duke@435 76 ifeq ($(VARIANT),tiered)
duke@435 77 PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_compiler2
duke@435 78 else
duke@435 79 PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_$(VARIANT)
duke@435 80 endif
duke@435 81 else
duke@435 82 PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_$(VARIANT)
duke@435 83 endif
duke@435 84
duke@435 85 #
duke@435 86 # We do two levels of exclusion in the shared directory.
duke@435 87 # TOPLEVEL excludes are pruned, they are not recursively searched,
duke@435 88 # but lower level directories can be named without fear of collision.
duke@435 89 # ALWAYS excludes are excluded at any level in the directory tree.
duke@435 90 #
duke@435 91
duke@435 92 ALWAYS_EXCLUDE_DIRS = $(SCM_DIRS)
duke@435 93
duke@435 94 ifeq ($(VARIANT),tiered)
duke@435 95 TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name agent
duke@435 96 else
duke@435 97 ifeq ($(VARIANT),compiler2)
duke@435 98 TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name c1 -o -name agent
duke@435 99 else
duke@435 100 # compiler1 and core use the same exclude list
duke@435 101 TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name opto -o -name libadt -o -name agent
duke@435 102 endif
duke@435 103 endif
duke@435 104
duke@435 105 # Get things from the platform file.
duke@435 106 COMPILER = $(shell sed -n 's/^compiler[ ]*=[ ]*//p' $(PLATFORM_FILE))
duke@435 107
duke@435 108 SIMPLE_DIRS = \
duke@435 109 $(PLATFORM_DIR)/generated/incls \
duke@435 110 $(PLATFORM_DIR)/generated/adfiles \
duke@435 111 $(PLATFORM_DIR)/generated/jvmtifiles
duke@435 112
duke@435 113 TARGETS = debug fastdebug jvmg optimized product profiled
duke@435 114 SUBMAKE_DIRS = $(addprefix $(PLATFORM_DIR)/,$(TARGETS))
duke@435 115
duke@435 116 # For dependencies and recursive makes.
kamg@526 117 BUILDTREE_MAKE = $(GAMMADIR)/make/$(OS_FAMILY)/makefiles/buildtree.make
duke@435 118
duke@435 119 BUILDTREE_TARGETS = Makefile flags.make flags_vm.make vm.make adlc.make jvmti.make sa.make \
duke@435 120 env.ksh env.csh .dbxrc test_gamma
duke@435 121
duke@435 122 BUILDTREE_VARS = GAMMADIR=$(GAMMADIR) OS_FAMILY=$(OS_FAMILY) \
duke@435 123 ARCH=$(ARCH) BUILDARCH=$(BUILDARCH) LIBARCH=$(LIBARCH) VARIANT=$(VARIANT)
duke@435 124
duke@435 125 # Define variables to be set in flags.make.
duke@435 126 # Default values are set in make/defs.make.
duke@435 127 ifeq ($(HOTSPOT_BUILD_VERSION),)
duke@435 128 HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION)
duke@435 129 else
duke@435 130 HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION)-$(HOTSPOT_BUILD_VERSION)
duke@435 131 endif
duke@435 132 # Set BUILD_USER from system-dependent hints: $LOGNAME, $(whoami)
duke@435 133 ifndef HOTSPOT_BUILD_USER
duke@435 134 HOTSPOT_BUILD_USER := $(shell echo $$LOGNAME)
duke@435 135 endif
duke@435 136 ifndef HOTSPOT_BUILD_USER
duke@435 137 HOTSPOT_BUILD_USER := $(shell whoami)
duke@435 138 endif
kamg@526 139 # Define HOTSPOT_VM_DISTRO based on settings in make/openjdk_distro
kamg@526 140 # or make/hotspot_distro.
duke@435 141 ifndef HOTSPOT_VM_DISTRO
duke@435 142 CLOSED_DIR_EXISTS := $(shell \
kamg@526 143 if [ -d $(GAMMADIR)/src/closed ] ; then \
duke@435 144 echo true; \
duke@435 145 else \
duke@435 146 echo false; \
duke@435 147 fi)
duke@435 148 ifeq ($(CLOSED_DIR_EXISTS), true)
kamg@526 149 include $(GAMMADIR)/make/hotspot_distro
duke@435 150 else
kamg@526 151 include $(GAMMADIR)/make/openjdk_distro
duke@435 152 endif
duke@435 153 endif
duke@435 154
duke@435 155 BUILDTREE_VARS += HOTSPOT_RELEASE_VERSION=$(HS_BUILD_VER) HOTSPOT_BUILD_VERSION= JRE_RELEASE_VERSION=$(JRE_RELEASE_VERSION)
duke@435 156
duke@435 157 BUILDTREE = \
duke@435 158 $(MAKE) -f $(BUILDTREE_MAKE) $(BUILDTREE_TARGETS) $(BUILDTREE_VARS)
duke@435 159
duke@435 160 BUILDTREE_COMMENT = echo "\# Generated by $(BUILDTREE_MAKE)"
duke@435 161
duke@435 162 all: $(SUBMAKE_DIRS)
duke@435 163
duke@435 164 # Run make in each subdirectory recursively.
duke@435 165 $(SUBMAKE_DIRS): $(SIMPLE_DIRS) FORCE
duke@435 166 $(QUIETLY) [ -d $@ ] || { mkdir -p $@; }
duke@435 167 $(QUIETLY) cd $@ && $(BUILDTREE) TARGET=$(@F)
duke@435 168 $(QUIETLY) touch $@
duke@435 169
duke@435 170 $(SIMPLE_DIRS):
duke@435 171 $(QUIETLY) mkdir -p $@
duke@435 172
duke@435 173 flags.make: $(BUILDTREE_MAKE) ../shared_dirs.lst
duke@435 174 @echo Creating $@ ...
duke@435 175 $(QUIETLY) ( \
duke@435 176 $(BUILDTREE_COMMENT); \
duke@435 177 echo; \
duke@435 178 echo "Platform_file = $(PLATFORM_FILE)" | sed 's|$(GAMMADIR)|$$(GAMMADIR)|'; \
duke@435 179 sed -n '/=/s/^ */Platform_/p' < $(PLATFORM_FILE); \
duke@435 180 echo; \
duke@435 181 echo "GAMMADIR = $(GAMMADIR)"; \
duke@435 182 echo "SYSDEFS = \$$(Platform_sysdefs)"; \
duke@435 183 echo "SRCARCH = $(ARCH)"; \
duke@435 184 echo "BUILDARCH = $(BUILDARCH)"; \
duke@435 185 echo "LIBARCH = $(LIBARCH)"; \
duke@435 186 echo "TARGET = $(TARGET)"; \
duke@435 187 echo "HS_BUILD_VER = $(HS_BUILD_VER)"; \
duke@435 188 echo "JRE_RELEASE_VER = $(JRE_RELEASE_VERSION)"; \
duke@435 189 echo "SA_BUILD_VERSION = $(HS_BUILD_VER)"; \
duke@435 190 echo "HOTSPOT_BUILD_USER = $(HOTSPOT_BUILD_USER)"; \
duke@435 191 echo "HOTSPOT_VM_DISTRO = $(HOTSPOT_VM_DISTRO)"; \
duke@435 192 echo "$(LP64_SETTING/$(DATA_MODE))"; \
duke@435 193 echo; \
duke@435 194 echo "Src_Dirs = \\"; \
duke@435 195 sed 's/$$/ \\/;s|$(GAMMADIR)|$$(GAMMADIR)|' ../shared_dirs.lst; \
duke@435 196 echo "\$$(GAMMADIR)/src/cpu/$(ARCH)/vm \\"; \
duke@435 197 echo "\$$(GAMMADIR)/src/os/$(OS_FAMILY)/vm \\"; \
duke@435 198 echo "\$$(GAMMADIR)/src/os_cpu/$(OS_FAMILY)_$(ARCH)/vm"; \
duke@435 199 [ -n "$(CFLAGS_BROWSE)" ] && \
duke@435 200 echo && echo "CFLAGS_BROWSE = $(CFLAGS_BROWSE)"; \
duke@435 201 [ -n "$(HOTSPOT_EXTRA_SYSDEFS)" ] && \
duke@435 202 echo && \
duke@435 203 echo "HOTSPOT_EXTRA_SYSDEFS\$$(HOTSPOT_EXTRA_SYSDEFS) = $(HOTSPOT_EXTRA_SYSDEFS)" && \
duke@435 204 echo "SYSDEFS += \$$(HOTSPOT_EXTRA_SYSDEFS)"; \
duke@435 205 echo; \
kamg@526 206 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(VARIANT).make"; \
kamg@526 207 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(COMPILER).make"; \
duke@435 208 ) > $@
duke@435 209
duke@435 210 flags_vm.make: $(BUILDTREE_MAKE) ../shared_dirs.lst
duke@435 211 @echo Creating $@ ...
duke@435 212 $(QUIETLY) ( \
duke@435 213 $(BUILDTREE_COMMENT); \
duke@435 214 echo; \
duke@435 215 [ "$(TARGET)" = profiled ] && \
kamg@526 216 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/optimized.make"; \
kamg@526 217 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(TARGET).make"; \
duke@435 218 ) > $@
duke@435 219
duke@435 220 ../shared_dirs.lst: $(BUILDTREE_MAKE) $(GAMMADIR)/src/share/vm
duke@435 221 @echo Creating directory list $@
duke@435 222 $(QUIETLY) find $(GAMMADIR)/src/share/vm/* -prune \
duke@435 223 -type d \! \( $(TOPLEVEL_EXCLUDE_DIRS) \) -exec find {} \
duke@435 224 \( $(ALWAYS_EXCLUDE_DIRS) \) -prune -o -type d -print \; > $@
duke@435 225
duke@435 226 Makefile: $(BUILDTREE_MAKE)
duke@435 227 @echo Creating $@ ...
duke@435 228 $(QUIETLY) ( \
duke@435 229 $(BUILDTREE_COMMENT); \
duke@435 230 echo; \
duke@435 231 echo include flags.make; \
duke@435 232 echo; \
kamg@526 233 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/top.make"; \
duke@435 234 ) > $@
duke@435 235
duke@435 236 vm.make: $(BUILDTREE_MAKE)
duke@435 237 @echo Creating $@ ...
duke@435 238 $(QUIETLY) ( \
duke@435 239 $(BUILDTREE_COMMENT); \
duke@435 240 echo; \
duke@435 241 echo include flags.make; \
duke@435 242 echo include flags_vm.make; \
duke@435 243 echo; \
kamg@526 244 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \
duke@435 245 ) > $@
duke@435 246
duke@435 247 adlc.make: $(BUILDTREE_MAKE)
duke@435 248 @echo Creating $@ ...
duke@435 249 $(QUIETLY) ( \
duke@435 250 $(BUILDTREE_COMMENT); \
duke@435 251 echo; \
duke@435 252 echo include flags.make; \
duke@435 253 echo; \
kamg@526 254 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \
duke@435 255 ) > $@
duke@435 256
duke@435 257 jvmti.make: $(BUILDTREE_MAKE)
duke@435 258 @echo Creating $@ ...
duke@435 259 $(QUIETLY) ( \
duke@435 260 $(BUILDTREE_COMMENT); \
duke@435 261 echo; \
duke@435 262 echo include flags.make; \
duke@435 263 echo; \
kamg@526 264 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \
duke@435 265 ) > $@
duke@435 266
duke@435 267 sa.make: $(BUILDTREE_MAKE)
duke@435 268 @echo Creating $@ ...
duke@435 269 $(QUIETLY) ( \
duke@435 270 $(BUILDTREE_COMMENT); \
duke@435 271 echo; \
duke@435 272 echo include flags.make; \
duke@435 273 echo; \
kamg@526 274 echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \
duke@435 275 ) > $@
duke@435 276
duke@435 277 env.ksh: $(BUILDTREE_MAKE)
duke@435 278 @echo Creating $@ ...
duke@435 279 $(QUIETLY) ( \
duke@435 280 $(BUILDTREE_COMMENT); \
duke@435 281 [ -n "$$JAVA_HOME" ] && { echo ": \$${JAVA_HOME:=$${JAVA_HOME}}"; }; \
duke@435 282 { \
duke@435 283 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 284 echo "unset LD_LIBRARY_PATH_32"; \
duke@435 285 echo "unset LD_LIBRARY_PATH_64"; \
duke@435 286 echo "CLASSPATH=$${CLASSPATH:+$$CLASSPATH:}.:\$${JAVA_HOME}/jre/lib/rt.jar:\$${JAVA_HOME}/jre/lib/i18n.jar"; \
duke@435 287 } | sed s:$${JAVA_HOME:--------}:\$${JAVA_HOME}:g; \
duke@435 288 echo "HOTSPOT_BUILD_USER=\"$${LOGNAME:-$$USER} in `basename $(GAMMADIR)`\""; \
duke@435 289 echo "export JAVA_HOME LD_LIBRARY_PATH CLASSPATH HOTSPOT_BUILD_USER"; \
duke@435 290 ) > $@
duke@435 291
duke@435 292 env.csh: env.ksh
duke@435 293 @echo Creating $@ ...
duke@435 294 $(QUIETLY) ( \
duke@435 295 $(BUILDTREE_COMMENT); \
duke@435 296 [ -n "$$JAVA_HOME" ] && \
duke@435 297 { echo "if (! \$$?JAVA_HOME) setenv JAVA_HOME \"$$JAVA_HOME\""; }; \
duke@435 298 sed -n 's/^\([A-Za-z_][A-Za-z0-9_]*\)=/setenv \1 /p' $?; \
duke@435 299 ) > $@
duke@435 300
duke@435 301 .dbxrc: $(BUILDTREE_MAKE)
duke@435 302 @echo Creating $@ ...
duke@435 303 $(QUIETLY) ( \
duke@435 304 echo "echo '# Loading $(PLATFORM_DIR)/$(TARGET)/.dbxrc'"; \
duke@435 305 echo "if [ -f \"\$${HOTSPOT_DBXWARE}\" ]"; \
duke@435 306 echo "then"; \
duke@435 307 echo " source \"\$${HOTSPOT_DBXWARE}\""; \
duke@435 308 echo "elif [ -f \"\$$HOME/.dbxrc\" ]"; \
duke@435 309 echo "then"; \
duke@435 310 echo " source \"\$$HOME/.dbxrc\""; \
duke@435 311 echo "fi"; \
duke@435 312 ) > $@
duke@435 313
duke@435 314 # Skip the test for product builds (which only work when installed in a JDK), to
duke@435 315 # avoid exiting with an error and causing make to halt.
duke@435 316 NO_TEST_MSG = \
duke@435 317 echo "$@: skipping the test--this build must be tested in a JDK."
duke@435 318
duke@435 319 NO_JAVA_HOME_MSG = \
duke@435 320 echo "JAVA_HOME must be set to run this test."
duke@435 321
duke@435 322 DATA_MODE = $(DATA_MODE/$(BUILDARCH))
duke@435 323 JAVA_FLAG = $(JAVA_FLAG/$(DATA_MODE))
duke@435 324
duke@435 325 DATA_MODE/i486 = 32
duke@435 326 DATA_MODE/sparc = 32
duke@435 327 DATA_MODE/sparcv9 = 64
duke@435 328 DATA_MODE/amd64 = 64
duke@435 329 DATA_MODE/ia64 = 64
duke@435 330
duke@435 331 # This bit is needed to enable local rebuilds.
duke@435 332 # Unless the makefile itself sets LP64, any environmental
duke@435 333 # setting of LP64 will interfere with the build.
duke@435 334 LP64_SETTING/32 = LP64 = \#empty
duke@435 335 LP64_SETTING/64 = LP64 = 1
duke@435 336
duke@435 337 JAVA_FLAG/32 = -d32
duke@435 338 JAVA_FLAG/64 = -d64
duke@435 339
duke@435 340 WRONG_DATA_MODE_MSG = \
duke@435 341 echo "JAVA_HOME must point to $(DATA_MODE)bit JDK."
duke@435 342
ohair@667 343 test_gamma: $(BUILDTREE_MAKE) $(GAMMADIR)/make/test/Queens.java
duke@435 344 @echo Creating $@ ...
duke@435 345 $(QUIETLY) ( \
duke@435 346 echo '#!/bin/ksh'; \
duke@435 347 $(BUILDTREE_COMMENT); \
duke@435 348 echo '. ./env.ksh'; \
duke@435 349 echo "if [ -z \$$JAVA_HOME ]; then { $(NO_JAVA_HOME_MSG); exit 0; }; fi"; \
duke@435 350 echo "if ! \$${JAVA_HOME}/bin/java $(JAVA_FLAG) -fullversion 2>&1 > /dev/null"; \
duke@435 351 echo "then"; \
duke@435 352 echo " $(WRONG_DATA_MODE_MSG); exit 0;"; \
duke@435 353 echo "fi"; \
ohair@667 354 echo "rm -f Queens.class"; \
ohair@667 355 echo "\$${JAVA_HOME}/bin/javac -d . $(GAMMADIR)/make/test/Queens.java"; \
duke@435 356 echo '[ -f gamma_g ] && { gamma=gamma_g; }'; \
duke@435 357 echo './$${gamma:-gamma} $(TESTFLAGS) Queens < /dev/null'; \
duke@435 358 ) > $@
duke@435 359 $(QUIETLY) chmod +x $@
duke@435 360
duke@435 361 FORCE:
duke@435 362
duke@435 363 .PHONY: all FORCE

mercurial