author | katleman |
Wed, 13 Jun 2012 16:53:25 -0700 | |
changeset 12906 | d382060bd755 |
parent 12503 | 9df71f999005 |
child 13958 | f5598a86c223 |
permissions | -rw-r--r-- |
1 | 1 |
# |
12501
ea7feae692ae
7102323: RFE: enable Full Debug Symbols Phase 1 on Solaris
dcubed
parents:
11593
diff
changeset
|
2 |
# Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. |
1 | 3 |
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
# |
|
5 |
# This code is free software; you can redistribute it and/or modify it |
|
6 |
# under the terms of the GNU General Public License version 2 only, as |
|
7 |
# published by the Free Software Foundation. |
|
8 |
# |
|
9 |
# This code is distributed in the hope that it will be useful, but WITHOUT |
|
10 |
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
11 |
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
12 |
# version 2 for more details (a copy is included in the LICENSE file that |
|
13 |
# accompanied this code). |
|
14 |
# |
|
15 |
# You should have received a copy of the GNU General Public License version |
|
16 |
# 2 along with this work; if not, write to the Free Software Foundation, |
|
17 |
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
18 |
# |
|
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
781
diff
changeset
|
19 |
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
781
diff
changeset
|
20 |
# or visit www.oracle.com if you need additional information or have any |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
781
diff
changeset
|
21 |
# questions. |
1 | 22 |
# |
23 |
# |
|
24 |
||
25 |
# Usage: |
|
26 |
# |
|
27 |
# $(MAKE) -f buildtree.make ARCH=arch BUILDARCH=buildarch LIBARCH=libarch |
|
28 |
# GAMMADIR=dir OS_FAMILY=os VARIANT=variant |
|
29 |
# |
|
30 |
# The macros ARCH, GAMMADIR, OS_FAMILY and VARIANT must be defined in the |
|
31 |
# environment or on the command-line: |
|
32 |
# |
|
33 |
# ARCH - sparc, i486, ... HotSpot cpu and os_cpu source directory |
|
34 |
# BUILDARCH - build directory |
|
35 |
# LIBARCH - the corresponding directory in JDK/JRE |
|
36 |
# GAMMADIR - top of workspace |
|
37 |
# OS_FAMILY - operating system |
|
38 |
# VARIANT - core, compiler1, compiler2, or tiered |
|
39 |
# HOTSPOT_RELEASE_VERSION - <major>.<minor>-b<nn> (11.0-b07) |
|
7402
554c8ae9c3e0
6987107: Add variable to add to but not modify non-fcs version string
ohair
parents:
5547
diff
changeset
|
40 |
# HOTSPOT_BUILD_VERSION - internal, internal-$(USER_RELEASE_SUFFIX) or empty |
1 | 41 |
# JRE_RELEASE_VERSION - <major>.<minor>.<micro> (1.7.0) |
42 |
# |
|
43 |
# Builds the directory trees with makefiles plus some convenience files in |
|
44 |
# each directory: |
|
45 |
# |
|
46 |
# Makefile - for "make foo" |
|
47 |
# flags.make - with macro settings |
|
48 |
# vm.make - to support making "$(MAKE) -v vm.make" in makefiles |
|
49 |
# adlc.make - |
|
50 |
# jvmti.make - generate JVMTI bindings from the spec (JSR-163) |
|
51 |
# sa.make - generate SA jar file and natives |
|
52 |
# env.[ck]sh - environment settings |
|
53 |
# test_gamma - script to run the Queens program |
|
54 |
# |
|
55 |
# The makefiles are split this way so that "make foo" will run faster by not |
|
56 |
# having to read the dependency files for the vm. |
|
57 |
||
11955
aeca8151886e
7141244: build-infra merge: Include $(SPEC) in makefiles and make variables overridable
erikj
parents:
11593
diff
changeset
|
58 |
-include $(SPEC) |
1 | 59 |
include $(GAMMADIR)/make/scm.make |
8114
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
60 |
include $(GAMMADIR)/make/altsrc.make |
1 | 61 |
|
62 |
# 'gmake MAKE_VERBOSE=y' or 'gmake QUIETLY=' gives all the gory details. |
|
63 |
QUIETLY$(MAKE_VERBOSE) = @ |
|
64 |
||
65 |
# For now, until the compiler is less wobbly: |
|
7704 | 66 |
TESTFLAGS = -Xbatch -Xmx32m -showversion |
1 | 67 |
|
68 |
### maye ARCH_XXX instead? |
|
69 |
ifdef USE_GCC |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
70 |
PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH).gcc |
1 | 71 |
GCC_LIB = /usr/local/lib |
72 |
else |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
73 |
PLATFORM_FILE = $(GAMMADIR)/make/$(OS_FAMILY)/platform_$(BUILDARCH) |
1 | 74 |
GCC_LIB = |
75 |
endif |
|
76 |
||
77 |
ifdef FORCE_TIERED |
|
78 |
ifeq ($(VARIANT),tiered) |
|
79 |
PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_compiler2 |
|
80 |
else |
|
81 |
PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_$(VARIANT) |
|
82 |
endif |
|
83 |
else |
|
84 |
PLATFORM_DIR = $(OS_FAMILY)_$(BUILDARCH)_$(VARIANT) |
|
85 |
endif |
|
86 |
||
87 |
# |
|
88 |
# We do two levels of exclusion in the shared directory. |
|
89 |
# TOPLEVEL excludes are pruned, they are not recursively searched, |
|
90 |
# but lower level directories can be named without fear of collision. |
|
91 |
# ALWAYS excludes are excluded at any level in the directory tree. |
|
92 |
# |
|
93 |
||
94 |
ALWAYS_EXCLUDE_DIRS = $(SCM_DIRS) |
|
95 |
||
96 |
ifeq ($(VARIANT),tiered) |
|
97 |
TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name agent |
|
98 |
else |
|
99 |
ifeq ($(VARIANT),compiler2) |
|
100 |
TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name c1 -o -name agent |
|
101 |
else |
|
102 |
# compiler1 and core use the same exclude list |
|
103 |
TOPLEVEL_EXCLUDE_DIRS = $(ALWAYS_EXCLUDE_DIRS) -o -name adlc -o -name opto -o -name libadt -o -name agent |
|
104 |
endif |
|
105 |
endif |
|
106 |
||
107 |
# Get things from the platform file. |
|
108 |
COMPILER = $(shell sed -n 's/^compiler[ ]*=[ ]*//p' $(PLATFORM_FILE)) |
|
109 |
||
110 |
SIMPLE_DIRS = \ |
|
7397 | 111 |
$(PLATFORM_DIR)/generated/dependencies \ |
1 | 112 |
$(PLATFORM_DIR)/generated/adfiles \ |
113 |
$(PLATFORM_DIR)/generated/jvmtifiles |
|
114 |
||
115 |
TARGETS = debug fastdebug jvmg optimized product profiled |
|
116 |
SUBMAKE_DIRS = $(addprefix $(PLATFORM_DIR)/,$(TARGETS)) |
|
117 |
||
118 |
# For dependencies and recursive makes. |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
119 |
BUILDTREE_MAKE = $(GAMMADIR)/make/$(OS_FAMILY)/makefiles/buildtree.make |
1 | 120 |
|
121 |
BUILDTREE_TARGETS = Makefile flags.make flags_vm.make vm.make adlc.make jvmti.make sa.make \ |
|
11593 | 122 |
env.sh env.csh jdkpath.sh .dbxrc test_gamma |
1 | 123 |
|
124 |
BUILDTREE_VARS = GAMMADIR=$(GAMMADIR) OS_FAMILY=$(OS_FAMILY) \ |
|
125 |
ARCH=$(ARCH) BUILDARCH=$(BUILDARCH) LIBARCH=$(LIBARCH) VARIANT=$(VARIANT) |
|
126 |
||
127 |
# Define variables to be set in flags.make. |
|
128 |
# Default values are set in make/defs.make. |
|
129 |
ifeq ($(HOTSPOT_BUILD_VERSION),) |
|
130 |
HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION) |
|
131 |
else |
|
132 |
HS_BUILD_VER=$(HOTSPOT_RELEASE_VERSION)-$(HOTSPOT_BUILD_VERSION) |
|
133 |
endif |
|
134 |
# Set BUILD_USER from system-dependent hints: $LOGNAME, $(whoami) |
|
135 |
ifndef HOTSPOT_BUILD_USER |
|
136 |
HOTSPOT_BUILD_USER := $(shell echo $$LOGNAME) |
|
137 |
endif |
|
138 |
ifndef HOTSPOT_BUILD_USER |
|
139 |
HOTSPOT_BUILD_USER := $(shell whoami) |
|
140 |
endif |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
141 |
# Define HOTSPOT_VM_DISTRO based on settings in make/openjdk_distro |
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
142 |
# or make/hotspot_distro. |
1 | 143 |
ifndef HOTSPOT_VM_DISTRO |
8114
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
144 |
ifeq ($(call if-has-altsrc,$(HS_COMMON_SRC)/,true,false),true) |
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
145 |
include $(GAMMADIR)/make/hotspot_distro |
1 | 146 |
else |
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
147 |
include $(GAMMADIR)/make/openjdk_distro |
1 | 148 |
endif |
149 |
endif |
|
150 |
||
151 |
BUILDTREE_VARS += HOTSPOT_RELEASE_VERSION=$(HS_BUILD_VER) HOTSPOT_BUILD_VERSION= JRE_RELEASE_VERSION=$(JRE_RELEASE_VERSION) |
|
152 |
||
153 |
BUILDTREE = \ |
|
154 |
$(MAKE) -f $(BUILDTREE_MAKE) $(BUILDTREE_TARGETS) $(BUILDTREE_VARS) |
|
155 |
||
156 |
BUILDTREE_COMMENT = echo "\# Generated by $(BUILDTREE_MAKE)" |
|
157 |
||
158 |
all: $(SUBMAKE_DIRS) |
|
159 |
||
160 |
# Run make in each subdirectory recursively. |
|
161 |
$(SUBMAKE_DIRS): $(SIMPLE_DIRS) FORCE |
|
162 |
$(QUIETLY) [ -d $@ ] || { mkdir -p $@; } |
|
163 |
$(QUIETLY) cd $@ && $(BUILDTREE) TARGET=$(@F) |
|
164 |
$(QUIETLY) touch $@ |
|
165 |
||
166 |
$(SIMPLE_DIRS): |
|
167 |
$(QUIETLY) mkdir -p $@ |
|
168 |
||
8114
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
169 |
# Convenience macro which takes a source relative path, applies $(1) to the |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
170 |
# absolute path, and then replaces $(GAMMADIR) in the result with a |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
171 |
# literal "$(GAMMADIR)/" suitable for inclusion in a Makefile. |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
172 |
gamma-path=$(subst $(GAMMADIR),\$$(GAMMADIR),$(call $(1),$(HS_COMMON_SRC)/$(2))) |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
173 |
|
1 | 174 |
flags.make: $(BUILDTREE_MAKE) ../shared_dirs.lst |
175 |
@echo Creating $@ ... |
|
176 |
$(QUIETLY) ( \ |
|
177 |
$(BUILDTREE_COMMENT); \ |
|
178 |
echo; \ |
|
179 |
echo "Platform_file = $(PLATFORM_FILE)" | sed 's|$(GAMMADIR)|$$(GAMMADIR)|'; \ |
|
180 |
sed -n '/=/s/^ */Platform_/p' < $(PLATFORM_FILE); \ |
|
181 |
echo; \ |
|
182 |
echo "GAMMADIR = $(GAMMADIR)"; \ |
|
183 |
echo "SYSDEFS = \$$(Platform_sysdefs)"; \ |
|
184 |
echo "SRCARCH = $(ARCH)"; \ |
|
185 |
echo "BUILDARCH = $(BUILDARCH)"; \ |
|
186 |
echo "LIBARCH = $(LIBARCH)"; \ |
|
187 |
echo "TARGET = $(TARGET)"; \ |
|
188 |
echo "HS_BUILD_VER = $(HS_BUILD_VER)"; \ |
|
189 |
echo "JRE_RELEASE_VER = $(JRE_RELEASE_VERSION)"; \ |
|
190 |
echo "SA_BUILD_VERSION = $(HS_BUILD_VER)"; \ |
|
191 |
echo "HOTSPOT_BUILD_USER = $(HOTSPOT_BUILD_USER)"; \ |
|
192 |
echo "HOTSPOT_VM_DISTRO = $(HOTSPOT_VM_DISTRO)"; \ |
|
193 |
echo "$(LP64_SETTING/$(DATA_MODE))"; \ |
|
194 |
echo; \ |
|
7397 | 195 |
echo "# Used for platform dispatching"; \ |
196 |
echo "TARGET_DEFINES = -DTARGET_OS_FAMILY_\$$(Platform_os_family)"; \ |
|
197 |
echo "TARGET_DEFINES += -DTARGET_ARCH_\$$(Platform_arch)"; \ |
|
198 |
echo "TARGET_DEFINES += -DTARGET_ARCH_MODEL_\$$(Platform_arch_model)"; \ |
|
199 |
echo "TARGET_DEFINES += -DTARGET_OS_ARCH_\$$(Platform_os_arch)"; \ |
|
200 |
echo "TARGET_DEFINES += -DTARGET_OS_ARCH_MODEL_\$$(Platform_os_arch_model)"; \ |
|
201 |
echo "TARGET_DEFINES += -DTARGET_COMPILER_\$$(Platform_compiler)"; \ |
|
202 |
echo "CFLAGS += \$$(TARGET_DEFINES)"; \ |
|
203 |
echo; \ |
|
204 |
echo "Src_Dirs_V = \\"; \ |
|
1 | 205 |
sed 's/$$/ \\/;s|$(GAMMADIR)|$$(GAMMADIR)|' ../shared_dirs.lst; \ |
8114
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
206 |
echo "$(call gamma-path,altsrc,cpu/$(ARCH)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
207 |
echo "$(call gamma-path,commonsrc,cpu/$(ARCH)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
208 |
echo "$(call gamma-path,altsrc,os_cpu/$(OS_FAMILY)_$(ARCH)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
209 |
echo "$(call gamma-path,commonsrc,os_cpu/$(OS_FAMILY)_$(ARCH)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
210 |
echo "$(call gamma-path,altsrc,os/$(OS_FAMILY)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
211 |
echo "$(call gamma-path,commonsrc,os/$(OS_FAMILY)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
212 |
echo "$(call gamma-path,altsrc,os/posix/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
213 |
echo "$(call gamma-path,commonsrc,os/posix/vm)"; \ |
7397 | 214 |
echo; \ |
215 |
echo "Src_Dirs_I = \\"; \ |
|
8114
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
216 |
echo "$(call gamma-path,altsrc,share/vm/prims) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
217 |
echo "$(call gamma-path,commonsrc,share/vm/prims) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
218 |
echo "$(call gamma-path,altsrc,share/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
219 |
echo "$(call gamma-path,commonsrc,share/vm) \\"; \ |
10830
f3fedfa29811
7106766: Move the precompiled header from the src/share/vm directory
brutisso
parents:
10559
diff
changeset
|
220 |
echo "$(call gamma-path,altsrc,share/vm/precompiled) \\"; \ |
f3fedfa29811
7106766: Move the precompiled header from the src/share/vm directory
brutisso
parents:
10559
diff
changeset
|
221 |
echo "$(call gamma-path,commonsrc,share/vm/precompiled) \\"; \ |
8114
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
222 |
echo "$(call gamma-path,altsrc,cpu/$(ARCH)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
223 |
echo "$(call gamma-path,commonsrc,cpu/$(ARCH)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
224 |
echo "$(call gamma-path,altsrc,os_cpu/$(OS_FAMILY)_$(ARCH)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
225 |
echo "$(call gamma-path,commonsrc,os_cpu/$(OS_FAMILY)_$(ARCH)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
226 |
echo "$(call gamma-path,altsrc,os/$(OS_FAMILY)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
227 |
echo "$(call gamma-path,commonsrc,os/$(OS_FAMILY)/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
228 |
echo "$(call gamma-path,altsrc,os/posix/vm) \\"; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
229 |
echo "$(call gamma-path,commonsrc,os/posix/vm)"; \ |
1 | 230 |
[ -n "$(CFLAGS_BROWSE)" ] && \ |
231 |
echo && echo "CFLAGS_BROWSE = $(CFLAGS_BROWSE)"; \ |
|
12501
ea7feae692ae
7102323: RFE: enable Full Debug Symbols Phase 1 on Solaris
dcubed
parents:
11593
diff
changeset
|
232 |
[ -n "$(ENABLE_FULL_DEBUG_SYMBOLS)" ] && \ |
ea7feae692ae
7102323: RFE: enable Full Debug Symbols Phase 1 on Solaris
dcubed
parents:
11593
diff
changeset
|
233 |
echo && echo "ENABLE_FULL_DEBUG_SYMBOLS = $(ENABLE_FULL_DEBUG_SYMBOLS)"; \ |
10559 | 234 |
[ -n "$(OBJCOPY)" ] && \ |
235 |
echo && echo "OBJCOPY = $(OBJCOPY)"; \ |
|
236 |
[ -n "$(STRIP_POLICY)" ] && \ |
|
237 |
echo && echo "STRIP_POLICY = $(STRIP_POLICY)"; \ |
|
12501
ea7feae692ae
7102323: RFE: enable Full Debug Symbols Phase 1 on Solaris
dcubed
parents:
11593
diff
changeset
|
238 |
[ -n "$(ZIP_DEBUGINFO_FILES)" ] && \ |
ea7feae692ae
7102323: RFE: enable Full Debug Symbols Phase 1 on Solaris
dcubed
parents:
11593
diff
changeset
|
239 |
echo && echo "ZIP_DEBUGINFO_FILES = $(ZIP_DEBUGINFO_FILES)"; \ |
ea7feae692ae
7102323: RFE: enable Full Debug Symbols Phase 1 on Solaris
dcubed
parents:
11593
diff
changeset
|
240 |
[ -n "$(ZIPEXE)" ] && \ |
ea7feae692ae
7102323: RFE: enable Full Debug Symbols Phase 1 on Solaris
dcubed
parents:
11593
diff
changeset
|
241 |
echo && echo "ZIPEXE = $(ZIPEXE)"; \ |
1 | 242 |
[ -n "$(HOTSPOT_EXTRA_SYSDEFS)" ] && \ |
243 |
echo && \ |
|
244 |
echo "HOTSPOT_EXTRA_SYSDEFS\$$(HOTSPOT_EXTRA_SYSDEFS) = $(HOTSPOT_EXTRA_SYSDEFS)" && \ |
|
245 |
echo "SYSDEFS += \$$(HOTSPOT_EXTRA_SYSDEFS)"; \ |
|
246 |
echo; \ |
|
11955
aeca8151886e
7141244: build-infra merge: Include $(SPEC) in makefiles and make variables overridable
erikj
parents:
11593
diff
changeset
|
247 |
[ -n "$(SPEC)" ] && \ |
aeca8151886e
7141244: build-infra merge: Include $(SPEC) in makefiles and make variables overridable
erikj
parents:
11593
diff
changeset
|
248 |
echo "include $(SPEC)"; \ |
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
249 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(VARIANT).make"; \ |
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
250 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(COMPILER).make"; \ |
1 | 251 |
) > $@ |
252 |
||
253 |
flags_vm.make: $(BUILDTREE_MAKE) ../shared_dirs.lst |
|
254 |
@echo Creating $@ ... |
|
255 |
$(QUIETLY) ( \ |
|
256 |
$(BUILDTREE_COMMENT); \ |
|
257 |
echo; \ |
|
258 |
[ "$(TARGET)" = profiled ] && \ |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
259 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/optimized.make"; \ |
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
260 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(TARGET).make"; \ |
1 | 261 |
) > $@ |
262 |
||
263 |
../shared_dirs.lst: $(BUILDTREE_MAKE) $(GAMMADIR)/src/share/vm |
|
264 |
@echo Creating directory list $@ |
|
8114
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
265 |
$(QUIETLY) if [ -d $(HS_ALT_SRC)/share/vm ]; then \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
266 |
find $(HS_ALT_SRC)/share/vm/* -prune \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
267 |
-type d \! \( $(TOPLEVEL_EXCLUDE_DIRS) \) -exec find {} \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
268 |
\( $(ALWAYS_EXCLUDE_DIRS) \) -prune -o -type d -print \; > $@; \ |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
269 |
fi; |
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
270 |
$(QUIETLY) find $(HS_COMMON_SRC)/share/vm/* -prune \ |
1 | 271 |
-type d \! \( $(TOPLEVEL_EXCLUDE_DIRS) \) -exec find {} \ |
8114
340b5b8b544b
7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents:
7718
diff
changeset
|
272 |
\( $(ALWAYS_EXCLUDE_DIRS) \) -prune -o -type d -print \; >> $@ |
1 | 273 |
|
274 |
Makefile: $(BUILDTREE_MAKE) |
|
275 |
@echo Creating $@ ... |
|
276 |
$(QUIETLY) ( \ |
|
277 |
$(BUILDTREE_COMMENT); \ |
|
278 |
echo; \ |
|
279 |
echo include flags.make; \ |
|
280 |
echo; \ |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
281 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/top.make"; \ |
1 | 282 |
) > $@ |
283 |
||
284 |
vm.make: $(BUILDTREE_MAKE) |
|
285 |
@echo Creating $@ ... |
|
286 |
$(QUIETLY) ( \ |
|
287 |
$(BUILDTREE_COMMENT); \ |
|
288 |
echo; \ |
|
289 |
echo include flags.make; \ |
|
290 |
echo include flags_vm.make; \ |
|
291 |
echo; \ |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
292 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \ |
1 | 293 |
) > $@ |
294 |
||
295 |
adlc.make: $(BUILDTREE_MAKE) |
|
296 |
@echo Creating $@ ... |
|
297 |
$(QUIETLY) ( \ |
|
298 |
$(BUILDTREE_COMMENT); \ |
|
299 |
echo; \ |
|
300 |
echo include flags.make; \ |
|
301 |
echo; \ |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
302 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \ |
1 | 303 |
) > $@ |
304 |
||
305 |
jvmti.make: $(BUILDTREE_MAKE) |
|
306 |
@echo Creating $@ ... |
|
307 |
$(QUIETLY) ( \ |
|
308 |
$(BUILDTREE_COMMENT); \ |
|
309 |
echo; \ |
|
310 |
echo include flags.make; \ |
|
311 |
echo; \ |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
312 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \ |
1 | 313 |
) > $@ |
314 |
||
315 |
sa.make: $(BUILDTREE_MAKE) |
|
316 |
@echo Creating $@ ... |
|
317 |
$(QUIETLY) ( \ |
|
318 |
$(BUILDTREE_COMMENT); \ |
|
319 |
echo; \ |
|
320 |
echo include flags.make; \ |
|
321 |
echo; \ |
|
338
5cf9f61d76f4
6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents:
1
diff
changeset
|
322 |
echo "include \$$(GAMMADIR)/make/$(OS_FAMILY)/makefiles/$(@F)"; \ |
1 | 323 |
) > $@ |
324 |
||
11593 | 325 |
env.sh: $(BUILDTREE_MAKE) |
1 | 326 |
@echo Creating $@ ... |
327 |
$(QUIETLY) ( \ |
|
328 |
$(BUILDTREE_COMMENT); \ |
|
329 |
[ -n "$$JAVA_HOME" ] && { echo ": \$${JAVA_HOME:=$${JAVA_HOME}}"; }; \ |
|
330 |
{ \ |
|
331 |
echo "CLASSPATH=$${CLASSPATH:+$$CLASSPATH:}.:\$${JAVA_HOME}/jre/lib/rt.jar:\$${JAVA_HOME}/jre/lib/i18n.jar"; \ |
|
332 |
} | sed s:$${JAVA_HOME:--------}:\$${JAVA_HOME}:g; \ |
|
333 |
echo "HOTSPOT_BUILD_USER=\"$${LOGNAME:-$$USER} in `basename $(GAMMADIR)`\""; \ |
|
334 |
echo "export JAVA_HOME LD_LIBRARY_PATH CLASSPATH HOTSPOT_BUILD_USER"; \ |
|
335 |
) > $@ |
|
336 |
||
11593 | 337 |
env.csh: env.sh |
1 | 338 |
@echo Creating $@ ... |
339 |
$(QUIETLY) ( \ |
|
340 |
$(BUILDTREE_COMMENT); \ |
|
341 |
[ -n "$$JAVA_HOME" ] && \ |
|
342 |
{ echo "if (! \$$?JAVA_HOME) setenv JAVA_HOME \"$$JAVA_HOME\""; }; \ |
|
343 |
sed -n 's/^\([A-Za-z_][A-Za-z0-9_]*\)=/setenv \1 /p' $?; \ |
|
344 |
) > $@ |
|
345 |
||
7452
b3fa838286de
7006354: Updates to Visual Studio project creation and development launcher
sla
parents:
7403
diff
changeset
|
346 |
jdkpath.sh: $(BUILDTREE_MAKE) |
b3fa838286de
7006354: Updates to Visual Studio project creation and development launcher
sla
parents:
7403
diff
changeset
|
347 |
@echo Creating $@ ... |
b3fa838286de
7006354: Updates to Visual Studio project creation and development launcher
sla
parents:
7403
diff
changeset
|
348 |
$(QUIETLY) ( \ |
b3fa838286de
7006354: Updates to Visual Studio project creation and development launcher
sla
parents:
7403
diff
changeset
|
349 |
$(BUILDTREE_COMMENT); \ |
b3fa838286de
7006354: Updates to Visual Studio project creation and development launcher
sla
parents:
7403
diff
changeset
|
350 |
echo "JDK=${JAVA_HOME}"; \ |
b3fa838286de
7006354: Updates to Visual Studio project creation and development launcher
sla
parents:
7403
diff
changeset
|
351 |
) > $@ |
b3fa838286de
7006354: Updates to Visual Studio project creation and development launcher
sla
parents:
7403
diff
changeset
|
352 |
|
1 | 353 |
.dbxrc: $(BUILDTREE_MAKE) |
354 |
@echo Creating $@ ... |
|
355 |
$(QUIETLY) ( \ |
|
356 |
echo "echo '# Loading $(PLATFORM_DIR)/$(TARGET)/.dbxrc'"; \ |
|
357 |
echo "if [ -f \"\$${HOTSPOT_DBXWARE}\" ]"; \ |
|
358 |
echo "then"; \ |
|
359 |
echo " source \"\$${HOTSPOT_DBXWARE}\""; \ |
|
360 |
echo "elif [ -f \"\$$HOME/.dbxrc\" ]"; \ |
|
361 |
echo "then"; \ |
|
362 |
echo " source \"\$$HOME/.dbxrc\""; \ |
|
363 |
echo "fi"; \ |
|
364 |
) > $@ |
|
365 |
||
366 |
# Skip the test for product builds (which only work when installed in a JDK), to |
|
367 |
# avoid exiting with an error and causing make to halt. |
|
368 |
NO_TEST_MSG = \ |
|
369 |
echo "$@: skipping the test--this build must be tested in a JDK." |
|
370 |
||
371 |
NO_JAVA_HOME_MSG = \ |
|
372 |
echo "JAVA_HOME must be set to run this test." |
|
373 |
||
374 |
DATA_MODE = $(DATA_MODE/$(BUILDARCH)) |
|
375 |
JAVA_FLAG = $(JAVA_FLAG/$(DATA_MODE)) |
|
376 |
||
377 |
DATA_MODE/i486 = 32 |
|
378 |
DATA_MODE/sparc = 32 |
|
379 |
DATA_MODE/sparcv9 = 64 |
|
380 |
DATA_MODE/amd64 = 64 |
|
381 |
DATA_MODE/ia64 = 64 |
|
382 |
||
383 |
# This bit is needed to enable local rebuilds. |
|
384 |
# Unless the makefile itself sets LP64, any environmental |
|
385 |
# setting of LP64 will interfere with the build. |
|
386 |
LP64_SETTING/32 = LP64 = \#empty |
|
387 |
LP64_SETTING/64 = LP64 = 1 |
|
388 |
||
389 |
JAVA_FLAG/32 = -d32 |
|
390 |
JAVA_FLAG/64 = -d64 |
|
391 |
||
392 |
WRONG_DATA_MODE_MSG = \ |
|
11593 | 393 |
echo "JAVA_HOME must point to a $(DATA_MODE)-bit OpenJDK." |
394 |
||
395 |
CROSS_COMPILING_MSG = \ |
|
396 |
echo "Cross compiling for ARCH $(CROSS_COMPILE_ARCH), skipping gamma run." |
|
1 | 397 |
|
778
574c011e95e3
6695777: Queens.class should be built from source, not put in source repo
ohair
parents:
338
diff
changeset
|
398 |
test_gamma: $(BUILDTREE_MAKE) $(GAMMADIR)/make/test/Queens.java |
1 | 399 |
@echo Creating $@ ... |
400 |
$(QUIETLY) ( \ |
|
11593 | 401 |
echo "#!/bin/sh"; \ |
402 |
echo ""; \ |
|
1 | 403 |
$(BUILDTREE_COMMENT); \ |
11593 | 404 |
echo ""; \ |
405 |
echo "# Include environment settings for gamma run"; \ |
|
406 |
echo ""; \ |
|
407 |
echo ". ./env.sh"; \ |
|
408 |
echo ""; \ |
|
409 |
echo "# Do not run gamma test for cross compiles"; \ |
|
410 |
echo ""; \ |
|
411 |
echo "if [ -n \"$(CROSS_COMPILE_ARCH)\" ]; then "; \ |
|
412 |
echo " $(CROSS_COMPILING_MSG)"; \ |
|
413 |
echo " exit 0"; \ |
|
414 |
echo "fi"; \ |
|
415 |
echo ""; \ |
|
416 |
echo "# Make sure JAVA_HOME is set as it is required for gamma"; \ |
|
417 |
echo ""; \ |
|
418 |
echo "if [ -z \"\$${JAVA_HOME}\" ]; then "; \ |
|
419 |
echo " $(NO_JAVA_HOME_MSG)"; \ |
|
420 |
echo " exit 0"; \ |
|
421 |
echo "fi"; \ |
|
422 |
echo ""; \ |
|
423 |
echo "# Check JAVA_HOME version to be used for the test"; \ |
|
424 |
echo ""; \ |
|
425 |
echo "\$${JAVA_HOME}/bin/java $(JAVA_FLAG) -fullversion > /dev/null 2>&1"; \ |
|
426 |
echo "if [ \$$? -ne 0 ]; then "; \ |
|
427 |
echo " $(WRONG_DATA_MODE_MSG)"; \ |
|
428 |
echo " exit 0"; \ |
|
1 | 429 |
echo "fi"; \ |
11593 | 430 |
echo ""; \ |
431 |
echo "# Use gamma_g if it exists"; \ |
|
432 |
echo ""; \ |
|
433 |
echo "GAMMA_PROG=gamma"; \ |
|
434 |
echo "if [ -f gamma_g ]; then "; \ |
|
435 |
echo " GAMMA_PROG=gamma_g"; \ |
|
436 |
echo "fi"; \ |
|
437 |
echo ""; \ |
|
438 |
echo "if [ \"$(OS_VENDOR)\" = \"Darwin\" ]; then "; \ |
|
439 |
echo " # Ensure architecture for gamma and JAVA_HOME is the same."; \ |
|
440 |
echo " # NOTE: gamma assumes the OpenJDK directory layout."; \ |
|
441 |
echo ""; \ |
|
442 |
echo " GAMMA_ARCH=\"\`file \$${GAMMA_PROG} | awk '{print \$$NF}'\`\""; \ |
|
443 |
echo " JVM_LIB=\"\$${JAVA_HOME}/jre/lib/libjava.$(LIBRARY_SUFFIX)\""; \ |
|
444 |
echo " if [ ! -f \$${JVM_LIB} ]; then"; \ |
|
445 |
echo " JVM_LIB=\"\$${JAVA_HOME}/jre/lib/$${LIBARCH}/libjava.$(LIBRARY_SUFFIX)\""; \ |
|
446 |
echo " fi"; \ |
|
447 |
echo " if [ ! -f \$${JVM_LIB} ] || [ -z \"\`file \$${JVM_LIB} | grep \$${GAMMA_ARCH}\`\" ]; then "; \ |
|
448 |
echo " $(WRONG_DATA_MODE_MSG)"; \ |
|
449 |
echo " exit 0"; \ |
|
450 |
echo " fi"; \ |
|
451 |
echo "fi"; \ |
|
452 |
echo ""; \ |
|
453 |
echo "# Compile Queens program for test"; \ |
|
454 |
echo ""; \ |
|
778
574c011e95e3
6695777: Queens.class should be built from source, not put in source repo
ohair
parents:
338
diff
changeset
|
455 |
echo "rm -f Queens.class"; \ |
574c011e95e3
6695777: Queens.class should be built from source, not put in source repo
ohair
parents:
338
diff
changeset
|
456 |
echo "\$${JAVA_HOME}/bin/javac -d . $(GAMMADIR)/make/test/Queens.java"; \ |
11593 | 457 |
echo ""; \ |
458 |
echo "# Set library path solely for gamma launcher test run"; \ |
|
459 |
echo ""; \ |
|
460 |
echo "LD_LIBRARY_PATH=.:$${LD_LIBRARY_PATH:+$$LD_LIBRARY_PATH:}\$${JAVA_HOME}/jre/lib/${LIBARCH}/native_threads:\$${JAVA_HOME}/jre/lib/${LIBARCH}:${GCC_LIB}"; \ |
|
461 |
echo "export LD_LIBRARY_PATH"; \ |
|
462 |
echo "unset LD_LIBRARY_PATH_32"; \ |
|
463 |
echo "unset LD_LIBRARY_PATH_64"; \ |
|
464 |
echo ""; \ |
|
465 |
echo "if [ \"$(OS_VENDOR)\" = \"Darwin\" ]; then "; \ |
|
466 |
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}"; \ |
|
467 |
echo " export DYLD_LIBRARY_PATH"; \ |
|
468 |
echo "fi"; \ |
|
469 |
echo ""; \ |
|
470 |
echo "# Use the gamma launcher and JAVA_HOME to run the test"; \ |
|
471 |
echo ""; \ |
|
472 |
echo "./\$${GAMMA_PROG} $(TESTFLAGS) Queens < /dev/null"; \ |
|
1 | 473 |
) > $@ |
474 |
$(QUIETLY) chmod +x $@ |
|
475 |
||
476 |
FORCE: |
|
477 |
||
478 |
.PHONY: all FORCE |