提交 e4dd400f 编写于 作者: O ohair

6729772: 64-bit build with SS12 compiler: SIGSEGV (0xb) at pc=0x0000000000000048, pid=14826, tid=2

Reviewed-by: tbell
上级 795ad25a
...@@ -86,18 +86,22 @@ HPIS = native ...@@ -86,18 +86,22 @@ HPIS = native
# #
# Default optimization # Default optimization
# #
CC_HIGHEST_OPT = -O3
CC_HIGHER_OPT = -O3
CC_LOWER_OPT = -O2
CC_NO_OPT =
ifeq ($(PRODUCT), java) ifndef OPTIMIZATION_LEVEL
_OPT = $(CC_HIGHER_OPT) ifeq ($(PRODUCT), java)
else OPTIMIZATION_LEVEL = HIGHER
_OPT = $(CC_LOWER_OPT) else
CPPFLAGS_DBG += -DLOGGING OPTIMIZATION_LEVEL = LOWER
endif
endif endif
CC_OPT/NONE =
CC_OPT/LOWER = -O2
CC_OPT/HIGHER = -O3
CC_OPT/HIGHEST = -O3
CC_OPT = $(CC_OPT/$(OPTIMIZATION_LEVEL))
# For all platforms, do not omit the frame pointer register usage. # For all platforms, do not omit the frame pointer register usage.
# We need this frame pointer to make it easy to walk the stacks. # We need this frame pointer to make it easy to walk the stacks.
# This should be the default on X86, but ia64 and amd64 may not have this # This should be the default on X86, but ia64 and amd64 may not have this
...@@ -112,18 +116,6 @@ LDFLAGS_COMMON_sparc += -m32 -mcpu=v9 ...@@ -112,18 +116,6 @@ LDFLAGS_COMMON_sparc += -m32 -mcpu=v9
CFLAGS_REQUIRED = $(CFLAGS_REQUIRED_$(ARCH)) CFLAGS_REQUIRED = $(CFLAGS_REQUIRED_$(ARCH))
LDFLAGS_COMMON += $(LDFLAGS_COMMON_$(ARCH)) LDFLAGS_COMMON += $(LDFLAGS_COMMON_$(ARCH))
# Add in platform specific optimizations for all opt levels
CC_HIGHEST_OPT += $(_OPT_$(ARCH))
CC_HIGHER_OPT += $(_OPT_$(ARCH))
CC_LOWER_OPT += $(_OPT_$(ARCH))
# If NO_OPTIMIZATIONS is defined in the environment, turn all optimzations off
ifdef NO_OPTIMIZATIONS
CC_HIGHEST_OPT = $(CC_NO_OPT)
CC_HIGHER_OPT = $(CC_NO_OPT)
CC_LOWER_OPT = $(CC_NO_OPT)
endif
# #
# Selection of warning messages # Selection of warning messages
# #
...@@ -163,19 +155,19 @@ ifeq ($(FASTDEBUG), true) ...@@ -163,19 +155,19 @@ ifeq ($(FASTDEBUG), true)
endif endif
endif endif
CFLAGS_OPT = $(POPT) CFLAGS_OPT = $(CC_OPT)
CFLAGS_DBG = $(DEBUG_FLAG) CFLAGS_DBG = $(DEBUG_FLAG)
CFLAGS_COMMON += $(CFLAGS_REQUIRED) CFLAGS_COMMON += $(CFLAGS_REQUIRED)
CXXFLAGS_COMMON = $(GLOBAL_KPIC) -DCC_NOEX $(GCC_WARNINGS) CXXFLAGS_COMMON = $(GLOBAL_KPIC) -DCC_NOEX $(GCC_WARNINGS)
CXXFLAGS_OPT = $(POPT) CXXFLAGS_OPT = $(CC_OPT)
CXXFLAGS_DBG = $(DEBUG_FLAG) CXXFLAGS_DBG = $(DEBUG_FLAG)
CXXFLAGS_COMMON += $(CFLAGS_REQUIRED) CXXFLAGS_COMMON += $(CFLAGS_REQUIRED)
# FASTDEBUG: Optimize the code in the -g versions, gives us a faster debug java # FASTDEBUG: Optimize the code in the -g versions, gives us a faster debug java
ifeq ($(FASTDEBUG), true) ifeq ($(FASTDEBUG), true)
CFLAGS_DBG += $(CC_LOWER_OPT) CFLAGS_DBG += $(CC_OPT/LOWER)
CXXFLAGS_DBG += $(CC_LOWER_OPT) CXXFLAGS_DBG += $(CC_OPT/LOWER)
endif endif
CPPFLAGS_COMMON = -D$(ARCH) -DARCH='"$(ARCH)"' -DLINUX $(VERSION_DEFINES) \ CPPFLAGS_COMMON = -D$(ARCH) -DARCH='"$(ARCH)"' -DLINUX $(VERSION_DEFINES) \
...@@ -187,6 +179,9 @@ endif ...@@ -187,6 +179,9 @@ endif
CPPFLAGS_OPT = CPPFLAGS_OPT =
CPPFLAGS_DBG = -DDEBUG CPPFLAGS_DBG = -DDEBUG
ifneq ($(PRODUCT), java)
CPPFLAGS_DBG += -DLOGGING
endif
ifdef LIBRARY ifdef LIBRARY
# Libraries need to locate other libraries at runtime, and you can tell # Libraries need to locate other libraries at runtime, and you can tell
......
...@@ -83,15 +83,16 @@ HPIS = native ...@@ -83,15 +83,16 @@ HPIS = native
# #
# Java default optimization (-x04/-O2) etc. Applies to the VM. # Java default optimization (-x04/-O2) etc. Applies to the VM.
# #
ifeq ($(PRODUCT), java) ifndef OPTIMIZATION_LEVEL
_OPT = $(CC_HIGHER_OPT) ifeq ($(PRODUCT), java)
else OPTIMIZATION_LEVEL = HIGHER
_OPT = $(CC_LOWER_OPT) else
CPPFLAGS_DBG += -DLOGGING -DDBINFO OPTIMIZATION_LEVEL = LOWER
endif
endif endif
# #
# If -Xa is in CFLAGS_COMMON it will end up ahead of $(POPT) for the # If -Xa is in CFLAGS_COMMON it will end up ahead of $(CC_OPT) for the
# optimized build, and that ordering of the flags completely freaks # optimized build, and that ordering of the flags completely freaks
# out cc. Hence, -Xa is instead in each CFLAGS variant. # out cc. Hence, -Xa is instead in each CFLAGS variant.
# #
...@@ -116,8 +117,8 @@ endif ...@@ -116,8 +117,8 @@ endif
# #
# Debug flag for C and C++ compiler # Debug flag for C and C++ compiler
# #
CFLAGS_DEBUG_OPTION=-g CFLAGS_DEBUG_OPTION = -g $(CC_OPT/NONE)
CXXFLAGS_DEBUG_OPTION=-g CXXFLAGS_DEBUG_OPTION = -g $(CXX_OPT/NONE)
# Turn off -g if we are doing tcov build # Turn off -g if we are doing tcov build
ifdef TCOV_BUILD ifdef TCOV_BUILD
...@@ -135,15 +136,14 @@ endif ...@@ -135,15 +136,14 @@ endif
# Performance/size of files should be about the same, maybe smaller. # Performance/size of files should be about the same, maybe smaller.
# #
ifeq ($(FASTDEBUG), true) ifeq ($(FASTDEBUG), true)
CC_FASTDEBUG_OPT = $(CC_LOWER_OPT) CFLAGS_DEBUG_OPTION = -g $(CC_OPT/LOWER)
CFLAGS_DEBUG_OPTION = -g $(CC_FASTDEBUG_OPT) CXXFLAGS_DEBUG_OPTION = -g0 $(CXX_OPT/LOWER)
CXXFLAGS_DEBUG_OPTION = -g0 $(CC_FASTDEBUG_OPT)
endif endif
CFLAGS_COMMON = -v -mt -L$(OBJDIR) -xc99=%none CFLAGS_COMMON = -v -mt -L$(OBJDIR) -xc99=%none
CFLAGS_COMMON += -xCC CFLAGS_COMMON += -xCC
CFLAGS_COMMON += -errshort=tags CFLAGS_COMMON += -errshort=tags
CFLAGS_OPT = $(POPT) CFLAGS_OPT = $(CC_OPT)
CFLAGS_DBG = $(CFLAGS_DEBUG_OPTION) CFLAGS_DBG = $(CFLAGS_DEBUG_OPTION)
CFLAGS_COMMON += -Xa $(CFLAGS_REQUIRED) CFLAGS_COMMON += -Xa $(CFLAGS_REQUIRED)
...@@ -171,7 +171,7 @@ ifeq ($(COMPILER_WARNINGS_FATAL),true) ...@@ -171,7 +171,7 @@ ifeq ($(COMPILER_WARNINGS_FATAL),true)
CXXFLAGS_COMMON += -errwarn=%all CXXFLAGS_COMMON += -errwarn=%all
endif endif
CXXFLAGS_OPT = $(POPT) CXXFLAGS_OPT = $(CXX_OPT)
CXXFLAGS_DBG = $(CXXFLAGS_DEBUG_OPTION) CXXFLAGS_DBG = $(CXXFLAGS_DEBUG_OPTION)
CXXFLAGS_COMMON += $(CFLAGS_REQUIRED) CXXFLAGS_COMMON += $(CFLAGS_REQUIRED)
...@@ -241,6 +241,10 @@ CPPFLAGS_COMMON = -D$(ARCH_FAMILY) -D__solaris__ -D_REENTRANT ...@@ -241,6 +241,10 @@ CPPFLAGS_COMMON = -D$(ARCH_FAMILY) -D__solaris__ -D_REENTRANT
CPPFLAGS_OPT = CPPFLAGS_OPT =
CPPFLAGS_DBG = -DDEBUG CPPFLAGS_DBG = -DDEBUG
ifneq ($(PRODUCT), java)
CPPFLAGS_DBG += -DLOGGING -DDBINFO
endif
ifeq ($(ARCH_FAMILY), i586) ifeq ($(ARCH_FAMILY), i586)
# The macro _LITTLE_ENDIAN needs to be defined the same to avoid the # The macro _LITTLE_ENDIAN needs to be defined the same to avoid the
# Sun C compiler warning message: warning: macro redefined: _LITTLE_ENDIAN # Sun C compiler warning message: warning: macro redefined: _LITTLE_ENDIAN
...@@ -384,63 +388,151 @@ endif ...@@ -384,63 +388,151 @@ endif
# Different "levels" of optimization. # Different "levels" of optimization.
# #
ifeq ($(CC_VERSION),gcc) ifeq ($(CC_VERSION),gcc)
CC_HIGHEST_OPT = -O3
CC_HIGHER_OPT = -O3 CC_OPT/NONE =
CC_LOWER_OPT = -O2 CC_OPT/LOWER = -O2
CC_OPT/HIGHER = -O3
CC_OPT/HIGHEST = -O3
CXX_OPT/NONE =
CXX_OPT/LOWER = -O2
CXX_OPT/HIGHER = -O3
CXX_OPT/HIGHEST = -O3
CFLAGS_REQUIRED_i586 += -fno-omit-frame-pointer CFLAGS_REQUIRED_i586 += -fno-omit-frame-pointer
CFLAGS_REQUIRED_amd64 += -fno-omit-frame-pointer CFLAGS_REQUIRED_amd64 += -fno-omit-frame-pointer
# Automatic precompiled header option to use (if COMPILE_APPROACH=batch) # Automatic precompiled header option to use (if COMPILE_APPROACH=batch)
# (See Rules.gmk) May need to wait for gcc 5? # (See Rules.gmk) May need to wait for gcc 5?
AUTOMATIC_PCH_OPTION = AUTOMATIC_PCH_OPTION =
else else
# Highest could be -xO5, but indications are that -xO5 should be reserved # Highest could be -xO5, but indications are that -xO5 should be reserved
# for a per-file use, on sources with known performance impacts. # for a per-file use, on sources with known performance impacts.
CC_HIGHEST_OPT = -xO4 OPT_LEVEL/LOWER = 2
CC_HIGHER_OPT = -xO4 OPT_LEVEL/HIGHER = 4
CC_LOWER_OPT = -xO2 OPT_LEVEL/HIGHEST = 4
CC_OPT/NONE =
CC_OPT/LOWER = $(OPT_LEVEL/LOWER:%=-xO%)
CC_OPT/HIGHER = $(OPT_LEVEL/HIGHER:%=-xO%)
CC_OPT/HIGHEST = $(OPT_LEVEL/HIGHEST:%=-xO%)
CXX_OPT/NONE =
CXX_OPT/LOWER = $(OPT_LEVEL/LOWER:%=-xO%)
CXX_OPT/HIGHER = $(OPT_LEVEL/HIGHER:%=-xO%)
CXX_OPT/HIGHEST = $(OPT_LEVEL/HIGHEST:%=-xO%)
# We need stack frames at all times
USE_XKEEPFRAME_OPTION = false
ifeq ($(USE_XKEEPFRAME_OPTION),true)
# Unknown spelling on this option at this time (Maybe in SS13?)
CC_XKEEPFRAME_OPTIONS = -xkeepframe
CXX_XKEEPFRAME_OPTIONS = -xkeepframe
else
# On X86, make sure tail call optimization is off
# The z and y are the tail call optimizations.
ifeq ($(ARCH_FAMILY), i586)
ifeq ($(shell $(EXPR) $(CC_VER) \> 5.8), 1)
# Somehow, tail call optimization is creeping in.
# Make sure it is off.
# WARNING: These may cause compiler warnings about duplicate -O options
CC_XKEEPFRAME_OPTIONS += -Wu,-O$(OPT_LEVEL/$(OPTIMIZATION_LEVEL))~yz
CXX_XKEEPFRAME_OPTIONS += -Qoption ube -O$(OPT_LEVEL/$(OPTIMIZATION_LEVEL))~yz
endif
endif
# On i586 we need to tell the code generator to ALWAYS use a
# frame pointer.
ifeq ($(ARCH_FAMILY), i586)
# Note that in 5.7, this is done with -xregs=no%frameptr
ifeq ($(CC_VER), 5.5)
# It's not exactly clear when this optimization kicks in, the
# current assumption is -xO4 or greater and for C++ with
# the -features=no%except option and -xO4 and greater.
# Bottom line is, we ALWAYS want a frame pointer!
CC_XKEEPFRAME_OPTIONS += -Wu,-Z~B
CXX_XKEEPFRAME_OPTIONS += -Qoption ube -Z~B
endif
ifeq ($(shell $(EXPR) $(CC_VER) \> 5.6), 1)
# Do NOT use frame pointer register as a general purpose opt register
CC_OPT/NONE += -xregs=no%frameptr
CXX_OPT/NONE += -xregs=no%frameptr
CC_XKEEPFRAME_OPTIONS += -xregs=no%frameptr
CXX_XKEEPFRAME_OPTIONS += -xregs=no%frameptr
endif
endif
# Optimizer for sparc needs to be told not to do certain things
# related to frames or save instructions.
ifeq ($(ARCH_FAMILY), sparc)
# Do not use save instructions instead of add instructions
# This was an optimization starting in SC5.0 that made it hard for us to
# find the "save" instruction (which got turned into an "add")
CC_XKEEPFRAME_OPTIONS += -Wc,-Qrm-s
CXX_XKEEPFRAME_OPTIONS += -Qoption cg -Qrm-s
# Don't allow tail call code optimization. Started in SC5.0.
# We don't like code of this form:
# save
# <code>
# call foo
# restore
# because we can't tell if the method will have a stack frame
# and register windows or not.
CC_XKEEPFRAME_OPTIONS += -Wc,-Qiselect-T0
CXX_XKEEPFRAME_OPTIONS += -Qoption cg -Qiselect-T0
endif
endif
# Extra options used with HIGHEST
# #
# WARNING: Use of _OPT=$(CC_HIGHEST_OPT) in your Makefile needs to be # WARNING: Use of OPTIMIZATION_LEVEL=HIGHEST in your Makefile needs to be
# done with care, there are some assumptions below that need to # done with care, there are some assumptions below that need to
# be understood about the use of pointers, and IEEE behavior. # be understood about the use of pointers, and IEEE behavior.
# #
# Use non-standard floating point mode (not IEEE 754) # Use non-standard floating point mode (not IEEE 754)
CC_HIGHEST_OPT += -fns CC_HIGHEST_EXTRAS += -fns
# Do some simplification of floating point arithmetic (not IEEE 754) # Do some simplification of floating point arithmetic (not IEEE 754)
CC_HIGHEST_OPT += -fsimple CC_HIGHEST_EXTRAS += -fsimple
# Use single precision floating point with 'float' # Use single precision floating point with 'float'
CC_HIGHEST_OPT += -fsingle CC_HIGHEST_EXTRAS += -fsingle
# Assume memory references via basic pointer types do not alias # Assume memory references via basic pointer types do not alias
# (Source with excessing pointer casting and data access with mixed # (Source with excessing pointer casting and data access with mixed
# pointer types are not recommended) # pointer types are not recommended)
CC_HIGHEST_OPT += -xalias_level=basic CC_HIGHEST_EXTRAS += -xalias_level=basic
# Use intrinsic or inline versions for math/std functions # Use intrinsic or inline versions for math/std functions
# (If you expect perfect errno behavior, do not use this) # (If you expect perfect errno behavior, do not use this)
CC_HIGHEST_OPT += -xbuiltin=%all CC_HIGHEST_EXTRAS += -xbuiltin=%all
# Loop data dependency optimizations (need -xO3 or higher) # Loop data dependency optimizations (need -xO3 or higher)
CC_HIGHEST_OPT += -xdepend CC_HIGHEST_EXTRAS += -xdepend
# Pointer parameters to functions do not overlap # Pointer parameters to functions do not overlap
# (Similar to -xalias_level=basic usage, but less obvious sometimes. # (Similar to -xalias_level=basic usage, but less obvious sometimes.
# If you pass in multiple pointers to the same data, do not use this) # If you pass in multiple pointers to the same data, do not use this)
CC_HIGHEST_OPT += -xrestrict CC_HIGHEST_EXTRAS += -xrestrict
# Inline some library routines # Inline some library routines
# (If you expect perfect errno behavior, do not use this) # (If you expect perfect errno behavior, do not use this)
CC_HIGHEST_OPT += -xlibmil CC_HIGHEST_EXTRAS += -xlibmil
# Use optimized math routines # Use optimized math routines
# (If you expect perfect errno behavior, do not use this) # (If you expect perfect errno behavior, do not use this)
# Can cause undefined external on Solaris 8 X86 on __sincos, removing for now # Can cause undefined external on Solaris 8 X86 on __sincos, removing for now
# CC_HIGHEST_OPT += -xlibmopt # CC_HIGHEST_EXTRAS += -xlibmopt
ifeq ($(ARCH_FAMILY), sparc) ifeq ($(ARCH_FAMILY), sparc)
# Assume at most 8byte alignment, raise SIGBUS on error # Assume at most 8byte alignment, raise SIGBUS on error
### Presents an ABI issue with customer JNI libs? ### Presents an ABI issue with customer JNI libs?
####CC_HIGHEST_OPT += -xmemalign=8s ####CC_HIGHEST_EXTRAS += -xmemalign=8s
# Automatic prefetch instructions, explicit prefetch macros # Automatic prefetch instructions, explicit prefetch macros
CC_HIGHEST_OPT += -xprefetch=auto,explicit CC_HIGHEST_EXTRAS += -xprefetch=auto,explicit
# Pick ultra as the chip to optimize to # Pick ultra as the chip to optimize to
CC_HIGHEST_OPT += -xchip=ultra CC_HIGHEST_EXTRAS += -xchip=ultra
endif endif
ifeq ($(ARCH), i586) ifeq ($(ARCH), i586)
# Pick pentium as the chip to optimize to # Pick pentium as the chip to optimize to
CC_HIGHEST_OPT += -xchip=pentium CC_HIGHEST_EXTRAS += -xchip=pentium
endif endif
ifdef LIBRARY ifdef LIBRARY
# The Solaris CBE (Common Build Environment) requires that the use # The Solaris CBE (Common Build Environment) requires that the use
...@@ -450,9 +542,6 @@ else ...@@ -450,9 +542,6 @@ else
CFLAGS_REQUIRED_sparcv9 += -xregs=no%appl CFLAGS_REQUIRED_sparcv9 += -xregs=no%appl
endif endif
ifeq ($(shell $(EXPR) $(CC_VER) \> 5.6), 1) ifeq ($(shell $(EXPR) $(CC_VER) \> 5.6), 1)
# Do NOT use the frame pointer register as a general purpose opt register
CFLAGS_REQUIRED_i586 += -xregs=no%frameptr
CFLAGS_REQUIRED_amd64 += -xregs=no%frameptr
# We MUST allow data alignment of 4 for sparc V8 (32bit) # We MUST allow data alignment of 4 for sparc V8 (32bit)
# Presents an ABI issue with customer JNI libs? We must be able to # Presents an ABI issue with customer JNI libs? We must be able to
# to handle 4byte aligned objects? (rare occurance, but possible?) # to handle 4byte aligned objects? (rare occurance, but possible?)
...@@ -466,77 +555,28 @@ else ...@@ -466,77 +555,28 @@ else
# Automatic precompiled header option to use (if COMPILE_APPROACH=batch) # Automatic precompiled header option to use (if COMPILE_APPROACH=batch)
# (See Rules.gmk) The SS11 -xpch=auto* options appear to be broken. # (See Rules.gmk) The SS11 -xpch=auto* options appear to be broken.
AUTOMATIC_PCH_OPTION = AUTOMATIC_PCH_OPTION =
endif
CC_NO_OPT =
# If NO_OPTIMIZATIONS is defined in the environment, turn all optimzations off # Add in keep frame options
ifdef NO_OPTIMIZATIONS CC_OPT/LOWER += $(CC_XKEEPFRAME_OPTIONS)
CC_HIGHEST_OPT = $(CC_NO_OPT) CC_OPT/HIGHER += $(CC_XKEEPFRAME_OPTIONS)
CC_HIGHER_OPT = $(CC_NO_OPT) CC_OPT/HIGHEST += $(CC_XKEEPFRAME_OPTIONS)
CC_LOWER_OPT = $(CC_NO_OPT) CXX_OPT/LOWER += $(CXX_XKEEPFRAME_OPTIONS)
CXX_OPT/HIGHER += $(CXX_XKEEPFRAME_OPTIONS)
CXX_OPT/HIGHEST += $(CXX_XKEEPFRAME_OPTIONS)
# Add in highest optimization settings
CC_OPT/HIGHEST += $(CC_HIGHEST_EXTRAS)
CXX_OPT/HIGHEST += $(CC_HIGHEST_EXTRAS)
endif endif
# Default optimization settings based on level.
CC_OPT = $(CC_OPT/$(OPTIMIZATION_LEVEL))
CXX_OPT = $(CXX_OPT/$(OPTIMIZATION_LEVEL))
# Flags required all the time # Flags required all the time
CFLAGS_REQUIRED = $(CFLAGS_REQUIRED_$(ARCH)) CFLAGS_REQUIRED = $(CFLAGS_REQUIRED_$(ARCH))
# Add processor specific options for optimizations
CC_HIGHEST_OPT += $(_OPT_$(ARCH))
CC_HIGHER_OPT += $(_OPT_$(ARCH))
CC_LOWER_OPT += $(_OPT_$(ARCH))
# Secret compiler optimization options that should be in the above macros
# but since they differ in format from C to C++, are added into the C or
# C++ specific macros for compiler flags.
#
# On i586 we need to tell the code generator to ALWAYS use a
# frame pointer.
ifeq ($(ARCH_FAMILY), i586)
# Note that in 5.7, this is done with -xregs=no%frameptr
ifeq ($(CC_VER), 5.5)
# It's not exactly clear when this optimization kicks in, the
# current assumption is -xO4 or greater and for C++ with
# the -features=no%except option and -xO4 and greater.
# Bottom line is, we ALWAYS want a frame pointer!
CXXFLAGS_OPT += -Qoption ube -Z~B
CFLAGS_OPT += -Wu,-Z~B
ifeq ($(FASTDEBUG), true)
CXXFLAGS_DBG += -Qoption ube -Z~B
CFLAGS_DBG += -Wu,-Z~B
endif
endif
endif
#
# Optimizer for sparc needs to be told not to do certain things
# related to frames or save instructions.
ifeq ($(ARCH_FAMILY), sparc)
# NOTE: Someday the compilers will provide a high-level option for this.
# Use save instructions instead of add instructions
# This was an optimization starting in SC5.0 that made it hard for us to
# find the "save" instruction (which got turned into an "add")
CXXFLAGS_OPT += -Qoption cg -Qrm-s
CFLAGS_OPT += -Wc,-Qrm-s
ifeq ($(FASTDEBUG), true)
CXXFLAGS_DBG += -Qoption cg -Qrm-s
CFLAGS_DBG += -Wc,-Qrm-s
endif
#
# NOTE: Someday the compilers will provide a high-level option for this.
# Don't allow tail call code optimization. Started in SC5.0.
# We don't like code of this form:
# save
# <code>
# call foo
# restore
# because we can't tell if the method will have a stack frame
# and register windows or not.
CXXFLAGS_OPT += -Qoption cg -Qiselect-T0
CFLAGS_OPT += -Wc,-Qiselect-T0
ifeq ($(FASTDEBUG), true)
CXXFLAGS_DBG += -Qoption cg -Qiselect-T0
CFLAGS_DBG += -Wc,-Qiselect-T0
endif
endif
# #
# Path and option to link against the VM, if you have to. Note that # Path and option to link against the VM, if you have to. Note that
# there are libraries that link against only -ljava, but they do get # there are libraries that link against only -ljava, but they do get
......
...@@ -84,6 +84,15 @@ EXTRA_LFLAGS += /LIBPATH:$(DXSDK_LIB_PATH) ...@@ -84,6 +84,15 @@ EXTRA_LFLAGS += /LIBPATH:$(DXSDK_LIB_PATH)
# #
# Default optimization # Default optimization
# #
ifndef OPTIMIZATION_LEVEL
ifeq ($(PRODUCT), java)
OPTIMIZATION_LEVEL = HIGHER
else
OPTIMIZATION_LEVEL = LOWER
endif
endif
ifeq ($(CC_VERSION),msvc) ifeq ($(CC_VERSION),msvc)
# Visual Studio .NET 2003 or VS2003 compiler option definitions: # Visual Studio .NET 2003 or VS2003 compiler option definitions:
# -O1 Favors reduced size over speed (-Og -Os -Oy -Ob2 -Gs -GF -Gy) # -O1 Favors reduced size over speed (-Og -Os -Oy -Ob2 -Gs -GF -Gy)
...@@ -113,21 +122,28 @@ ifeq ($(CC_VERSION),msvc) ...@@ -113,21 +122,28 @@ ifeq ($(CC_VERSION),msvc)
# NOTE: With VC6, -Ox, -O1, and -O2 used -Ob1, not -Ob2. # NOTE: With VC6, -Ox, -O1, and -O2 used -Ob1, not -Ob2.
# NOTE: With VC6, -O1 and -O2 used -Gf, not -GF. # NOTE: With VC6, -O1 and -O2 used -Gf, not -GF.
# #
CC_OPT/NONE = -Od
CC_OPT/LOWER = -O2
CC_OPT/HIGHER = -O3
CC_OPT/HIGHEST = -O3
ifeq ($(COMPILER_VERSION), VC6) ifeq ($(COMPILER_VERSION), VC6)
# VC6 (6.2) msvc compiler (the way Tiger and early Mustang were built) # VC6 (6.2) msvc compiler (the way Tiger and early Mustang were built)
# Automatic precompiled header option to use (if COMPILE_APPROACH=batch) # Automatic precompiled header option to use (if COMPILE_APPROACH=batch)
AUTOMATIC_PCH_OPTION = AUTOMATIC_PCH_OPTION =
GX_OPTION = -GX GX_OPTION = -GX
ifeq ($(ARCH_DATA_MODEL), 32) ifeq ($(ARCH_DATA_MODEL), 32)
CC_HIGHEST_OPT = -Ox -Gy -Os -GB CC_OPT/HIGHEST = -Ox -Gy -Os -GB
CC_HIGHER_OPT = -Ox -Gy -Os -GB CC_OPT/HIGHER = -Ox -Gy -Os -GB
CC_LOWER_OPT = -Ox -Gy -Os -GB CC_OPT/LOWER = -Ox -Gy -Os -GB
else else
CC_HIGHEST_OPT = -Ox -Gy -Op CC_OPT/HIGHEST = -Ox -Gy -Op
CC_HIGHER_OPT = -Ox -Gy -Op CC_OPT/HIGHER = -Ox -Gy -Op
CC_LOWER_OPT = -Ox -Gy -Op CC_OPT/LOWER = -Ox -Gy -Op
endif endif
endif endif
ifeq ($(COMPILER_VERSION), VS2003) ifeq ($(COMPILER_VERSION), VS2003)
# Automatic precompiled header option to use (if COMPILE_APPROACH=batch) # Automatic precompiled header option to use (if COMPILE_APPROACH=batch)
AUTOMATIC_PCH_OPTION = -YX AUTOMATIC_PCH_OPTION = -YX
...@@ -135,53 +151,45 @@ ifeq ($(CC_VERSION),msvc) ...@@ -135,53 +151,45 @@ ifeq ($(CC_VERSION),msvc)
GX_OPTION = -GX GX_OPTION = -GX
ifeq ($(ARCH_DATA_MODEL), 32) ifeq ($(ARCH_DATA_MODEL), 32)
# Lowered opt level to try and reduce footprint, dll size especially. # Lowered opt level to try and reduce footprint, dll size especially.
# Was: CC_HIGHEST_OPT = -O2 -G6 # Was: CC_OPT/HIGHEST = -O2 -G6
# Was: CC_HIGHER_OPT = -O2 # Was: CC_OPT/HIGHER = -O2
CC_HIGHEST_OPT = -O2 CC_OPT/HIGHEST = -O2
CC_HIGHER_OPT = -O1 CC_OPT/HIGHER = -O1
CC_LOWER_OPT = -O1 CC_OPT/LOWER = -O1
else else
CC_HIGHEST_OPT = -O2 -Op CC_OPT/HIGHEST = -O2 -Op
CC_HIGHER_OPT = -O2 -Op CC_OPT/HIGHER = -O2 -Op
CC_LOWER_OPT = -O1 -Op CC_OPT/LOWER = -O1 -Op
endif endif
endif endif
ifeq ($(COMPILER_VERSION), VS2005) ifeq ($(COMPILER_VERSION), VS2005)
# Automatic precompiled header option to use (if COMPILE_APPROACH=batch) # Automatic precompiled header option to use (if COMPILE_APPROACH=batch)
AUTOMATIC_PCH_OPTION = AUTOMATIC_PCH_OPTION =
# VS2005 compiler, only with Platform SDK right now? # VS2005 compiler, only with Platform SDK right now?
GX_OPTION = -EHsc GX_OPTION = -EHsc
ifeq ($(ARCH_DATA_MODEL), 32) ifeq ($(ARCH_DATA_MODEL), 32)
CC_HIGHEST_OPT = -O2 CC_OPT/HIGHEST = -O2
CC_HIGHER_OPT = -O1 CC_OPT/HIGHER = -O1
CC_LOWER_OPT = -O1 CC_OPT/LOWER = -O1
else else
CC_HIGHEST_OPT = -O2 CC_OPT/HIGHEST = -O2
CC_HIGHER_OPT = -O1 CC_OPT/HIGHER = -O1
CC_LOWER_OPT = -O1 CC_OPT/LOWER = -O1
endif endif
endif endif
CC_NO_OPT = -Od
else # CC_VERSION else # CC_VERSION
# GCC not supported, but left for historical reference... # GCC not supported, but left for historical reference...
CC_HIGHEST_OPT = -O3 CC_OPT/NONE =
CC_HIGHER_OPT = -O2 CC_OPT/LOWER = -O2
CC_LOWER_OPT = -O2 CC_OPT/HIGHER = -O2
CC_NO_OPT = CC_OPT/HIGHEST = -O3
endif
# If NO_OPTIMIZATIONS is defined in the environment, turn all optimzations off
ifdef NO_OPTIMIZATIONS
CC_HIGHEST_OPT = $(CC_NO_OPT)
CC_HIGHER_OPT = $(CC_NO_OPT)
CC_LOWER_OPT = $(CC_NO_OPT)
endif endif
ifeq ($(PRODUCT), java) CC_OPT = $(CC_OPT/$(OPTIMIZATION_LEVEL))
_OPT = $(CC_HIGHER_OPT)
else
_OPT = $(CC_LOWER_OPT)
endif
# Select the runtime support library carefully, need to be consistent # Select the runtime support library carefully, need to be consistent
# #
...@@ -233,7 +241,7 @@ ifeq ($(CC_VERSION),msvc) ...@@ -233,7 +241,7 @@ ifeq ($(CC_VERSION),msvc)
# Use static link for the C++ runtime (so msvcp71.dll not needed) # Use static link for the C++ runtime (so msvcp71.dll not needed)
# #
CFLAGS_COMMON += -Zi -nologo CFLAGS_COMMON += -Zi -nologo
CFLAGS_OPT = $(POPT) CFLAGS_OPT = $(CC_OPT)
CFLAGS_DBG = -Od $(MS_RUNTIME_DEBUG_OPTION) CFLAGS_DBG = -Od $(MS_RUNTIME_DEBUG_OPTION)
# Starting from VS2005 the wchar_t is handled as a built-in C/C++ data type # Starting from VS2005 the wchar_t is handled as a built-in C/C++ data type
......
...@@ -482,11 +482,6 @@ PKGDIR = $(subst .,/,$(PACKAGE)) ...@@ -482,11 +482,6 @@ PKGDIR = $(subst .,/,$(PACKAGE))
# #
include $(JDK_MAKE_SHARED_DIR)/Defs-java.gmk include $(JDK_MAKE_SHARED_DIR)/Defs-java.gmk
#
# Set opt level to ALT_OPT if set otherwise _OPT
#
POPT = $(_OPT$(ALT_OPT))$(ALT_OPT)
# #
# Convenient macros # Convenient macros
# #
......
...@@ -238,7 +238,7 @@ else # PLATFORM ...@@ -238,7 +238,7 @@ else # PLATFORM
# #
$(ACTUAL_LIBRARY):: $(COMPILE_FILES_o) $(FILES_m) $(FILES_reorder) $(ACTUAL_LIBRARY):: $(COMPILE_FILES_o) $(FILES_m) $(FILES_reorder)
@$(prep-target) @$(prep-target)
@$(ECHO) "STATS: LIBRARY=$(LIBRARY), PRODUCT=$(PRODUCT), _OPT=$(_OPT)" @$(ECHO) "STATS: LIBRARY=$(LIBRARY), PRODUCT=$(PRODUCT), OPTIMIZATION_LEVEL=$(OPTIMIZATION_LEVEL)"
@$(ECHO) "Rebuilding $@ because of $?" @$(ECHO) "Rebuilding $@ because of $?"
ifeq ($(LIBRARY), fdlibm) ifeq ($(LIBRARY), fdlibm)
$(AR) -r $@ $(FILES_o) $(AR) -r $@ $(FILES_o)
......
...@@ -277,9 +277,6 @@ PROMOTED_BUILD_LATEST = latest ...@@ -277,9 +277,6 @@ PROMOTED_BUILD_LATEST = latest
PROMOTED_BUILD_BASEDIR = $(PROMOTED_RE_AREA)/$(PROMOTED_BUILD_LATEST) PROMOTED_BUILD_BASEDIR = $(PROMOTED_RE_AREA)/$(PROMOTED_BUILD_LATEST)
PROMOTED_BUILD_BINARIES = $(PROMOTED_BUILD_BASEDIR)/binaries PROMOTED_BUILD_BINARIES = $(PROMOTED_BUILD_BASEDIR)/binaries
# OPT: Changes what the optimizations settings (in _OPT)
POPT = $(_OPT$(ALT_OPT))$(ALT_OPT)
# PARALLEL_COMPILE_JOBS: is the number of compiles done in parallel. # PARALLEL_COMPILE_JOBS: is the number of compiles done in parallel.
# If the user sets ALT_PARALLEL_COMPILE_JOBS, then COMPILE_APPROACH is set # If the user sets ALT_PARALLEL_COMPILE_JOBS, then COMPILE_APPROACH is set
# to parallel. # to parallel.
......
...@@ -33,6 +33,7 @@ ...@@ -33,6 +33,7 @@
BUILDDIR = ../.. BUILDDIR = ../..
LIBRARY = fdlibm LIBRARY = fdlibm
PRODUCT = java PRODUCT = java
include $(BUILDDIR)/common/Defs.gmk include $(BUILDDIR)/common/Defs.gmk
# #
...@@ -40,16 +41,25 @@ include $(BUILDDIR)/common/Defs.gmk ...@@ -40,16 +41,25 @@ include $(BUILDDIR)/common/Defs.gmk
# #
FDLIBM_SRC = $(SHARE_SRC)/native/java/lang/fdlibm FDLIBM_SRC = $(SHARE_SRC)/native/java/lang/fdlibm
# windows compiler flags # Windows: compiler flags
ifeq ($(PLATFORM),windows) ifeq ($(PLATFORM),windows)
# Turn all optimizations off # Turn all optimizations off
_OPT = $(CC_NO_OPT) OPTIMIZATION_LEVEL = NONE
OTHER_CFLAGS = OTHER_CFLAGS =
CPPFLAGS_DBG += -DLOGGING CPPFLAGS_DBG += -DLOGGING
# Files built here do not compile with warning level 3 if warnings are fatal # Files built here do not compile with warning level 3 if warnings are fatal
COMPILER_WARNINGS_FATAL=false COMPILER_WARNINGS_FATAL=false
endif endif
#
# Linux: Disable optimization to get correctly reproducible
# floating-point results.
#
ifeq ($(PLATFORM),linux)
# Turn all optimizations off
OPTIMIZATION_LEVEL = NONE
endif
# #
# Include path. # Include path.
# #
...@@ -70,15 +80,6 @@ include FILES_c.gmk ...@@ -70,15 +80,6 @@ include FILES_c.gmk
# #
include $(BUILDDIR)/common/Library.gmk include $(BUILDDIR)/common/Library.gmk
#
# Disable optimization to get correctly reproducible
# floating-point results.
#
ifeq ($(PLATFORM),linux)
# Turn all optimizations off
_OPT = $(CC_NO_OPT)
endif
# #
# Find fdlibm source files. # Find fdlibm source files.
# #
......
...@@ -28,14 +28,14 @@ LIBRARY = hprof ...@@ -28,14 +28,14 @@ LIBRARY = hprof
PRODUCT = sun PRODUCT = sun
LIBRARY_OUTPUT = hprof_jvmti LIBRARY_OUTPUT = hprof_jvmti
# Configure the CFLAGS for this library. # Use highest optimization
OPTIMIZATION_LEVEL = HIGHEST
# Configure the CFLAGS for this library.
FILES_m = mapfile-vers FILES_m = mapfile-vers
include $(BUILDDIR)/common/Defs.gmk include $(BUILDDIR)/common/Defs.gmk
_OPT=$(CC_HIGHEST_OPT)
SRCDIR=$(SHARE_SRC)/demo/jvmti/hprof SRCDIR=$(SHARE_SRC)/demo/jvmti/hprof
PSRCDIR=$(PLATFORM_SRC)/demo/jvmti/hprof PSRCDIR=$(PLATFORM_SRC)/demo/jvmti/hprof
......
...@@ -28,17 +28,13 @@ PACKAGE = sun.awt ...@@ -28,17 +28,13 @@ PACKAGE = sun.awt
LIBRARY = awt LIBRARY = awt
PRODUCT = sun PRODUCT = sun
#
# Tell Defs.gmk that VIS is needed # Tell Defs.gmk that VIS is needed
#
VIS_NEEDED=true VIS_NEEDED=true
include $(BUILDDIR)/common/Defs.gmk
#
# Use highest optimization level # Use highest optimization level
# OPTMIZATION_LEVEL = HIGHEST
_OPT = $(CC_HIGHEST_OPT)
include $(BUILDDIR)/common/Defs.gmk
OTHER_CFLAGS += -D__MEDIALIB_OLD_NAMES -D__USE_J2D_NAMES OTHER_CFLAGS += -D__MEDIALIB_OLD_NAMES -D__USE_J2D_NAMES
......
...@@ -35,6 +35,9 @@ PRODUCT = sun ...@@ -35,6 +35,9 @@ PRODUCT = sun
# Indicate we want the C++ compiler to do the linking. # Indicate we want the C++ compiler to do the linking.
CPLUSPLUSLIBRARY=true CPLUSPLUSLIBRARY=true
# Use higher optimization level
OPTIMIZATION_LEVEL = HIGHER
include $(BUILDDIR)/common/Defs.gmk include $(BUILDDIR)/common/Defs.gmk
# #
...@@ -48,11 +51,6 @@ endif ...@@ -48,11 +51,6 @@ endif
# Files # Files
# #
#
# Use higher optimization level
#
_OPT = $(CC_HIGHER_OPT)
include FILES_c.gmk include FILES_c.gmk
AUTO_FILES_JAVA_DIRS = sun/font AUTO_FILES_JAVA_DIRS = sun/font
......
...@@ -41,12 +41,10 @@ CPLUSPLUSLIBRARY=true ...@@ -41,12 +41,10 @@ CPLUSPLUSLIBRARY=true
# for a few ones with native methods) so shouldn't clobber them. # for a few ones with native methods) so shouldn't clobber them.
DONT_CLOBBER_CLASSES=true DONT_CLOBBER_CLASSES=true
include $(BUILDDIR)/common/Defs.gmk
#
# Use higher optimization level # Use higher optimization level
# OPTIMIZATION_LEVEL = HIGHER
_OPT = $(CC_HIGHER_OPT)
include $(BUILDDIR)/common/Defs.gmk
# #
# Files # Files
......
...@@ -31,12 +31,11 @@ BUILDDIR = ../../.. ...@@ -31,12 +31,11 @@ BUILDDIR = ../../..
PACKAGE = sun.awt.medialib PACKAGE = sun.awt.medialib
LIBRARY = mlib_image LIBRARY = mlib_image
PRODUCT = sun PRODUCT = sun
include $(BUILDDIR)/common/Defs.gmk
#
# Use highest level of optimization on this library # Use highest level of optimization on this library
# OPTIMIZATION_LEVEL = HIGHEST
_OPT = $(CC_HIGHEST_OPT)
include $(BUILDDIR)/common/Defs.gmk
# #
# Use mapfile # Use mapfile
......
...@@ -31,17 +31,13 @@ PACKAGE = sun.awt.medialib ...@@ -31,17 +31,13 @@ PACKAGE = sun.awt.medialib
LIBRARY = mlib_image_v LIBRARY = mlib_image_v
PRODUCT = sun PRODUCT = sun
#
# Tell Defs.gmk we need VIS instructions # Tell Defs.gmk we need VIS instructions
#
VIS_NEEDED=true VIS_NEEDED=true
include $(BUILDDIR)/common/Defs.gmk
#
# Select highest level of optimization for this library # Select highest level of optimization for this library
# OPTIMIZATION_LEVEL = HIGHEST
_OPT = $(CC_HIGHEST_OPT)
include $(BUILDDIR)/common/Defs.gmk
# #
# Use generic mapfile # Use generic mapfile
......
...@@ -27,12 +27,11 @@ BUILDDIR = ../.. ...@@ -27,12 +27,11 @@ BUILDDIR = ../..
PACKAGE = sun.awt PACKAGE = sun.awt
LIBRARY = jpeg LIBRARY = jpeg
PRODUCT = sun PRODUCT = sun
include $(BUILDDIR)/common/Defs.gmk
#
# Use highest optimization level # Use highest optimization level
# OPTIMIZATION_LEVEL = HIGHEST
_OPT = $(CC_HIGHEST_OPT)
include $(BUILDDIR)/common/Defs.gmk
# #
# Files # Files
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册