Mon, 08 Oct 2012 09:18:54 -0400
7170638: Use DTRACE_PROBE[N] in JNI Set and SetStatic Field.
Summary: Don't use HS_DTRACE_PROBE_CDECL_N and HS_DTRACE_PROBE_N directly.
Reviewed-by: coleenp, kamg, dholmes, sspitsyn
Contributed-by: Mark Wielaard <mjw@redhat.com>
duke@435 | 1 | # |
dcubed@3724 | 2 | # Copyright (c) 2000, 2012, 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 | |
erikj@3600 | 58 | -include $(SPEC) |
duke@435 | 59 | include $(GAMMADIR)/make/scm.make |
kamg@2515 | 60 | include $(GAMMADIR)/make/altsrc.make |
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: |
kvn@2403 | 66 | TESTFLAGS = -Xbatch -Xmx32m -showversion |
duke@435 | 67 | |
duke@435 | 68 | ### maye ARCH_XXX instead? |
duke@435 | 69 | ifdef USE_GCC |
kamg@526 | 70 | PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH).gcc |
duke@435 | 71 | GCC_LIB = /usr/local/lib |
duke@435 | 72 | else |
kamg@526 | 73 | PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH) |
duke@435 | 74 | GCC_LIB = |
duke@435 | 75 | endif |
duke@435 | 76 | |
duke@435 | 77 | ifdef FORCE_TIERED |
duke@435 | 78 | ifeq ($(VARIANT),tiered) |
duke@435 | 79 | PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_compiler2 |
duke@435 | 80 | else |
duke@435 | 81 | PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_$(VARIANT) |
duke@435 | 82 | endif |
duke@435 | 83 | else |
duke@435 | 84 | PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_$(VARIANT) |
duke@435 | 85 | endif |
duke@435 | 86 | |
duke@435 | 87 | # |
duke@435 | 88 | # We do two levels of exclusion in the shared directory. |
duke@435 | 89 | # TOPLEVEL excludes are pruned, they are not recursively searched, |
duke@435 | 90 | # but lower level directories can be named without fear of collision. |
duke@435 | 91 | # ALWAYS excludes are excluded at any level in the directory tree. |
duke@435 | 92 | # |
duke@435 | 93 | |
duke@435 | 94 | ALWAYS_EXCLUDE_DIRS = $(SCM_DIRS) |
duke@435 | 95 | |
duke@435 | 96 | ifeq ($(VARIANT),tiered) |
duke@435 | 97 | TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name agent |
duke@435 | 98 | else |
duke@435 | 99 | ifeq ($(VARIANT),compiler2) |
duke@435 | 100 | TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name c1 -o -name agent |
duke@435 | 101 | else |
duke@435 | 102 | # compiler1 and core use the same exclude list |
duke@435 | 103 | TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name opto -o -name libadt -o -name agent |
duke@435 | 104 | endif |
duke@435 | 105 | endif |
duke@435 | 106 | |
duke@435 | 107 | # Get things from the platform file. |
duke@435 | 108 | COMPILER = $(shell sed -n 's/^compiler[ ]*=[ ]*//p' $(PLATFORM_FILE)) |
duke@435 | 109 | |
duke@435 | 110 | SIMPLE_DIRS = \ |
stefank@2314 | 111 | $(PLATFORM_DIR)/generated/dependencies \ |
duke@435 | 112 | $(PLATFORM_DIR)/generated/adfiles \ |
duke@435 | 113 | $(PLATFORM_DIR)/generated/jvmtifiles |
duke@435 | 114 | |
duke@435 | 115 | TARGETS = debug fastdebug jvmg optimized product profiled |
duke@435 | 116 | SUBMAKE_DIRS = $(addprefix $(PLATFORM_DIR)/,$(TARGETS)) |
duke@435 | 117 | |
duke@435 | 118 | # For dependencies and recursive makes. |
kamg@526 | 119 | BUILDTREE_MAKE = $(GAMMADIR)/make/$(OS_FAMILY)/makefiles/buildtree.make |
duke@435 | 120 | |
duke@435 | 121 | BUILDTREE_TARGETS = Makefile flags.make flags_vm.make vm.make adlc.make jvmti.make sa.make \ |
phh@3473 | 122 | env.sh env.csh jdkpath.sh .dbxrc test_gamma |
duke@435 | 123 | |
duke@435 | 124 | BUILDTREE_VARS = GAMMADIR=$(GAMMADIR) OS_FAMILY=$(OS_FAMILY) \ |
duke@435 | 125 | ARCH=$(ARCH) BUILDARCH=$(BUILDARCH) LIBARCH=$(LIBARCH) VARIANT=$(VARIANT) |
duke@435 | 126 | |
duke@435 | 127 | # Define variables to be set in flags.make. |
duke@435 | 128 | # Default values are set in make/defs.make. |
duke@435 | 129 | ifeq ($(HOTSPOT_BUILD_VERSION),) |
duke@435 | 130 | HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION) |
duke@435 | 131 | else |
duke@435 | 132 | HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION)-$(HOTSPOT_BUILD_VERSION) |
duke@435 | 133 | endif |
duke@435 | 134 | # Set BUILD_USER from system-dependent hints: $LOGNAME, $(whoami) |
duke@435 | 135 | ifndef HOTSPOT_BUILD_USER |
duke@435 | 136 | HOTSPOT_BUILD_USER := $(shell echo $$LOGNAME) |
duke@435 | 137 | endif |
duke@435 | 138 | ifndef HOTSPOT_BUILD_USER |
duke@435 | 139 | HOTSPOT_BUILD_USER := $(shell whoami) |
duke@435 | 140 | endif |
kamg@526 | 141 | # Define HOTSPOT_VM_DISTRO based on settings in make/openjdk_distro |
kamg@526 | 142 | # or make/hotspot_distro. |
duke@435 | 143 | ifndef HOTSPOT_VM_DISTRO |
kamg@2515 | 144 | ifeq ($(call if-has-altsrc,$(HS_COMMON_SRC)/,true,false),true) |
kamg@526 | 145 | include $(GAMMADIR)/make/hotspot_distro |
duke@435 | 146 | else |
kamg@526 | 147 | include $(GAMMADIR)/make/openjdk_distro |
duke@435 | 148 | endif |
duke@435 | 149 | endif |
duke@435 | 150 | |
coleenp@4148 | 151 | # if hotspot-only build and/or OPENJDK isn't passed down, need to set OPENJDK |
coleenp@4148 | 152 | ifndef OPENJDK |
coleenp@4148 | 153 | ifneq ($(call if-has-altsrc,$(HS_COMMON_SRC)/,true,false),true) |
coleenp@4148 | 154 | OPENJDK=true |
coleenp@4148 | 155 | endif |
coleenp@4148 | 156 | endif |
coleenp@4148 | 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)"; \ |
duke@435 | 191 | echo "SRCARCH = $(ARCH)"; \ |
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)"; \ |
coleenp@4148 | 200 | echo "OPENJDK = $(OPENJDK)"; \ |
duke@435 | 201 | echo "$(LP64_SETTING/$(DATA_MODE))"; \ |
duke@435 | 202 | echo; \ |
stefank@2314 | 203 | echo "# Used for platform dispatching"; \ |
stefank@2314 | 204 | echo "TARGET_DEFINES = -DTARGET_OS_FAMILY_\$$(Platform_os_family)"; \ |
stefank@2314 | 205 | echo "TARGET_DEFINES += -DTARGET_ARCH_\$$(Platform_arch)"; \ |
stefank@2314 | 206 | echo "TARGET_DEFINES += -DTARGET_ARCH_MODEL_\$$(Platform_arch_model)"; \ |
stefank@2314 | 207 | echo "TARGET_DEFINES += -DTARGET_OS_ARCH_\$$(Platform_os_arch)"; \ |
stefank@2314 | 208 | echo "TARGET_DEFINES += -DTARGET_OS_ARCH_MODEL_\$$(Platform_os_arch_model)"; \ |
stefank@2314 | 209 | echo "TARGET_DEFINES += -DTARGET_COMPILER_\$$(Platform_compiler)"; \ |
stefank@2314 | 210 | echo "CFLAGS += \$$(TARGET_DEFINES)"; \ |
stefank@2314 | 211 | echo; \ |
stefank@2314 | 212 | echo "Src_Dirs_V = \\"; \ |
duke@435 | 213 | sed 's/$$/ \\/;s|$(GAMMADIR)|$$(GAMMADIR)|' ../shared_dirs.lst; \ |
kamg@2515 | 214 | echo "$(call gamma-path,altsrc,cpu/$(ARCH)/vm) \\"; \ |
kamg@2515 | 215 | echo "$(call gamma-path,commonsrc,cpu/$(ARCH)/vm) \\"; \ |
kamg@2515 | 216 | echo "$(call gamma-path,altsrc,os_cpu/$(OS_FAMILY)_$(ARCH)/vm) \\"; \ |
kamg@2515 | 217 | echo "$(call gamma-path,commonsrc,os_cpu/$(OS_FAMILY)_$(ARCH)/vm) \\"; \ |
kamg@2515 | 218 | echo "$(call gamma-path,altsrc,os/$(OS_FAMILY)/vm) \\"; \ |
kamg@2515 | 219 | echo "$(call gamma-path,commonsrc,os/$(OS_FAMILY)/vm) \\"; \ |
kamg@2515 | 220 | echo "$(call gamma-path,altsrc,os/posix/vm) \\"; \ |
kamg@2515 | 221 | echo "$(call gamma-path,commonsrc,os/posix/vm)"; \ |
stefank@2314 | 222 | echo; \ |
stefank@2314 | 223 | echo "Src_Dirs_I = \\"; \ |
kamg@2515 | 224 | echo "$(call gamma-path,altsrc,share/vm/prims) \\"; \ |
kamg@2515 | 225 | echo "$(call gamma-path,commonsrc,share/vm/prims) \\"; \ |
kamg@2515 | 226 | echo "$(call gamma-path,altsrc,share/vm) \\"; \ |
kamg@2515 | 227 | echo "$(call gamma-path,commonsrc,share/vm) \\"; \ |
brutisso@3229 | 228 | echo "$(call gamma-path,altsrc,share/vm/precompiled) \\"; \ |
brutisso@3229 | 229 | echo "$(call gamma-path,commonsrc,share/vm/precompiled) \\"; \ |
kamg@2515 | 230 | echo "$(call gamma-path,altsrc,cpu/$(ARCH)/vm) \\"; \ |
kamg@2515 | 231 | echo "$(call gamma-path,commonsrc,cpu/$(ARCH)/vm) \\"; \ |
kamg@2515 | 232 | echo "$(call gamma-path,altsrc,os_cpu/$(OS_FAMILY)_$(ARCH)/vm) \\"; \ |
kamg@2515 | 233 | echo "$(call gamma-path,commonsrc,os_cpu/$(OS_FAMILY)_$(ARCH)/vm) \\"; \ |
kamg@2515 | 234 | echo "$(call gamma-path,altsrc,os/$(OS_FAMILY)/vm) \\"; \ |
kamg@2515 | 235 | echo "$(call gamma-path,commonsrc,os/$(OS_FAMILY)/vm) \\"; \ |
kamg@2515 | 236 | echo "$(call gamma-path,altsrc,os/posix/vm) \\"; \ |
kamg@2515 | 237 | echo "$(call gamma-path,commonsrc,os/posix/vm)"; \ |
duke@435 | 238 | [ -n "$(CFLAGS_BROWSE)" ] && \ |
duke@435 | 239 | echo && echo "CFLAGS_BROWSE = $(CFLAGS_BROWSE)"; \ |
dcubed@3724 | 240 | [ -n "$(ENABLE_FULL_DEBUG_SYMBOLS)" ] && \ |
dcubed@3724 | 241 | echo && echo "ENABLE_FULL_DEBUG_SYMBOLS = $(ENABLE_FULL_DEBUG_SYMBOLS)"; \ |
dcubed@3150 | 242 | [ -n "$(OBJCOPY)" ] && \ |
dcubed@3150 | 243 | echo && echo "OBJCOPY = $(OBJCOPY)"; \ |
dcubed@3150 | 244 | [ -n "$(STRIP_POLICY)" ] && \ |
dcubed@3150 | 245 | echo && echo "STRIP_POLICY = $(STRIP_POLICY)"; \ |
dcubed@3724 | 246 | [ -n "$(ZIP_DEBUGINFO_FILES)" ] && \ |
dcubed@3724 | 247 | echo && echo "ZIP_DEBUGINFO_FILES = $(ZIP_DEBUGINFO_FILES)"; \ |
dcubed@3724 | 248 | [ -n "$(ZIPEXE)" ] && \ |
dcubed@3724 | 249 | echo && echo "ZIPEXE = $(ZIPEXE)"; \ |
duke@435 | 250 | [ -n "$(HOTSPOT_EXTRA_SYSDEFS)" ] && \ |
duke@435 | 251 | echo && \ |
duke@435 | 252 | echo "HOTSPOT_EXTRA_SYSDEFS\$$(HOTSPOT_EXTRA_SYSDEFS) = $(HOTSPOT_EXTRA_SYSDEFS)" && \ |
duke@435 | 253 | echo "SYSDEFS += \$$(HOTSPOT_EXTRA_SYSDEFS)"; \ |
duke@435 | 254 | echo; \ |
erikj@3600 | 255 | [ -n "$(SPEC)" ] && \ |
erikj@3600 | 256 | echo "include $(SPEC)"; \ |
kamg@526 | 257 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(VARIANT).make"; \ |
kamg@526 | 258 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(COMPILER).make"; \ |
duke@435 | 259 | ) > $@ |
duke@435 | 260 | |
duke@435 | 261 | flags_vm.make: $(BUILDTREE_MAKE) ../shared_dirs.lst |
duke@435 | 262 | @echo Creating $@ ... |
duke@435 | 263 | $(QUIETLY) ( \ |
duke@435 | 264 | $(BUILDTREE_COMMENT); \ |
duke@435 | 265 | echo; \ |
duke@435 | 266 | [ "$(TARGET)" = profiled ] && \ |
kamg@526 | 267 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/optimized.make"; \ |
kamg@526 | 268 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(TARGET).make"; \ |
duke@435 | 269 | ) > $@ |
duke@435 | 270 | |
duke@435 | 271 | ../shared_dirs.lst: $(BUILDTREE_MAKE) $(GAMMADIR)/src/share/vm |
duke@435 | 272 | @echo Creating directory list $@ |
kamg@2515 | 273 | $(QUIETLY) if [ -d $(HS_ALT_SRC)/share/vm ]; then \ |
kamg@2515 | 274 | find $(HS_ALT_SRC)/share/vm/* -prune \ |
kamg@2515 | 275 | -type d \! \( $(TOPLEVEL_EXCLUDE_DIRS) \) -exec find {} \ |
kamg@2515 | 276 | \( $(ALWAYS_EXCLUDE_DIRS) \) -prune -o -type d -print \; > $@; \ |
kamg@2515 | 277 | fi; |
kamg@2515 | 278 | $(QUIETLY) find $(HS_COMMON_SRC)/share/vm/* -prune \ |
duke@435 | 279 | -type d \! \( $(TOPLEVEL_EXCLUDE_DIRS) \) -exec find {} \ |
kamg@2515 | 280 | \( $(ALWAYS_EXCLUDE_DIRS) \) -prune -o -type d -print \; >> $@ |
duke@435 | 281 | |
duke@435 | 282 | Makefile: $(BUILDTREE_MAKE) |
duke@435 | 283 | @echo Creating $@ ... |
duke@435 | 284 | $(QUIETLY) ( \ |
duke@435 | 285 | $(BUILDTREE_COMMENT); \ |
duke@435 | 286 | echo; \ |
duke@435 | 287 | echo include flags.make; \ |
duke@435 | 288 | echo; \ |
kamg@526 | 289 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/top.make"; \ |
duke@435 | 290 | ) > $@ |
duke@435 | 291 | |
duke@435 | 292 | vm.make: $(BUILDTREE_MAKE) |
duke@435 | 293 | @echo Creating $@ ... |
duke@435 | 294 | $(QUIETLY) ( \ |
duke@435 | 295 | $(BUILDTREE_COMMENT); \ |
duke@435 | 296 | echo; \ |
duke@435 | 297 | echo include flags.make; \ |
duke@435 | 298 | echo include flags_vm.make; \ |
duke@435 | 299 | echo; \ |
kamg@526 | 300 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \ |
duke@435 | 301 | ) > $@ |
duke@435 | 302 | |
duke@435 | 303 | adlc.make: $(BUILDTREE_MAKE) |
duke@435 | 304 | @echo Creating $@ ... |
duke@435 | 305 | $(QUIETLY) ( \ |
duke@435 | 306 | $(BUILDTREE_COMMENT); \ |
duke@435 | 307 | echo; \ |
duke@435 | 308 | echo include flags.make; \ |
duke@435 | 309 | echo; \ |
kamg@526 | 310 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \ |
duke@435 | 311 | ) > $@ |
duke@435 | 312 | |
duke@435 | 313 | jvmti.make: $(BUILDTREE_MAKE) |
duke@435 | 314 | @echo Creating $@ ... |
duke@435 | 315 | $(QUIETLY) ( \ |
duke@435 | 316 | $(BUILDTREE_COMMENT); \ |
duke@435 | 317 | echo; \ |
duke@435 | 318 | echo include flags.make; \ |
duke@435 | 319 | echo; \ |
kamg@526 | 320 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \ |
duke@435 | 321 | ) > $@ |
duke@435 | 322 | |
duke@435 | 323 | sa.make: $(BUILDTREE_MAKE) |
duke@435 | 324 | @echo Creating $@ ... |
duke@435 | 325 | $(QUIETLY) ( \ |
duke@435 | 326 | $(BUILDTREE_COMMENT); \ |
duke@435 | 327 | echo; \ |
duke@435 | 328 | echo include flags.make; \ |
duke@435 | 329 | echo; \ |
kamg@526 | 330 | echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \ |
duke@435 | 331 | ) > $@ |
duke@435 | 332 | |
phh@3473 | 333 | env.sh: $(BUILDTREE_MAKE) |
duke@435 | 334 | @echo Creating $@ ... |
duke@435 | 335 | $(QUIETLY) ( \ |
duke@435 | 336 | $(BUILDTREE_COMMENT); \ |
duke@435 | 337 | [ -n "$$JAVA_HOME" ] && { echo ": \$${JAVA_HOME:=$${JAVA_HOME}}"; }; \ |
duke@435 | 338 | { \ |
duke@435 | 339 | echo "CLASSPATH=$${CLASSPATH:+$$CLASSPATH:}.:\$${JAVA_HOME}/jre/lib/rt.jar:\$${JAVA_HOME}/jre/lib/i18n.jar"; \ |
duke@435 | 340 | } | sed s:$${JAVA_HOME:--------}:\$${JAVA_HOME}:g; \ |
duke@435 | 341 | echo "HOTSPOT_BUILD_USER=\"$${LOGNAME:-$$USER} in `basename $(GAMMADIR)`\""; \ |
duke@435 | 342 | echo "export JAVA_HOME LD_LIBRARY_PATH CLASSPATH HOTSPOT_BUILD_USER"; \ |
duke@435 | 343 | ) > $@ |
duke@435 | 344 | |
phh@3473 | 345 | env.csh: env.sh |
duke@435 | 346 | @echo Creating $@ ... |
duke@435 | 347 | $(QUIETLY) ( \ |
duke@435 | 348 | $(BUILDTREE_COMMENT); \ |
duke@435 | 349 | [ -n "$$JAVA_HOME" ] && \ |
duke@435 | 350 | { echo "if (! \$$?JAVA_HOME) setenv JAVA_HOME \"$$JAVA_HOME\""; }; \ |
duke@435 | 351 | sed -n 's/^\([A-Za-z_][A-Za-z0-9_]*\)=/setenv \1 /p' $?; \ |
duke@435 | 352 | ) > $@ |
duke@435 | 353 | |
sla@2369 | 354 | jdkpath.sh: $(BUILDTREE_MAKE) |
sla@2369 | 355 | @echo Creating $@ ... |
sla@2369 | 356 | $(QUIETLY) ( \ |
sla@2369 | 357 | $(BUILDTREE_COMMENT); \ |
sla@2369 | 358 | echo "JDK=${JAVA_HOME}"; \ |
sla@2369 | 359 | ) > $@ |
sla@2369 | 360 | |
duke@435 | 361 | .dbxrc: $(BUILDTREE_MAKE) |
duke@435 | 362 | @echo Creating $@ ... |
duke@435 | 363 | $(QUIETLY) ( \ |
duke@435 | 364 | echo "echo '# Loading $(PLATFORM_DIR)/$(TARGET)/.dbxrc'"; \ |
duke@435 | 365 | echo "if [ -f \"\$${HOTSPOT_DBXWARE}\" ]"; \ |
duke@435 | 366 | echo "then"; \ |
duke@435 | 367 | echo " source \"\$${HOTSPOT_DBXWARE}\""; \ |
duke@435 | 368 | echo "elif [ -f \"\$$HOME/.dbxrc\" ]"; \ |
duke@435 | 369 | echo "then"; \ |
duke@435 | 370 | echo " source \"\$$HOME/.dbxrc\""; \ |
duke@435 | 371 | echo "fi"; \ |
duke@435 | 372 | ) > $@ |
duke@435 | 373 | |
duke@435 | 374 | # Skip the test for product builds (which only work when installed in a JDK), to |
duke@435 | 375 | # avoid exiting with an error and causing make to halt. |
duke@435 | 376 | NO_TEST_MSG = \ |
duke@435 | 377 | echo "$@: skipping the test--this build must be tested in a JDK." |
duke@435 | 378 | |
duke@435 | 379 | NO_JAVA_HOME_MSG = \ |
duke@435 | 380 | echo "JAVA_HOME must be set to run this test." |
duke@435 | 381 | |
duke@435 | 382 | DATA_MODE = $(DATA_MODE/$(BUILDARCH)) |
duke@435 | 383 | JAVA_FLAG = $(JAVA_FLAG/$(DATA_MODE)) |
duke@435 | 384 | |
duke@435 | 385 | DATA_MODE/i486 = 32 |
duke@435 | 386 | DATA_MODE/sparc = 32 |
duke@435 | 387 | DATA_MODE/sparcv9 = 64 |
duke@435 | 388 | DATA_MODE/amd64 = 64 |
duke@435 | 389 | DATA_MODE/ia64 = 64 |
duke@435 | 390 | |
duke@435 | 391 | # This bit is needed to enable local rebuilds. |
duke@435 | 392 | # Unless the makefile itself sets LP64, any environmental |
duke@435 | 393 | # setting of LP64 will interfere with the build. |
duke@435 | 394 | LP64_SETTING/32 = LP64 = \#empty |
duke@435 | 395 | LP64_SETTING/64 = LP64 = 1 |
duke@435 | 396 | |
duke@435 | 397 | JAVA_FLAG/32 = -d32 |
duke@435 | 398 | JAVA_FLAG/64 = -d64 |
duke@435 | 399 | |
duke@435 | 400 | WRONG_DATA_MODE_MSG = \ |
phh@3473 | 401 | echo "JAVA_HOME must point to a $(DATA_MODE)-bit OpenJDK." |
phh@3473 | 402 | |
phh@3473 | 403 | CROSS_COMPILING_MSG = \ |
phh@3473 | 404 | echo "Cross compiling for ARCH $(CROSS_COMPILE_ARCH), skipping gamma run." |
duke@435 | 405 | |
ohair@667 | 406 | test_gamma: $(BUILDTREE_MAKE) $(GAMMADIR)/make/test/Queens.java |
duke@435 | 407 | @echo Creating $@ ... |
duke@435 | 408 | $(QUIETLY) ( \ |
phh@3473 | 409 | echo "#!/bin/sh"; \ |
phh@3473 | 410 | echo ""; \ |
duke@435 | 411 | $(BUILDTREE_COMMENT); \ |
phh@3473 | 412 | echo ""; \ |
phh@3473 | 413 | echo "# Include environment settings for gamma run"; \ |
phh@3473 | 414 | echo ""; \ |
phh@3473 | 415 | echo ". ./env.sh"; \ |
phh@3473 | 416 | echo ""; \ |
phh@3473 | 417 | echo "# Do not run gamma test for cross compiles"; \ |
phh@3473 | 418 | echo ""; \ |
phh@3473 | 419 | echo "if [ -n \"$(CROSS_COMPILE_ARCH)\" ]; then "; \ |
phh@3473 | 420 | echo " $(CROSS_COMPILING_MSG)"; \ |
phh@3473 | 421 | echo " exit 0"; \ |
duke@435 | 422 | echo "fi"; \ |
phh@3473 | 423 | echo ""; \ |
phh@3473 | 424 | echo "# Make sure JAVA_HOME is set as it is required for gamma"; \ |
phh@3473 | 425 | echo ""; \ |
phh@3473 | 426 | echo "if [ -z \"\$${JAVA_HOME}\" ]; then "; \ |
phh@3473 | 427 | echo " $(NO_JAVA_HOME_MSG)"; \ |
phh@3473 | 428 | echo " exit 0"; \ |
phh@3473 | 429 | echo "fi"; \ |
phh@3473 | 430 | echo ""; \ |
phh@3473 | 431 | echo "# Check JAVA_HOME version to be used for the test"; \ |
phh@3473 | 432 | echo ""; \ |
phh@3473 | 433 | echo "\$${JAVA_HOME}/bin/java $(JAVA_FLAG) -fullversion > /dev/null 2>&1"; \ |
phh@3473 | 434 | echo "if [ \$$? -ne 0 ]; then "; \ |
phh@3473 | 435 | echo " $(WRONG_DATA_MODE_MSG)"; \ |
phh@3473 | 436 | echo " exit 0"; \ |
phh@3473 | 437 | echo "fi"; \ |
phh@3473 | 438 | echo ""; \ |
phh@3473 | 439 | echo "# Use gamma_g if it exists"; \ |
phh@3473 | 440 | echo ""; \ |
phh@3473 | 441 | echo "GAMMA_PROG=gamma"; \ |
phh@3473 | 442 | echo "if [ -f gamma_g ]; then "; \ |
phh@3473 | 443 | echo " GAMMA_PROG=gamma_g"; \ |
phh@3473 | 444 | echo "fi"; \ |
phh@3473 | 445 | echo ""; \ |
phh@3473 | 446 | echo "if [ \"$(OS_VENDOR)\" = \"Darwin\" ]; then "; \ |
phh@3473 | 447 | echo " # Ensure architecture for gamma and JAVA_HOME is the same."; \ |
phh@3473 | 448 | echo " # NOTE: gamma assumes the OpenJDK directory layout."; \ |
phh@3473 | 449 | echo ""; \ |
phh@3473 | 450 | echo " GAMMA_ARCH=\"\`file \$${GAMMA_PROG} | awk '{print \$$NF}'\`\""; \ |
phh@3473 | 451 | echo " JVM_LIB=\"\$${JAVA_HOME}/jre/lib/libjava.$(LIBRARY_SUFFIX)\""; \ |
phh@3473 | 452 | echo " if [ ! -f \$${JVM_LIB} ]; then"; \ |
phh@3473 | 453 | echo " JVM_LIB=\"\$${JAVA_HOME}/jre/lib/$${LIBARCH}/libjava.$(LIBRARY_SUFFIX)\""; \ |
phh@3473 | 454 | echo " fi"; \ |
phh@3473 | 455 | echo " if [ ! -f \$${JVM_LIB} ] || [ -z \"\`file \$${JVM_LIB} | grep \$${GAMMA_ARCH}\`\" ]; then "; \ |
phh@3473 | 456 | echo " $(WRONG_DATA_MODE_MSG)"; \ |
phh@3473 | 457 | echo " exit 0"; \ |
phh@3473 | 458 | echo " fi"; \ |
phh@3473 | 459 | echo "fi"; \ |
phh@3473 | 460 | echo ""; \ |
phh@3473 | 461 | echo "# Compile Queens program for test"; \ |
phh@3473 | 462 | echo ""; \ |
ohair@667 | 463 | echo "rm -f Queens.class"; \ |
ohair@667 | 464 | echo "\$${JAVA_HOME}/bin/javac -d . $(GAMMADIR)/make/test/Queens.java"; \ |
phh@3473 | 465 | echo ""; \ |
phh@3473 | 466 | echo "# Set library path solely for gamma launcher test run"; \ |
phh@3473 | 467 | echo ""; \ |
phh@3473 | 468 | echo "LD_LIBRARY_PATH=.:$${LD_LIBRARY_PATH:+$$LD_LIBRARY_PATH:}\$${JAVA_HOME}/jre/lib/${LIBARCH}/native_threads:\$${JAVA_HOME}/jre/lib/${LIBARCH}:${GCC_LIB}"; \ |
phh@3473 | 469 | echo "export LD_LIBRARY_PATH"; \ |
phh@3473 | 470 | echo "unset LD_LIBRARY_PATH_32"; \ |
phh@3473 | 471 | echo "unset LD_LIBRARY_PATH_64"; \ |
phh@3473 | 472 | echo ""; \ |
phh@3473 | 473 | echo "if [ \"$(OS_VENDOR)\" = \"Darwin\" ]; then "; \ |
phh@3473 | 474 | echo " DYLD_LIBRARY_PATH=.:$${DYLD_LIBRARY_PATH:+$$DYLD_LIBRARY_PATH:}\$${JAVA_HOME}/jre/lib/native_threads:\$${JAVA_HOME}/jre/lib:$${DYLD_LIBRARY_PATH:+$$DYLD_LIBRARY_PATH:}\$${JAVA_HOME}/jre/lib/${LIBARCH}/native_threads:\$${JAVA_HOME}/jre/lib/${LIBARCH}:${GCC_LIB}"; \ |
phh@3473 | 475 | echo " export DYLD_LIBRARY_PATH"; \ |
phh@3473 | 476 | echo "fi"; \ |
phh@3473 | 477 | echo ""; \ |
phh@3473 | 478 | echo "# Use the gamma launcher and JAVA_HOME to run the test"; \ |
phh@3473 | 479 | echo ""; \ |
phh@3473 | 480 | echo "./\$${GAMMA_PROG} $(TESTFLAGS) Queens < /dev/null"; \ |
duke@435 | 481 | ) > $@ |
duke@435 | 482 | $(QUIETLY) chmod +x $@ |
duke@435 | 483 | |
duke@435 | 484 | FORCE: |
duke@435 | 485 | |
duke@435 | 486 | .PHONY: all FORCE |