Print this page
rev 6314 : 8030011: Update Hotspot version string output
Reviewed-by: dholmes, jcoomes, kvn
Split |
Split |
Close |
Expand all |
Collapse all |
--- old/make/solaris/makefiles/vm.make
+++ new/make/solaris/makefiles/vm.make
1 1 #
2 2 # Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved.
3 3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 4 #
5 5 # This code is free software; you can redistribute it and/or modify it
6 6 # under the terms of the GNU General Public License version 2 only, as
7 7 # published by the Free Software Foundation.
8 8 #
9 9 # This code is distributed in the hope that it will be useful, but WITHOUT
10 10 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 11 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 12 # version 2 for more details (a copy is included in the LICENSE file that
13 13 # accompanied this code).
14 14 #
15 15 # You should have received a copy of the GNU General Public License version
16 16 # 2 along with this work; if not, write to the Free Software Foundation,
17 17 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 18 #
19 19 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 20 # or visit www.oracle.com if you need additional information or have any
21 21 # questions.
22 22 #
23 23 #
24 24
25 25 # Rules to build JVM and related libraries, included from vm.make in the build
26 26 # directory.
27 27
28 28 # Common build rules.
29 29 MAKEFILES_DIR=$(GAMMADIR)/make/$(Platform_os_family)/makefiles
30 30 include $(MAKEFILES_DIR)/rules.make
31 31 include $(GAMMADIR)/make/altsrc.make
32 32
33 33 default: build
34 34
35 35 #----------------------------------------------------------------------
36 36 # Defs
37 37
38 38 GENERATED = ../generated
39 39 DEP_DIR = $(GENERATED)/dependencies
40 40
41 41 # reads the generated files defining the set of .o's and the .o .h dependencies
42 42 -include $(DEP_DIR)/*.d
43 43
44 44 # read machine-specific adjustments (%%% should do this via buildtree.make?)
45 45 include $(MAKEFILES_DIR)/$(BUILDARCH).make
46 46
47 47 # set VPATH so make knows where to look for source files
48 48 # Src_Dirs_V is everything in src/share/vm/*, plus the right os/*/vm and cpu/*/vm
49 49 # The adfiles directory contains ad_<arch>.[ch]pp.
50 50 # The jvmtifiles directory contains jvmti*.[ch]pp
51 51 Src_Dirs_V += $(GENERATED)/adfiles $(GENERATED)/jvmtifiles $(GENERATED)/tracefiles
52 52 VPATH += $(Src_Dirs_V:%=%:)
53 53
54 54 # set INCLUDES for C preprocessor
55 55 Src_Dirs_I += $(GENERATED)
56 56 INCLUDES += $(Src_Dirs_I:%=-I%)
57 57
58 58 # SYMFLAG is used by {dtrace,jsig,saproc}.make.
59 59 ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1)
60 60 # always build with debug info when we can create .debuginfo files
61 61 # and disable 'lazy debug info' so the .so has everything.
↓ open down ↓ |
61 lines elided |
↑ open up ↑ |
62 62 SYMFLAG = -g -xs
63 63 else
64 64 ifeq (${VERSION}, debug)
65 65 SYMFLAG = -g
66 66 else
67 67 SYMFLAG =
68 68 endif
69 69 endif
70 70
71 71 # The following variables are defined in the generated flags.make file.
72 -BUILD_VERSION = -DHOTSPOT_RELEASE_VERSION="\"$(HS_BUILD_VER)\""
73 -JRE_VERSION = -DJRE_RELEASE_VERSION="\"$(JRE_RELEASE_VER)\""
72 +JDK_VER_DEFS = -DJDK_MAJOR_VERSION="\"$(JDK_MAJOR_VERSION)\"" \
73 + -DJDK_MINOR_VERSION="\"$(JDK_MINOR_VERSION)\"" \
74 + -DJDK_MICRO_VERSION="\"$(JDK_MICRO_VERSION)\"" \
75 + -DJDK_BUILD_NUMBER="\"$(JDK_BUILD_NUMBER)\""
76 +VM_VER_DEFS = -DHOTSPOT_RELEASE_VERSION="\"$(HS_BUILD_VER)\"" \
77 + -DJRE_RELEASE_VERSION="\"$(JRE_RELEASE_VER)\"" \
78 + $(JDK_VER_DEFS)
74 79 HS_LIB_ARCH = -DHOTSPOT_LIB_ARCH=\"$(LIBARCH)\"
75 80 BUILD_TARGET = -DHOTSPOT_BUILD_TARGET="\"$(TARGET)\""
76 81 BUILD_USER = -DHOTSPOT_BUILD_USER="\"$(HOTSPOT_BUILD_USER)\""
77 82 VM_DISTRO = -DHOTSPOT_VM_DISTRO="\"$(HOTSPOT_VM_DISTRO)\""
78 83
79 84 CXXFLAGS = \
80 85 ${SYSDEFS} \
81 86 ${INCLUDES} \
82 - ${BUILD_VERSION} \
83 87 ${BUILD_TARGET} \
84 88 ${BUILD_USER} \
85 89 ${HS_LIB_ARCH} \
86 90 ${VM_DISTRO}
87 91
88 92 # This is VERY important! The version define must only be supplied to vm_version.o
89 93 # If not, ccache will not re-use the cache at all, since the version string might contain
90 94 # a time and date.
91 -CXXFLAGS/vm_version.o += ${JRE_VERSION}
95 +CXXFLAGS/vm_version.o += ${VM_VER_DEFS}
92 96
93 97 CXXFLAGS/BYFILE = $(CXXFLAGS/$@)
94 98
95 99 # File specific flags
96 100 CXXFLAGS += $(CXXFLAGS/BYFILE)
97 101
98 102 # Large File Support
99 103 ifneq ($(LP64), 1)
100 104 CXXFLAGS/ostream.o += -D_FILE_OFFSET_BITS=64
101 105 endif # ifneq ($(LP64), 1)
102 106
103 107 # CFLAGS_WARN holds compiler options to suppress/enable warnings.
104 108 CFLAGS += $(CFLAGS_WARN)
105 109
106 110 # Do not use C++ exception handling
107 111 CFLAGS += $(CFLAGS/NOEX)
108 112
109 113 # Extra flags from gnumake's invocation or environment
110 114 CFLAGS += $(EXTRA_CFLAGS)
111 115
112 116 # Math Library (libm.so), do not use -lm.
113 117 # There might be two versions of libm.so on the build system:
114 118 # libm.so.1 and libm.so.2, and we want libm.so.1.
115 119 # Depending on the Solaris release being used to build with,
116 120 # /usr/lib/libm.so could point at a libm.so.2, so we are
117 121 # explicit here so that the libjvm.so you have built will work on an
118 122 # older Solaris release that might not have libm.so.2.
119 123 # This is a critical factor in allowing builds on Solaris 10 or newer
120 124 # to run on Solaris 8 or 9.
121 125 #
122 126 LIBM=/usr/lib$(ISA_DIR)/libm.so.1
123 127
124 128 ifeq ("${Platform_compiler}", "sparcWorks")
125 129 # The whole megilla:
126 130 ifeq ($(shell expr $(COMPILER_REV_NUMERIC) \>= 505), 1)
127 131 # Old Comment: List the libraries in the order the compiler was designed for
128 132 # Not sure what the 'designed for' comment is referring too above.
129 133 # The order may not be too significant anymore, but I have placed this
130 134 # older libm before libCrun, just to make sure it's found and used first.
131 135 LIBS += -lsocket -lsched -ldl $(LIBM) -lCrun -lthread -ldoor -lc -ldemangle
132 136 else
133 137 ifeq ($(COMPILER_REV_NUMERIC), 502)
134 138 # SC6.1 has it's own libm.so: specifying anything else provokes a name conflict.
135 139 LIBS += -ldl -lthread -lsocket -lm -lsched -ldoor -ldemangle
136 140 else
137 141 LIBS += -ldl -lthread -lsocket $(LIBM) -lsched -ldoor -ldemangle
138 142 endif # 502
139 143 endif # 505
140 144 else
141 145 LIBS += -lsocket -lsched -ldl $(LIBM) -lthread -lc -ldemangle
142 146 endif # sparcWorks
143 147
144 148 LIBS += -lkstat
145 149
146 150 # By default, link the *.o into the library, not the executable.
147 151 LINK_INTO$(LINK_INTO) = LIBJVM
148 152
149 153 JDK_LIBDIR = $(JAVA_HOME)/jre/lib/$(LIBARCH)
150 154
151 155 #----------------------------------------------------------------------
152 156 # jvm_db & dtrace
153 157 include $(MAKEFILES_DIR)/dtrace.make
154 158
155 159 #----------------------------------------------------------------------
156 160 # add_gnu_debuglink tool
157 161 include $(MAKEFILES_DIR)/add_gnu_debuglink.make
158 162
159 163 #----------------------------------------------------------------------
160 164 # fix_empty_sec_hdr_flags tool
161 165 include $(MAKEFILES_DIR)/fix_empty_sec_hdr_flags.make
162 166
163 167 #----------------------------------------------------------------------
164 168 # JVM
165 169
166 170 JVM = jvm
167 171 LIBJVM = lib$(JVM).so
168 172
169 173 LIBJVM_DEBUGINFO = lib$(JVM).debuginfo
170 174 LIBJVM_DIZ = lib$(JVM).diz
171 175
172 176 SPECIAL_PATHS:=adlc c1 dist gc_implementation opto shark libadt
173 177
174 178 SOURCE_PATHS=\
175 179 $(shell find $(HS_COMMON_SRC)/share/vm/* -type d \! \
176 180 \( -name DUMMY $(foreach dir,$(SPECIAL_PATHS),-o -name $(dir)) \))
177 181 SOURCE_PATHS+=$(HS_COMMON_SRC)/os/$(Platform_os_family)/vm
178 182 SOURCE_PATHS+=$(HS_COMMON_SRC)/os/posix/vm
179 183 SOURCE_PATHS+=$(HS_COMMON_SRC)/cpu/$(Platform_arch)/vm
180 184 SOURCE_PATHS+=$(HS_COMMON_SRC)/os_cpu/$(Platform_os_arch)/vm
181 185
182 186 CORE_PATHS=$(foreach path,$(SOURCE_PATHS),$(call altsrc,$(path)) $(path))
183 187 CORE_PATHS+=$(GENERATED)/jvmtifiles $(GENERATED)/tracefiles
184 188
185 189 ifneq ($(INCLUDE_TRACE), false)
186 190 CORE_PATHS+=$(shell if [ -d $(HS_ALT_SRC)/share/vm/jfr ]; then \
187 191 find $(HS_ALT_SRC)/share/vm/jfr -type d; \
188 192 fi)
189 193 endif
190 194
191 195 COMPILER1_PATHS := $(call altsrc,$(HS_COMMON_SRC)/share/vm/c1)
192 196 COMPILER1_PATHS += $(HS_COMMON_SRC)/share/vm/c1
193 197
194 198 COMPILER2_PATHS := $(call altsrc,$(HS_COMMON_SRC)/share/vm/opto)
195 199 COMPILER2_PATHS += $(call altsrc,$(HS_COMMON_SRC)/share/vm/libadt)
196 200 COMPILER2_PATHS += $(HS_COMMON_SRC)/share/vm/opto
197 201 COMPILER2_PATHS += $(HS_COMMON_SRC)/share/vm/libadt
198 202 COMPILER2_PATHS += $(GENERATED)/adfiles
199 203
200 204 # Include dirs per type.
201 205 Src_Dirs/CORE := $(CORE_PATHS)
202 206 Src_Dirs/COMPILER1 := $(CORE_PATHS) $(COMPILER1_PATHS)
203 207 Src_Dirs/COMPILER2 := $(CORE_PATHS) $(COMPILER2_PATHS)
204 208 Src_Dirs/TIERED := $(CORE_PATHS) $(COMPILER1_PATHS) $(COMPILER2_PATHS)
205 209 Src_Dirs/ZERO := $(CORE_PATHS)
206 210 Src_Dirs/SHARK := $(CORE_PATHS)
207 211 Src_Dirs := $(Src_Dirs/$(TYPE))
208 212
209 213 COMPILER2_SPECIFIC_FILES := opto libadt bcEscapeAnalyzer.cpp c2_\* runtime_\*
210 214 COMPILER1_SPECIFIC_FILES := c1_\*
211 215 SHARK_SPECIFIC_FILES := shark
212 216 ZERO_SPECIFIC_FILES := zero
213 217
214 218 # Always exclude these.
215 219 Src_Files_EXCLUDE := dtrace jsig.c jvmtiEnvRecommended.cpp jvmtiEnvStub.cpp
216 220
217 221 # Exclude per type.
218 222 Src_Files_EXCLUDE/CORE := $(COMPILER1_SPECIFIC_FILES) $(COMPILER2_SPECIFIC_FILES) $(ZERO_SPECIFIC_FILES) $(SHARK_SPECIFIC_FILES) ciTypeFlow.cpp
219 223 Src_Files_EXCLUDE/COMPILER1 := $(COMPILER2_SPECIFIC_FILES) $(ZERO_SPECIFIC_FILES) $(SHARK_SPECIFIC_FILES) ciTypeFlow.cpp
220 224 Src_Files_EXCLUDE/COMPILER2 := $(COMPILER1_SPECIFIC_FILES) $(ZERO_SPECIFIC_FILES) $(SHARK_SPECIFIC_FILES)
221 225 Src_Files_EXCLUDE/TIERED := $(ZERO_SPECIFIC_FILES) $(SHARK_SPECIFIC_FILES)
222 226 Src_Files_EXCLUDE/ZERO := $(COMPILER1_SPECIFIC_FILES) $(COMPILER2_SPECIFIC_FILES) $(SHARK_SPECIFIC_FILES) ciTypeFlow.cpp
223 227 Src_Files_EXCLUDE/SHARK := $(COMPILER1_SPECIFIC_FILES) $(COMPILER2_SPECIFIC_FILES) $(ZERO_SPECIFIC_FILES)
224 228
225 229 Src_Files_EXCLUDE += $(Src_Files_EXCLUDE/$(TYPE))
226 230
227 231 # Special handling of arch model.
228 232 ifeq ($(Platform_arch_model), x86_32)
229 233 Src_Files_EXCLUDE += \*x86_64\*
230 234 endif
231 235 ifeq ($(Platform_arch_model), x86_64)
232 236 Src_Files_EXCLUDE += \*x86_32\*
233 237 endif
234 238
235 239 # Locate all source files in the given directory, excluding files in Src_Files_EXCLUDE.
236 240 define findsrc
237 241 $(notdir $(shell find $(1)/. ! -name . -prune \
238 242 -a \( -name \*.c -o -name \*.cpp -o -name \*.s \) \
239 243 -a ! \( -name DUMMY $(addprefix -o -name ,$(Src_Files_EXCLUDE)) \)))
240 244 endef
241 245
242 246 Src_Files := $(foreach e,$(Src_Dirs),$(call findsrc,$(e)))
243 247
244 248 Obj_Files = $(sort $(addsuffix .o,$(basename $(Src_Files))))
245 249
246 250 JVM_OBJ_FILES = $(Obj_Files) $(DTRACE_OBJS)
247 251
248 252 vm_version.o: $(filter-out vm_version.o,$(JVM_OBJ_FILES))
249 253
250 254 mapfile : $(MAPFILE) $(MAPFILE_DTRACE_OPT) vm.def
251 255 rm -f $@
252 256 cat $(MAPFILE) $(MAPFILE_DTRACE_OPT) \
253 257 | $(NAWK) '{ \
254 258 if ($$0 ~ "INSERT VTABLE SYMBOLS HERE") { \
255 259 system ("cat vm.def"); \
256 260 } else { \
257 261 print $$0; \
258 262 } \
259 263 }' > $@
260 264
261 265 mapfile_extended : mapfile $(MAPFILE_DTRACE_OPT)
262 266 rm -f $@
263 267 cat $^ > $@
264 268
265 269 vm.def: $(Obj_Files)
266 270 sh $(GAMMADIR)/make/solaris/makefiles/build_vm_def.sh *.o > $@
267 271
268 272 ifeq ($(LINK_INTO),AOUT)
269 273 LIBJVM.o =
270 274 LIBJVM_MAPFILE =
271 275 LIBS_VM = $(LIBS)
272 276 else
273 277 LIBJVM.o = $(JVM_OBJ_FILES)
274 278 LIBJVM_MAPFILE$(LDNOMAP) = mapfile_extended
275 279 LFLAGS_VM$(LDNOMAP) += $(MAPFLAG:FILENAME=$(LIBJVM_MAPFILE))
276 280 LFLAGS_VM += $(SONAMEFLAG:SONAME=$(LIBJVM))
277 281 ifndef USE_GCC
278 282 LIBS_VM = $(LIBS)
279 283 else
280 284 # JVM is statically linked with libgcc[_s] and libstdc++; this is needed to
281 285 # get around library dependency and compatibility issues. Must use gcc not
282 286 # g++ to link.
283 287 LFLAGS_VM += $(STATIC_LIBGCC)
284 288 LIBS_VM += $(STATIC_STDCXX) $(LIBS)
285 289 endif
286 290 endif
287 291
288 292 ifdef USE_GCC
289 293 LINK_VM = $(LINK_LIB.CC)
290 294 else
291 295 LINK_VM = $(LINK_LIB.CXX)
292 296 endif
293 297 # making the library:
294 298 $(LIBJVM): $(ADD_GNU_DEBUGLINK) $(FIX_EMPTY_SEC_HDR_FLAGS) $(LIBJVM.o) $(LIBJVM_MAPFILE)
295 299 ifeq ($(filter -sbfast -xsbfast, $(CFLAGS_BROWSE)),)
296 300 @echo Linking vm...
297 301 $(QUIETLY) $(LINK_LIB.CXX/PRE_HOOK)
298 302 $(QUIETLY) $(LINK_VM) $(LFLAGS_VM) -o $@ $(sort $(LIBJVM.o)) $(LIBS_VM)
299 303 $(QUIETLY) $(LINK_LIB.CXX/POST_HOOK)
300 304 $(QUIETLY) rm -f $@.1 && ln -s $@ $@.1
301 305 ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1)
302 306 # gobjcopy crashes on "empty" section headers with the SHF_ALLOC flag set.
303 307 # Clear the SHF_ALLOC flag (if set) from empty section headers.
304 308 # An empty section header has sh_addr == 0 and sh_size == 0.
305 309 # This problem has only been seen on Solaris X64, but we call this tool
306 310 # on all Solaris builds just in case.
307 311 $(QUIETLY) $(FIX_EMPTY_SEC_HDR_FLAGS) $@
308 312 $(QUIETLY) $(OBJCOPY) --only-keep-debug $@ $(LIBJVM_DEBUGINFO)
309 313 # $(OBJCOPY) --add-gnu-debuglink=... corrupts SUNW_* sections.
310 314 # Use $(ADD_GNU_DEBUGLINK) until a fixed $(OBJCOPY) is available.
311 315 # $(QUIETLY) $(OBJCOPY) --add-gnu-debuglink=$(LIBJVM_DEBUGINFO) $@
312 316 $(QUIETLY) $(ADD_GNU_DEBUGLINK) $(LIBJVM_DEBUGINFO) $@
313 317 ifeq ($(STRIP_POLICY),all_strip)
314 318 $(QUIETLY) $(STRIP) $@
315 319 else
316 320 ifeq ($(STRIP_POLICY),min_strip)
317 321 $(QUIETLY) $(STRIP) -x $@
318 322 # implied else here is no stripping at all
319 323 endif
320 324 endif
321 325 ifeq ($(ZIP_DEBUGINFO_FILES),1)
322 326 $(ZIPEXE) -q -y $(LIBJVM_DIZ) $(LIBJVM_DEBUGINFO)
323 327 $(RM) $(LIBJVM_DEBUGINFO)
324 328 endif
325 329 endif
326 330 endif # filter -sbfast -xsbfast
327 331
328 332
329 333 DEST_SUBDIR = $(JDK_LIBDIR)/$(VM_SUBDIR)
330 334 DEST_JVM = $(DEST_SUBDIR)/$(LIBJVM)
331 335 DEST_JVM_DEBUGINFO = $(DEST_SUBDIR)/$(LIBJVM_DEBUGINFO)
332 336 DEST_JVM_DIZ = $(DEST_SUBDIR)/$(LIBJVM_DIZ)
333 337
334 338 install_jvm: $(LIBJVM)
335 339 @echo "Copying $(LIBJVM) to $(DEST_JVM)"
336 340 $(QUIETLY) test ! -f $(LIBJVM_DEBUGINFO) || \
337 341 cp -f $(LIBJVM_DEBUGINFO) $(DEST_JVM_DEBUGINFO)
338 342 $(QUIETLY) test ! -f $(LIBJVM_DIZ) || \
339 343 cp -f $(LIBJVM_DIZ) $(DEST_JVM_DIZ)
340 344 $(QUIETLY) cp -f $(LIBJVM) $(DEST_JVM) && echo "Done"
341 345
342 346 #----------------------------------------------------------------------
343 347 # Other files
344 348
345 349 # Signal interposition library
346 350 include $(MAKEFILES_DIR)/jsig.make
347 351
348 352 # Serviceability agent
349 353 include $(MAKEFILES_DIR)/saproc.make
350 354
351 355 #----------------------------------------------------------------------
352 356
353 357 build: $(LIBJVM) $(LAUNCHER) $(LIBJSIG) $(LIBJVM_DB) $(LIBJVM_DTRACE) $(BUILDLIBSAPROC) dtraceCheck
354 358
355 359 install: install_jvm install_jsig install_saproc
356 360
357 361 .PHONY: default build install install_jvm
↓ open down ↓ |
256 lines elided |
↑ open up ↑ |
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX