hotspot/build/solaris/makefiles/sparcWorks.make
changeset 1 489c9b5090e2
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/hotspot/build/solaris/makefiles/sparcWorks.make	Sat Dec 01 00:00:00 2007 +0000
@@ -0,0 +1,495 @@
+#
+# Copyright 1998-2007 Sun Microsystems, Inc.  All Rights Reserved.
+# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+#
+# This code is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License version 2 only, as
+# published by the Free Software Foundation.
+#
+# This code is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+# version 2 for more details (a copy is included in the LICENSE file that
+# accompanied this code).
+#
+# You should have received a copy of the GNU General Public License version
+# 2 along with this work; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+#
+# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+#  
+#
+
+# Compiler-specific flags for sparcworks.
+
+# tell make which C and C++ compilers to use
+CC	= cc
+CPP	= CC
+
+AS	= /usr/ccs/bin/as
+
+NM	= /usr/ccs/bin/nm
+NAWK    = /bin/nawk
+
+REORDER_FLAG = -xF
+
+# Check for the versions of C++ and C compilers ($CPP and $CC) used. 
+
+# Get the last thing on the line that looks like x.x+ (x is a digit).
+COMPILER_REV := \
+$(shell $(CPP) -V 2>&1 | sed -e 's/^.*\([1-9]\.[0-9][0-9]*\).*/\1/')
+C_COMPILER_REV := \
+$(shell $(CC) -V 2>&1 | grep -i "cc:" |  sed -e 's/^.*\([1-9]\.[0-9][0-9]*\).*/\1/')
+
+VALIDATED_COMPILER_REV   := 5.8
+VALIDATED_C_COMPILER_REV := 5.8
+
+ENFORCE_COMPILER_REV${ENFORCE_COMPILER_REV} := ${VALIDATED_COMPILER_REV}
+ifneq (${COMPILER_REV},${ENFORCE_COMPILER_REV})
+dummy_target_to_enforce_compiler_rev:
+	@echo "Wrong ${CPP} version:  ${COMPILER_REV}. " \
+	"Use version ${ENFORCE_COMPILER_REV}, or set" \
+	"ENFORCE_COMPILER_REV=${COMPILER_REV}."
+	@exit 1
+endif
+
+ENFORCE_C_COMPILER_REV${ENFORCE_C_COMPILER_REV} := ${VALIDATED_C_COMPILER_REV}
+ifneq (${C_COMPILER_REV},${ENFORCE_C_COMPILER_REV})
+dummy_target_to_enforce_c_compiler_rev:
+	@echo "Wrong ${CC} version:  ${C_COMPILER_REV}. " \
+	"Use version ${ENFORCE_C_COMPILER_REV}, or set" \
+	"ENFORCE_C_COMPILER_REV=${C_COMPILER_REV}."
+	@exit 1
+endif
+
+# Fail the build if __fabsf is used.  __fabsf exists only in Solaris 8 2/04
+# and newer; objects with a dependency on this symbol will not run on older
+# Solaris 8.
+JVM_FAIL_IF_UNDEFINED = __fabsf
+
+JVM_CHECK_SYMBOLS = $(NM) -u -p $(LIBJVM.o) | \
+	$(NAWK) -v f="${JVM_FAIL_IF_UNDEFINED}" \
+	     'BEGIN    { c=split(f,s); rc=0; } \
+	      /:$$/     { file = $$1; } \
+	      /[^:]$$/  { for(n=1;n<=c;++n) { \
+			   if($$1==s[n]) { \
+			     printf("JVM_CHECK_SYMBOLS: %s contains illegal symbol %s\n", \
+				    file,$$1); \
+			     rc=1; \
+			   } \
+		         } \
+                       } \
+	      END      { exit rc; }'
+
+LINK_LIB.CC/PRE_HOOK += $(JVM_CHECK_SYMBOLS) || exit 1;
+
+# Some interfaces (_lwp_create) changed with LP64 and Solaris 7
+SOLARIS_7_OR_LATER := \
+$(shell uname -r | awk -F. '{ if ($$2 >= 7) print "-DSOLARIS_7_OR_LATER"; }')
+CFLAGS += ${SOLARIS_7_OR_LATER}
+
+ARCHFLAG         = $(ARCHFLAG/$(BUILDARCH))
+# set ARCHFLAG/BUILDARCH which will ultimately be ARCHFLAG
+ifeq ($(TYPE),COMPILER2)
+ARCHFLAG/sparc   = -xarch=v8plus
+else
+ifeq ($(TYPE),TIERED)
+ARCHFLAG/sparc   = -xarch=v8plus
+else
+ARCHFLAG/sparc   = -xarch=v8
+endif
+endif
+ARCHFLAG/sparcv9 = -xarch=v9
+ARCHFLAG/i486  =
+ARCHFLAG/amd64  = -xarch=amd64
+
+# Optional sub-directory in /usr/lib where BUILDARCH libraries are kept.
+ISA_DIR=$(ISA_DIR/$(BUILDARCH))
+ISA_DIR/sparcv9=/sparcv9
+ISA_DIR/amd64=/amd64
+
+# Use these to work around compiler bugs:
+OPT_CFLAGS/SLOWER=-xO3
+OPT_CFLAGS/O2=-xO2
+OPT_CFLAGS/NOOPT=-xO1
+
+#################################################
+# Begin current (>=5.6) Forte compiler options #
+#################################################
+
+ifeq ($(shell expr $(COMPILER_REV) \>= 5.6), 1)
+
+ifeq ("${Platform_arch}", "sparc")
+
+# We MUST allow data alignment of 4 for sparc (sparcv9 is ok at 8s)
+ifndef LP64
+CFLAGS += -xmemalign=4s
+endif
+
+endif
+
+endif
+
+#################################################
+# Begin current (>=5.5) Forte compiler options #
+#################################################
+
+ifeq ($(shell expr $(COMPILER_REV) \>= 5.5), 1)
+
+CFLAGS     += $(ARCHFLAG)
+AOUT_FLAGS += $(ARCHFLAG)
+LIB_FLAGS  += $(ARCHFLAG)
+LFLAGS     += $(ARCHFLAG)
+
+ifeq ("${Platform_arch}", "sparc")
+
+# Flags for Optimization
+
+# [phh] Commented out pending verification that we do indeed want
+#       to potentially bias against u1 and u3 targets.
+#CFLAGS += -xchip=ultra2
+
+OPT_CFLAGS=-xO4 $(EXTRA_OPT_CFLAGS)
+
+endif # sparc
+
+ifeq ("${Platform_arch_model}", "x86_32")
+
+OPT_CFLAGS=-xtarget=pentium $(EXTRA_OPT_CFLAGS)
+
+# UBE (CC 5.5) has bug 4923569 with -xO4
+OPT_CFLAGS+=-xO3
+
+endif # 32bit x86
+
+ifeq ("${Platform_arch_model}", "x86_64")
+
+ASFLAGS += -xarch=amd64
+CFLAGS  += -xarch=amd64
+# this one seemed useless
+LFLAGS_VM  += -xarch=amd64
+# this one worked
+LFLAGS  += -xarch=amd64
+AOUT_FLAGS += -xarch=amd64
+
+# -xO3 is faster than -xO4 on specjbb with SS10 compiler
+OPT_CFLAGS=-xO4 $(EXTRA_OPT_CFLAGS)
+
+endif # 64bit x86
+
+# Inline functions
+CFLAGS += $(GAMMADIR)/src/os_cpu/solaris_${Platform_arch}/vm/solaris_${Platform_arch_model}.il
+
+# no more exceptions
+CFLAGS/NOEX=-features=no%except
+
+# Reduce code bloat by reverting back to 5.0 behavior for static initializers
+CFLAGS += -features=no%split_init
+
+# Use -D_Crun_inline_placement so we don't get references to 
+#    __1c2n6FIpv_0_ or   void*operator new(unsigned,void*)
+#  This avoids the hard requirement of the newer Solaris C++ runtime patches.
+#  NOTE: This is an undocumented feature of the SS10 compiler. See 6306698.
+CFLAGS += -D_Crun_inline_placement
+
+# PIC is safer for SPARC, and is considerably slower
+# a file foo.o which wants to compile -pic can set "PICFLAG/foo.o = -PIC"
+PICFLAG         = -KPIC
+PICFLAG/DEFAULT = $(PICFLAG)
+# [RGV] Need to figure which files to remove to get link to work
+#PICFLAG/BETTER  = -pic
+PICFLAG/BETTER  = $(PICFLAG/DEFAULT)
+PICFLAG/BYFILE  = $(PICFLAG/$@)$(PICFLAG/DEFAULT$(PICFLAG/$@))
+
+# Use $(MAPFLAG:FILENAME=real_file_name) to specify a map file.
+MAPFLAG = -M FILENAME
+
+# Use $(SONAMEFLAG:SONAME=soname) to specify the intrinsic name of a shared obj
+SONAMEFLAG = -h SONAME
+
+# Build shared library
+SHARED_FLAG = -G
+
+# We don't need libCstd.so and librwtools7.so, only libCrun.so
+CFLAGS += -library=%none
+LFLAGS += -library=%none
+
+LFLAGS += -mt
+
+endif	# COMPILER_REV >= VALIDATED_COMPILER_REV
+
+######################################
+# End 5.5 Forte compiler options     #
+######################################
+
+######################################
+# Begin 5.2 Forte compiler options   #
+######################################
+
+ifeq ($(COMPILER_REV), 5.2)
+
+CFLAGS     += $(ARCHFLAG)
+AOUT_FLAGS += $(ARCHFLAG)
+LIB_FLAGS  += $(ARCHFLAG)
+LFLAGS     += $(ARCHFLAG)
+
+ifeq ("${Platform_arch}", "sparc")
+
+# Flags for Optimization
+
+# [phh] Commented out pending verification that we do indeed want
+#       to potentially bias against u1 and u3 targets.
+#CFLAGS += -xchip=ultra2
+
+ifdef LP64
+# SC5.0 tools on v9 are flakey at -xO4
+# [phh] Is this still true for 6.1?
+OPT_CFLAGS=-xO3 $(EXTRA_OPT_CFLAGS)
+else
+OPT_CFLAGS=-xO4 $(EXTRA_OPT_CFLAGS)
+endif
+
+CFLAGS += $(GAMMADIR)/src/os_cpu/solaris_sparc/vm/solaris_sparc.il
+
+endif # sparc
+
+ifeq ("${Platform_arch_model}", "x86_32")
+
+OPT_CFLAGS=-xtarget=pentium $(EXTRA_OPT_CFLAGS)
+
+# SC5.0 tools on x86 are flakey at -xO4
+# [phh] Is this still true for 6.1?
+OPT_CFLAGS+=-xO3
+
+CFLAGS += $(GAMMADIR)/src/os_cpu/solaris_x86/vm/solaris_x86_32.il
+
+endif # 32bit x86
+
+# no more exceptions
+CFLAGS/NOEX=-noex
+
+# Reduce code bloat by reverting back to 5.0 behavior for static initializers
+CFLAGS += -Qoption ccfe -one_static_init
+
+# PIC is safer for SPARC, and is considerably slower
+# a file foo.o which wants to compile -pic can set "PICFLAG/foo.o = -PIC"
+PICFLAG         = -KPIC
+PICFLAG/DEFAULT = $(PICFLAG)
+# [RGV] Need to figure which files to remove to get link to work
+#PICFLAG/BETTER  = -pic
+PICFLAG/BETTER  = $(PICFLAG/DEFAULT)
+PICFLAG/BYFILE  = $(PICFLAG/$@)$(PICFLAG/DEFAULT$(PICFLAG/$@))
+
+# Would be better if these weren't needed, since we link with CC, but
+# at present removing them causes run-time errors
+LFLAGS += -library=Crun
+LIBS   += -library=Crun -lCrun
+
+endif	# COMPILER_REV >= VALIDATED_COMPILER_REV
+
+##################################
+# End 5.2 Forte compiler options #
+##################################
+
+##################################
+# Begin old 5.1 compiler options #
+##################################
+ifeq ($(COMPILER_REV), 5.1)
+
+_JUNK_ := $(shell echo >&2 \
+       "*** ERROR: sparkWorks.make incomplete for 5.1 compiler")
+	@exit 1
+endif
+##################################
+# End old 5.1 compiler options   #
+##################################
+
+##################################
+# Begin old 5.0 compiler options #
+##################################
+
+ifeq	(${COMPILER_REV}, 5.0)
+
+# Had to hoist this higher apparently because of other changes. Must
+# come before -xarch specification.
+CFLAGS += -xtarget=native
+
+CFLAGS     += $(ARCHFLAG)
+AOUT_FLAGS += $(ARCHFLAG)
+LIB_FLAGS  += $(ARCHFLAG)
+LFLAGS     += $(ARCHFLAG)
+
+CFLAGS += -library=iostream
+LFLAGS += -library=iostream  -library=Crun
+LIBS += -library=iostream -library=Crun -lCrun
+
+# Flags for Optimization
+ifdef LP64
+# SC5.0 tools on v9 are flakey at -xO4
+OPT_CFLAGS=-xO3 $(EXTRA_OPT_CFLAGS)
+else
+OPT_CFLAGS=-xO4 $(EXTRA_OPT_CFLAGS)
+endif
+
+ifeq ("${Platform_arch}", "sparc")
+
+CFLAGS += $(GAMMADIR)/src/os_cpu/solaris_sparc/vm/atomic_solaris_sparc.il
+
+endif # sparc
+
+ifeq ("${Platform_arch_model}", "x86_32")
+OPT_CFLAGS=-xtarget=pentium $(EXTRA_OPT_CFLAGS)
+ifeq ("${COMPILER_REV}", "5.0")
+# SC5.0 tools on x86 are flakey at -xO4
+OPT_CFLAGS+=-xO3
+else
+OPT_CFLAGS+=-xO4
+endif
+
+CFLAGS += $(GAMMADIR)/src/os_cpu/solaris_x86/vm/solaris_x86_32.il
+
+endif  # 32bit x86
+
+# The following options run into misaligned ldd problem (raj)
+#OPT_CFLAGS = -fast -O4 -xarch=v8 -xchip=ultra
+
+# no more exceptions
+CFLAGS/NOEX=-noex
+
+# PIC is safer for SPARC, and is considerably slower
+# a file foo.o which wants to compile -pic can set "PICFLAG/foo.o = -PIC"
+PICFLAG         = -PIC
+PICFLAG/DEFAULT = $(PICFLAG)
+# [RGV] Need to figure which files to remove to get link to work
+#PICFLAG/BETTER  = -pic
+PICFLAG/BETTER  = $(PICFLAG/DEFAULT)
+PICFLAG/BYFILE  = $(PICFLAG/$@)$(PICFLAG/DEFAULT$(PICFLAG/$@))
+
+endif	# COMPILER_REV = 5.0
+
+################################
+# End old 5.0 compiler options #
+################################
+
+ifeq ("${COMPILER_REV}", "4.2")
+# 4.2 COMPILERS SHOULD NO LONGER BE USED
+_JUNK_ := $(shell echo >&2 \
+       "*** ERROR: SC4.2 compilers are not supported by this code base!")
+	@exit 1
+endif
+
+# do not include shared lib path in a.outs
+AOUT_FLAGS += -norunpath
+LFLAGS_VM = -norunpath -z noversion
+
+# need position-indep-code for shared libraries
+# (ild appears to get errors on PIC code, so we'll try non-PIC for debug)
+ifeq ($(PICFLAGS),DEFAULT)
+VM_PICFLAG/LIBJVM  = $(PICFLAG/DEFAULT)
+else
+VM_PICFLAG/LIBJVM  = $(PICFLAG/BYFILE)
+endif
+VM_PICFLAG/AOUT    =
+
+VM_PICFLAG = $(VM_PICFLAG/$(LINK_INTO))
+CFLAGS += $(VM_PICFLAG)
+
+# less dynamic linking (no PLTs, please)
+#LIB_FLAGS += $(LINK_MODE)
+# %%%%% despite -znodefs, -Bsymbolic gets link errors -- Rose
+
+LINK_MODE = $(LINK_MODE/$(VERSION))
+LINK_MODE/debug     =
+LINK_MODE/optimized = -Bsymbolic -znodefs
+
+# Have thread local errnos
+ifeq ($(shell expr $(COMPILER_REV) \>= 5.5), 1)
+CFLAGS += -mt
+else
+CFLAGS += -D_REENTRANT
+endif
+
+ifdef CC_INTERP
+# C++ Interpreter
+CFLAGS += -DCC_INTERP
+endif
+
+# Flags for Debugging
+DEBUG_CFLAGS = -g
+FASTDEBUG_CFLAGS = -g0
+# The -g0 setting allows the C++ frontend to inline, which is a big win.
+
+# Enable the following CFLAGS additions if you need to compare the
+# built ELF objects.
+#
+# The -g option makes static data global and the "-Qoption ccfe
+# -xglobalstatic" option tells the compiler to not globalize static
+# data using a unique globalization prefix. Instead force the use of
+# a static globalization prefix based on the source filepath so the
+# objects from two identical compilations are the same.
+#DEBUG_CFLAGS += -Qoption ccfe -xglobalstatic
+#FASTDEBUG_CFLAGS += -Qoption ccfe -xglobalstatic
+
+ifeq	(${COMPILER_REV}, 5.2)
+COMPILER_DATE := $(shell $(CPP) -V 2>&1 | awk '{ print $$NF; }')
+ifeq	(${COMPILER_DATE}, 2001/01/31)
+# disable -g0 in fastdebug since SC6.1 dated 2001/01/31 seems to be buggy
+# use an innocuous value because it will get -g if it's empty
+FASTDEBUG_CFLAGS = -c
+endif
+endif
+
+# Uncomment or 'gmake CFLAGS_BROWSE=-sbfast' to get source browser information.
+# CFLAGS_BROWSE	= -sbfast
+CFLAGS		+= $(CFLAGS_BROWSE)
+
+# ILD is gone as of SS11 (5.8), not supportted in SS10 (5.7)
+ifeq ($(shell expr $(COMPILER_REV) \< 5.7), 1)
+  # use ild when debugging (but when optimizing we want reproducible results)
+  ILDFLAG = $(ILDFLAG/$(VERSION))
+  ILDFLAG/debug     = -xildon
+  ILDFLAG/optimized =
+  AOUT_FLAGS += $(ILDFLAG)
+endif
+
+# Where to put the *.o files (a.out, or shared library)?
+LINK_INTO = $(LINK_INTO/$(VERSION))
+LINK_INTO/debug = LIBJVM
+LINK_INTO/optimized = LIBJVM
+
+# We link the debug version into the a.out because:
+#  1. ild works on a.out but not shared libraries, and using ild
+#     can cut rebuild times by 25% for small changes. (ILD is gone in SS11)
+#  2. dbx cannot gracefully set breakpoints in shared libraries
+#
+
+# apply this setting to link into the shared library even in the debug version:
+ifdef LP64
+LINK_INTO = LIBJVM
+else
+#LINK_INTO = LIBJVM
+endif
+
+MCS	= /usr/ccs/bin/mcs
+STRIP	= /usr/ccs/bin/strip
+
+# Solaris platforms collect lots of redundant file-ident lines,
+# to the point of wasting a significant percentage of file space.
+# (The text is stored in ELF .comment sections, contributed by
+# all "#pragma ident" directives in header and source files.)
+# This command "compresses" the .comment sections simply by
+# removing repeated lines.  The data can be extracted from
+# binaries in the field by using "mcs -p libjvm.so" or the older
+# command "what libjvm.so".
+LINK_LIB.CC/POST_HOOK += $(MCS) -c $@ || exit 1;
+# (The exit 1 is necessary to cause a build failure if the command fails and
+# multiple commands are strung together, and the final semicolon is necessary
+# since the hook must terminate itself as a valid command.)
+
+# Also, strip debug and line number information (worth about 1.7Mb).
+STRIP_LIB.CC/POST_HOOK = $(STRIP) -x $@ || exit 1;
+# STRIP_LIB.CC/POST_HOOK is incorporated into LINK_LIB.CC/POST_HOOK
+# in certain configurations, such as product.make.  Other configurations,
+# such as debug.make, do not include the strip operation.