Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
e4dd400f
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
e4dd400f
编写于
7月 30, 2008
作者:
O
ohair
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6729772: 64-bit build with SS12 compiler: SIGSEGV (0xb) at pc=0x0000000000000048, pid=14826, tid=2
Reviewed-by: tbell
上级
795ad25a
变更
14
显示空白变更内容
内联
并排
Showing
14 changed file
with
240 addition
and
218 deletion
+240
-218
make/common/Defs-linux.gmk
make/common/Defs-linux.gmk
+20
-25
make/common/Defs-solaris.gmk
make/common/Defs-solaris.gmk
+141
-101
make/common/Defs-windows.gmk
make/common/Defs-windows.gmk
+45
-37
make/common/Defs.gmk
make/common/Defs.gmk
+0
-5
make/common/Library.gmk
make/common/Library.gmk
+1
-1
make/common/shared/Defs.gmk
make/common/shared/Defs.gmk
+0
-3
make/java/fdlibm/Makefile
make/java/fdlibm/Makefile
+12
-11
make/java/java_hprof_demo/Makefile
make/java/java_hprof_demo/Makefile
+3
-3
make/sun/awt/Makefile
make/sun/awt/Makefile
+3
-7
make/sun/font/Makefile
make/sun/font/Makefile
+3
-5
make/sun/font/t2k/Makefile
make/sun/font/t2k/Makefile
+3
-5
make/sun/image/generic/Makefile
make/sun/image/generic/Makefile
+3
-4
make/sun/image/vis/Makefile
make/sun/image/vis/Makefile
+3
-7
make/sun/jpeg/Makefile
make/sun/jpeg/Makefile
+3
-4
未找到文件。
make/common/Defs-linux.gmk
浏览文件 @
e4dd400f
...
@@ -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 = $(
P
OPT)
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 = $(
P
OPT)
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
...
...
make/common/Defs-solaris.gmk
浏览文件 @
e4dd400f
...
@@ -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 $(
P
OPT) 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 = $(
P
OPT)
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 = $(
P
OPT)
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
...
...
make/common/Defs-windows.gmk
浏览文件 @
e4dd400f
...
@@ -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_OP
T = -Ox -Gy -Os -GB
CC_
OPT/HIGHES
T = -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_OP
T = -Ox -Gy -Op
CC_
OPT/HIGHES
T = -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_OP
T = -O2 -G6
# Was: CC_
OPT/HIGHES
T = -O2 -G6
# Was: CC_
HIGHER_OPT
= -O2
# Was: CC_
OPT/HIGHER
= -O2
CC_
HIGHEST_OP
T = -O2
CC_
OPT/HIGHES
T = -O2
CC_
HIGHER_OPT
= -O1
CC_
OPT/HIGHER
= -O1
CC_
LOWER_OPT
= -O1
CC_
OPT/LOWER
= -O1
else
else
CC_
HIGHEST_OP
T = -O2 -Op
CC_
OPT/HIGHES
T = -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_OP
T = -O2
CC_
OPT/HIGHES
T = -O2
CC_
HIGHER_OPT
= -O1
CC_
OPT/HIGHER
= -O1
CC_
LOWER_OPT
= -O1
CC_
OPT/LOWER
= -O1
else
else
CC_
HIGHEST_OP
T = -O2
CC_
OPT/HIGHES
T = -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 = $(
P
OPT)
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
...
...
make/common/Defs.gmk
浏览文件 @
e4dd400f
...
@@ -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
#
#
...
...
make/common/Library.gmk
浏览文件 @
e4dd400f
...
@@ -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)
...
...
make/common/shared/Defs.gmk
浏览文件 @
e4dd400f
...
@@ -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.
...
...
make/java/fdlibm/Makefile
浏览文件 @
e4dd400f
...
@@ -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.
#
#
...
...
make/java/java_hprof_demo/Makefile
浏览文件 @
e4dd400f
...
@@ -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
...
...
make/sun/awt/Makefile
浏览文件 @
e4dd400f
...
@@ -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
...
...
make/sun/font/Makefile
浏览文件 @
e4dd400f
...
@@ -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
...
...
make/sun/font/t2k/Makefile
浏览文件 @
e4dd400f
...
@@ -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
...
...
make/sun/image/generic/Makefile
浏览文件 @
e4dd400f
...
@@ -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
...
...
make/sun/image/vis/Makefile
浏览文件 @
e4dd400f
...
@@ -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
...
...
make/sun/jpeg/Makefile
浏览文件 @
e4dd400f
...
@@ -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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录