Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
06e5d445
D
dragonwell8_hotspot
项目概览
openanolis
/
dragonwell8_hotspot
通知
2
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_hotspot
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
06e5d445
编写于
10月 23, 2014
作者:
A
amurillo
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
2f258210
efa8e575
变更
22
显示空白变更内容
内联
并排
Showing
22 changed file
with
446 addition
and
245 deletion
+446
-245
make/excludeSrc.make
make/excludeSrc.make
+1
-0
make/hotspot_version
make/hotspot_version
+1
-1
make/jprt.properties
make/jprt.properties
+14
-10
src/cpu/x86/vm/vm_version_x86.cpp
src/cpu/x86/vm/vm_version_x86.cpp
+7
-2
src/share/vm/classfile/classFileParser.cpp
src/share/vm/classfile/classFileParser.cpp
+6
-2
src/share/vm/opto/doCall.cpp
src/share/vm/opto/doCall.cpp
+10
-4
src/share/vm/prims/whitebox.cpp
src/share/vm/prims/whitebox.cpp
+31
-1
src/share/vm/runtime/os.hpp
src/share/vm/runtime/os.hpp
+8
-7
src/share/vm/services/mallocTracker.cpp
src/share/vm/services/mallocTracker.cpp
+2
-15
src/share/vm/services/mallocTracker.hpp
src/share/vm/services/mallocTracker.hpp
+0
-20
src/share/vm/services/memBaseline.hpp
src/share/vm/services/memBaseline.hpp
+1
-6
src/share/vm/services/memReporter.hpp
src/share/vm/services/memReporter.hpp
+0
-14
src/share/vm/services/memTracker.cpp
src/share/vm/services/memTracker.cpp
+19
-30
src/share/vm/services/memTracker.hpp
src/share/vm/services/memTracker.hpp
+16
-7
src/share/vm/services/virtualMemoryTracker.cpp
src/share/vm/services/virtualMemoryTracker.cpp
+13
-11
src/share/vm/services/virtualMemoryTracker.hpp
src/share/vm/services/virtualMemoryTracker.hpp
+0
-15
src/share/vm/utilities/vmError.cpp
src/share/vm/utilities/vmError.cpp
+1
-1
test/Makefile
test/Makefile
+162
-99
test/TEST.groups
test/TEST.groups
+21
-0
test/compiler/exceptions/CatchInlineExceptions.java
test/compiler/exceptions/CatchInlineExceptions.java
+81
-0
test/runtime/NMT/ChangeTrackingLevel.java
test/runtime/NMT/ChangeTrackingLevel.java
+51
-0
test/testlibrary/whitebox/sun/hotspot/WhiteBox.java
test/testlibrary/whitebox/sun/hotspot/WhiteBox.java
+1
-0
未找到文件。
make/excludeSrc.make
浏览文件 @
06e5d445
...
...
@@ -97,6 +97,7 @@ ifeq ($(INCLUDE_ALL_GCS), false)
ageTable.cpp
\
collectorCounters.cpp
\
cSpaceCounters.cpp
\
gcId.cpp
\
gcPolicyCounters.cpp
\
gcStats.cpp
\
gcTimer.cpp
\
...
...
make/hotspot_version
浏览文件 @
06e5d445
...
...
@@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2014
HS_MAJOR_VER=25
HS_MINOR_VER=40
HS_BUILD_NUMBER=1
5
HS_BUILD_NUMBER=1
6
JDK_MAJOR_VER=1
JDK_MINOR_VER=8
...
...
make/jprt.properties
浏览文件 @
06e5d445
...
...
@@ -374,21 +374,25 @@ jprt.make.rule.test.targets.standard.internalvmtests = \
${jprt.my.windows.i586}-fastdebug-c2-internalvmtests,
\
${jprt.my.windows.x64}-fastdebug-c2-internalvmtests
jprt.make.rule.test.targets.standard.
wbapi
=
\
${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-
wbapitest
,
\
${jprt.my.solaris.x64}-{product|fastdebug}-c2-
wbapitest
,
\
${jprt.my.linux.i586}-{product|fastdebug}-c2-
wbapitest
,
\
${jprt.my.linux.x64}-{product|fastdebug}-c2-
wbapitest
,
\
${jprt.my.windows.i586}-{product|fastdebug}-c2-
wbapitest
,
\
${jprt.my.windows.x64}-{product|fastdebug}-c2-
wbapitest
,
\
${jprt.my.linux.i586}-{product|fastdebug}-c1-
wbapitest
,
\
${jprt.my.windows.i586}-{product|fastdebug}-c1-
wbapitest
jprt.make.rule.test.targets.standard.
reg.group
=
\
${jprt.my.solaris.sparcv9}-{product|fastdebug}-c2-
GROUP
,
\
${jprt.my.solaris.x64}-{product|fastdebug}-c2-
GROUP
,
\
${jprt.my.linux.i586}-{product|fastdebug}-c2-
GROUP
,
\
${jprt.my.linux.x64}-{product|fastdebug}-c2-
GROUP
,
\
${jprt.my.windows.i586}-{product|fastdebug}-c2-
GROUP
,
\
${jprt.my.windows.x64}-{product|fastdebug}-c2-
GROUP
,
\
${jprt.my.linux.i586}-{product|fastdebug}-c1-
GROUP
,
\
${jprt.my.windows.i586}-{product|fastdebug}-c1-
GROUP
jprt.make.rule.test.targets.standard
=
\
${jprt.make.rule.test.targets.standard.client},
\
${jprt.make.rule.test.targets.standard.server},
\
${jprt.make.rule.test.targets.standard.internalvmtests},
\
${jprt.make.rule.test.targets.standard.wbapi}
${jprt.make.rule.test.targets.standard.reg.group:GROUP=hotspot_wbapitest},
\
${jprt.make.rule.test.targets.standard.reg.group:GROUP=hotspot_compiler},
\
${jprt.make.rule.test.targets.standard.reg.group:GROUP=hotspot_gc},
\
${jprt.make.rule.test.targets.standard.reg.group:GROUP=hotspot_runtime},
\
${jprt.make.rule.test.targets.standard.reg.group:GROUP=hotspot_serviceability}
jprt.make.rule.test.targets.embedded
=
\
${jprt.make.rule.test.targets.standard.client}
...
...
src/cpu/x86/vm/vm_version_x86.cpp
浏览文件 @
06e5d445
...
...
@@ -873,14 +873,19 @@ void VM_Version::get_processor_features() {
if
(
supports_bmi1
())
{
// tzcnt does not require VEX prefix
if
(
FLAG_IS_DEFAULT
(
UseCountTrailingZerosInstruction
))
{
if
(
!
UseBMI1Instructions
&&
!
FLAG_IS_DEFAULT
(
UseBMI1Instructions
))
{
// Don't use tzcnt if BMI1 is switched off on command line.
UseCountTrailingZerosInstruction
=
false
;
}
else
{
UseCountTrailingZerosInstruction
=
true
;
}
}
}
else
if
(
UseCountTrailingZerosInstruction
)
{
warning
(
"tzcnt instruction is not available on this CPU"
);
FLAG_SET_DEFAULT
(
UseCountTrailingZerosInstruction
,
false
);
}
// BMI instructions use an encoding with VEX prefix.
// BMI instructions
(except tzcnt)
use an encoding with VEX prefix.
// VEX prefix is generated only when AVX > 0.
if
(
supports_bmi1
()
&&
supports_avx
())
{
if
(
FLAG_IS_DEFAULT
(
UseBMI1Instructions
))
{
...
...
src/share/vm/classfile/classFileParser.cpp
浏览文件 @
06e5d445
...
...
@@ -4165,8 +4165,12 @@ instanceKlassHandle ClassFileParser::parseClassFile(Symbol* name,
tty
->
print
(
"[Loaded %s from %s]
\n
"
,
this_klass
->
external_name
(),
cfs
->
source
());
}
else
if
(
class_loader
.
is_null
())
{
if
(
THREAD
->
is_Java_thread
())
{
Klass
*
caller
=
((
JavaThread
*
)
THREAD
)
->
security_get_caller_class
(
1
);
Klass
*
caller
=
THREAD
->
is_Java_thread
()
?
((
JavaThread
*
)
THREAD
)
->
security_get_caller_class
(
1
)
:
NULL
;
// caller can be NULL, for example, during a JVMTI VM_Init hook
if
(
caller
!=
NULL
)
{
tty
->
print
(
"[Loaded %s by instance of %s]
\n
"
,
this_klass
->
external_name
(),
InstanceKlass
::
cast
(
caller
)
->
external_name
());
...
...
src/share/vm/opto/doCall.cpp
浏览文件 @
06e5d445
...
...
@@ -799,10 +799,16 @@ void Parse::catch_inline_exceptions(SafePointNode* ex_map) {
// each arm of the Phi. If I know something clever about the exceptions
// I'm loading the class from, I can replace the LoadKlass with the
// klass constant for the exception oop.
if
(
ex_node
->
is_Phi
()
)
{
ex_klass_node
=
new
(
C
)
PhiNode
(
ex_node
->
in
(
0
),
TypeKlassPtr
::
OBJECT
);
for
(
uint
i
=
1
;
i
<
ex_node
->
req
();
i
++
)
{
Node
*
p
=
basic_plus_adr
(
ex_node
->
in
(
i
),
ex_node
->
in
(
i
),
oopDesc
::
klass_offset_in_bytes
()
);
if
(
ex_node
->
is_Phi
())
{
ex_klass_node
=
new
(
C
)
PhiNode
(
ex_node
->
in
(
0
),
TypeKlassPtr
::
OBJECT
);
for
(
uint
i
=
1
;
i
<
ex_node
->
req
();
i
++
)
{
Node
*
ex_in
=
ex_node
->
in
(
i
);
if
(
ex_in
==
top
()
||
ex_in
==
NULL
)
{
// This path was not taken.
ex_klass_node
->
init_req
(
i
,
top
());
continue
;
}
Node
*
p
=
basic_plus_adr
(
ex_in
,
ex_in
,
oopDesc
::
klass_offset_in_bytes
());
Node
*
k
=
_gvn
.
transform
(
LoadKlassNode
::
make
(
_gvn
,
immutable_memory
(),
p
,
TypeInstPtr
::
KLASS
,
TypeKlassPtr
::
OBJECT
)
);
ex_klass_node
->
init_req
(
i
,
k
);
}
...
...
src/share/vm/prims/whitebox.cpp
浏览文件 @
06e5d445
...
...
@@ -331,7 +331,36 @@ WB_ENTRY(void, WB_NMTOverflowHashBucket(JNIEnv* env, jobject o, jlong num))
}
WB_END
WB_ENTRY
(
jboolean
,
WB_NMTChangeTrackingLevel
(
JNIEnv
*
env
))
// Test that we can downgrade NMT levels but not upgrade them.
if
(
MemTracker
::
tracking_level
()
==
NMT_off
)
{
MemTracker
::
transition_to
(
NMT_off
);
return
MemTracker
::
tracking_level
()
==
NMT_off
;
}
else
{
assert
(
MemTracker
::
tracking_level
()
==
NMT_detail
,
"Should start out as detail tracking"
);
MemTracker
::
transition_to
(
NMT_summary
);
assert
(
MemTracker
::
tracking_level
()
==
NMT_summary
,
"Should be summary now"
);
// Can't go to detail once NMT is set to summary.
MemTracker
::
transition_to
(
NMT_detail
);
assert
(
MemTracker
::
tracking_level
()
==
NMT_summary
,
"Should still be summary now"
);
// Shutdown sets tracking level to minimal.
MemTracker
::
shutdown
();
assert
(
MemTracker
::
tracking_level
()
==
NMT_minimal
,
"Should be minimal now"
);
// Once the tracking level is minimal, we cannot increase to summary.
// The code ignores this request instead of asserting because if the malloc site
// table overflows in another thread, it tries to change the code to summary.
MemTracker
::
transition_to
(
NMT_summary
);
assert
(
MemTracker
::
tracking_level
()
==
NMT_minimal
,
"Should still be minimal now"
);
// Really can never go up to detail, verify that the code would never do this.
MemTracker
::
transition_to
(
NMT_detail
);
assert
(
MemTracker
::
tracking_level
()
==
NMT_minimal
,
"Should still be minimal now"
);
return
MemTracker
::
tracking_level
()
==
NMT_minimal
;
}
WB_END
#endif // INCLUDE_NMT
static
jmethodID
reflected_method_to_jmid
(
JavaThread
*
thread
,
JNIEnv
*
env
,
jobject
method
)
{
...
...
@@ -936,6 +965,7 @@ static JNINativeMethod methods[] = {
{
CC
"NMTReleaseMemory"
,
CC
"(JJ)V"
,
(
void
*
)
&
WB_NMTReleaseMemory
},
{
CC
"NMTOverflowHashBucket"
,
CC
"(J)V"
,
(
void
*
)
&
WB_NMTOverflowHashBucket
},
{
CC
"NMTIsDetailSupported"
,
CC
"()Z"
,
(
void
*
)
&
WB_NMTIsDetailSupported
},
{
CC
"NMTChangeTrackingLevel"
,
CC
"()Z"
,
(
void
*
)
&
WB_NMTChangeTrackingLevel
},
#endif // INCLUDE_NMT
{
CC
"deoptimizeAll"
,
CC
"()V"
,
(
void
*
)
&
WB_DeoptimizeAll
},
{
CC
"deoptimizeMethod"
,
CC
"(Ljava/lang/reflect/Executable;Z)I"
,
...
...
src/share/vm/runtime/os.hpp
浏览文件 @
06e5d445
...
...
@@ -214,13 +214,14 @@ class os: AllStatic {
// Interface for detecting multiprocessor system
static
inline
bool
is_MP
()
{
#if !INCLUDE_NMT
assert
(
_processor_count
>
0
,
"invalid processor count"
);
return
_processor_count
>
1
||
AssumeMP
;
#else
// NMT needs atomic operations before this initialization.
return
true
;
#endif
// During bootstrap if _processor_count is not yet initialized
// we claim to be MP as that is safest. If any platform has a
// stub generator that might be triggered in this phase and for
// which being declared MP when in fact not, is a problem - then
// the bootstrap routine for the stub generator needs to check
// the processor count directly and leave the bootstrap routine
// in place until called after initialization has ocurred.
return
(
_processor_count
!=
1
)
||
AssumeMP
;
}
static
julong
available_memory
();
static
julong
physical_memory
();
...
...
src/share/vm/services/mallocTracker.cpp
浏览文件 @
06e5d445
...
...
@@ -51,14 +51,6 @@ size_t MallocMemorySnapshot::total_arena() const {
return
amount
;
}
void
MallocMemorySnapshot
::
reset
()
{
_tracking_header
.
reset
();
for
(
int
index
=
0
;
index
<
mt_number_of_types
;
index
++
)
{
_malloc
[
index
].
reset
();
}
}
// Make adjustment by subtracting chunks used by arenas
// from total chunks to get total free chunck size
void
MallocMemorySnapshot
::
make_adjustment
()
{
...
...
@@ -116,14 +108,9 @@ bool MallocTracker::initialize(NMT_TrackingLevel level) {
bool
MallocTracker
::
transition
(
NMT_TrackingLevel
from
,
NMT_TrackingLevel
to
)
{
assert
(
from
!=
NMT_off
,
"Can not transition from off state"
);
assert
(
to
!=
NMT_off
,
"Can not transition to off state"
);
if
(
from
==
NMT_minimal
)
{
MallocMemorySummary
::
reset
();
}
assert
(
from
!=
NMT_minimal
,
"cannot transition from minimal state"
);
if
(
to
==
NMT_detail
)
{
assert
(
from
==
NMT_minimal
||
from
==
NMT_summary
,
"Just check"
);
return
MallocSiteTable
::
initialize
();
}
else
if
(
from
==
NMT_detail
)
{
if
(
from
==
NMT_detail
)
{
assert
(
to
==
NMT_minimal
||
to
==
NMT_summary
,
"Just check"
);
MallocSiteTable
::
shutdown
();
}
...
...
src/share/vm/services/mallocTracker.hpp
浏览文件 @
06e5d445
...
...
@@ -51,14 +51,6 @@ class MemoryCounter VALUE_OBJ_CLASS_SPEC {
DEBUG_ONLY
(
_peak_size
=
0
;)
}
// Reset counters
void
reset
()
{
_size
=
0
;
_count
=
0
;
DEBUG_ONLY
(
_peak_size
=
0
;)
DEBUG_ONLY
(
_peak_count
=
0
;)
}
inline
void
allocate
(
size_t
sz
)
{
Atomic
::
add
(
1
,
(
volatile
MemoryCounterType
*
)
&
_count
);
if
(
sz
>
0
)
{
...
...
@@ -124,11 +116,6 @@ class MallocMemory VALUE_OBJ_CLASS_SPEC {
_arena
.
resize
(
sz
);
}
void
reset
()
{
_malloc
.
reset
();
_arena
.
reset
();
}
inline
size_t
malloc_size
()
const
{
return
_malloc
.
size
();
}
inline
size_t
malloc_count
()
const
{
return
_malloc
.
count
();}
inline
size_t
arena_size
()
const
{
return
_arena
.
size
();
}
...
...
@@ -176,8 +163,6 @@ class MallocMemorySnapshot : public ResourceObj {
return
s
->
by_type
(
mtThreadStack
)
->
malloc_count
();
}
void
reset
();
void
copy_to
(
MallocMemorySnapshot
*
s
)
{
s
->
_tracking_header
=
_tracking_header
;
for
(
int
index
=
0
;
index
<
mt_number_of_types
;
index
++
)
{
...
...
@@ -240,11 +225,6 @@ class MallocMemorySummary : AllStatic {
return
as_snapshot
()
->
malloc_overhead
()
->
size
();
}
// Reset all counters to zero
static
void
reset
()
{
as_snapshot
()
->
reset
();
}
static
MallocMemorySnapshot
*
as_snapshot
()
{
return
(
MallocMemorySnapshot
*
)
_snapshot
;
}
...
...
src/share/vm/services/memBaseline.hpp
浏览文件 @
06e5d445
...
...
@@ -90,10 +90,6 @@ class MemBaseline VALUE_OBJ_CLASS_SPEC {
_class_count
(
0
)
{
}
~
MemBaseline
()
{
reset
();
}
bool
baseline
(
bool
summaryOnly
=
true
);
BaselineType
baseline_type
()
const
{
return
_baseline_type
;
}
...
...
@@ -169,8 +165,7 @@ class MemBaseline VALUE_OBJ_CLASS_SPEC {
// reset the baseline for reuse
void
reset
()
{
_baseline_type
=
Not_baselined
;
_malloc_memory_snapshot
.
reset
();
_virtual_memory_snapshot
.
reset
();
// _malloc_memory_snapshot and _virtual_memory_snapshot are copied over.
_class_count
=
0
;
_malloc_sites
.
clear
();
...
...
src/share/vm/services/memReporter.hpp
浏览文件 @
06e5d445
...
...
@@ -96,20 +96,6 @@ class MemSummaryReporter : public MemReporterBase {
size_t
_class_count
;
public:
// Report summary tracking data from global snapshots directly.
// This constructor is used for final reporting and hs_err reporting.
MemSummaryReporter
(
MallocMemorySnapshot
*
malloc_snapshot
,
VirtualMemorySnapshot
*
vm_snapshot
,
outputStream
*
output
,
size_t
class_count
=
0
,
size_t
scale
=
K
)
:
MemReporterBase
(
output
,
scale
),
_malloc_snapshot
(
malloc_snapshot
),
_vm_snapshot
(
vm_snapshot
)
{
if
(
class_count
==
0
)
{
_class_count
=
InstanceKlass
::
number_of_instance_classes
();
}
else
{
_class_count
=
class_count
;
}
}
// This constructor is for normal reporting from a recent baseline.
MemSummaryReporter
(
MemBaseline
&
baseline
,
outputStream
*
output
,
size_t
scale
=
K
)
:
MemReporterBase
(
output
,
scale
),
...
...
src/share/vm/services/memTracker.cpp
浏览文件 @
06e5d445
...
...
@@ -144,11 +144,9 @@ void Tracker::record(address addr, size_t size) {
}
// Shutdown can only be issued via JCmd, and NMT JCmd is serialized
// by lock
// Shutdown can only be issued via JCmd, and NMT JCmd is serialized by lock
void
MemTracker
::
shutdown
()
{
// We can only shutdown NMT to minimal tracking level if it is
// ever on.
// We can only shutdown NMT to minimal tracking level if it is ever on.
if
(
tracking_level
()
>
NMT_minimal
)
{
transition_to
(
NMT_minimal
);
}
...
...
@@ -157,45 +155,36 @@ void MemTracker::shutdown() {
bool
MemTracker
::
transition_to
(
NMT_TrackingLevel
level
)
{
NMT_TrackingLevel
current_level
=
tracking_level
();
assert
(
level
!=
NMT_off
||
current_level
==
NMT_off
,
"Cannot transition NMT to off"
);
if
(
current_level
==
level
)
{
return
true
;
}
else
if
(
current_level
>
level
)
{
// Downgrade tracking level, we want to lower the tracking
// level first
// Downgrade tracking level, we want to lower the tracking level first
_tracking_level
=
level
;
// Make _tracking_level visible immediately.
OrderAccess
::
fence
();
VirtualMemoryTracker
::
transition
(
current_level
,
level
);
MallocTracker
::
transition
(
current_level
,
level
);
if
(
level
==
NMT_minimal
)
_baseline
.
reset
();
}
else
{
VirtualMemoryTracker
::
transition
(
current_level
,
level
);
MallocTracker
::
transition
(
current_level
,
level
);
_tracking_level
=
level
;
// Make _tracking_level visible immediately.
OrderAccess
::
fence
();
// Upgrading tracking level is not supported and has never been supported.
// Allocating and deallocating malloc tracking structures is not thread safe and
// leads to inconsistencies unless a lot coarser locks are added.
}
return
true
;
}
void
MemTracker
::
final_report
(
outputStream
*
output
)
{
void
MemTracker
::
report
(
bool
summary_only
,
outputStream
*
output
)
{
assert
(
output
!=
NULL
,
"No output stream"
);
if
(
tracking_level
()
>=
NMT_summary
)
{
MallocMemorySnapshot
*
malloc_memory_snapshot
=
MallocMemorySummary
::
as_snapshot
();
malloc_memory_snapshot
->
make_adjustment
();
VirtualMemorySnapshot
*
virtual_memory_snapshot
=
VirtualMemorySummary
::
as_snapshot
();
MemSummaryReporter
rptr
(
malloc_memory_snapshot
,
virtual_memory_snapshot
,
output
);
rptr
.
report
();
// shutdown NMT, the data no longer accurate
shutdown
();
MemBaseline
baseline
;
if
(
baseline
.
baseline
(
summary_only
))
{
if
(
summary_only
)
{
MemSummaryReporter
rpt
(
baseline
,
output
);
rpt
.
report
();
}
else
{
MemDetailReporter
rpt
(
baseline
,
output
);
rpt
.
report
();
}
}
}
...
...
src/share/vm/services/memTracker.hpp
浏览文件 @
06e5d445
...
...
@@ -70,6 +70,7 @@ class MemTracker : AllStatic {
static
inline
void
release_thread_stack
(
void
*
addr
,
size_t
size
)
{
}
static
void
final_report
(
outputStream
*
)
{
}
static
void
error_report
(
outputStream
*
)
{
}
};
#else
...
...
@@ -270,13 +271,20 @@ class MemTracker : AllStatic {
// other tools.
static
inline
Mutex
*
query_lock
()
{
return
_query_lock
;
}
// Make a final report and shutdown.
// This function generates summary report without creating snapshots,
// to avoid additional memory allocation. It uses native memory summary
// counters, and makes adjustment to them, once the adjustment is made,
// the counters are no longer accurate. As the result, this function
// should only be used for final reporting before shutting down.
static
void
final_report
(
outputStream
*
);
// Make a final report or report for hs_err file.
static
void
error_report
(
outputStream
*
output
)
{
if
(
tracking_level
()
>=
NMT_summary
)
{
report
(
true
,
output
);
// just print summary for error case.
}
}
static
void
final_report
(
outputStream
*
output
)
{
NMT_TrackingLevel
level
=
tracking_level
();
if
(
level
>=
NMT_summary
)
{
report
(
level
==
NMT_summary
,
output
);
}
}
// Stored baseline
static
inline
MemBaseline
&
get_baseline
()
{
...
...
@@ -291,6 +299,7 @@ class MemTracker : AllStatic {
private:
static
NMT_TrackingLevel
init_tracking_level
();
static
void
report
(
bool
summary_only
,
outputStream
*
output
);
private:
// Tracking level
...
...
src/share/vm/services/virtualMemoryTracker.cpp
浏览文件 @
06e5d445
...
...
@@ -443,6 +443,8 @@ bool VirtualMemoryTracker::remove_released_region(address addr, size_t size) {
bool
VirtualMemoryTracker
::
walk_virtual_memory
(
VirtualMemoryWalker
*
walker
)
{
assert
(
_reserved_regions
!=
NULL
,
"Sanity check"
);
ThreadCritical
tc
;
// Check that the _reserved_regions haven't been deleted.
if
(
_reserved_regions
!=
NULL
)
{
LinkedListNode
<
ReservedMemoryRegion
>*
head
=
_reserved_regions
->
head
();
while
(
head
!=
NULL
)
{
const
ReservedMemoryRegion
*
rgn
=
head
->
peek
();
...
...
@@ -451,18 +453,18 @@ bool VirtualMemoryTracker::walk_virtual_memory(VirtualMemoryWalker* walker) {
}
head
=
head
->
next
();
}
}
return
true
;
}
// Transition virtual memory tracking level.
bool
VirtualMemoryTracker
::
transition
(
NMT_TrackingLevel
from
,
NMT_TrackingLevel
to
)
{
if
(
from
==
NMT_minimal
)
{
assert
(
to
==
NMT_summary
||
to
==
NMT_detail
,
"Just check"
);
VirtualMemorySummary
::
reset
();
}
else
if
(
to
==
NMT_minimal
)
{
assert
(
from
!=
NMT_minimal
,
"cannot convert from the lowest tracking level to anything"
);
if
(
to
==
NMT_minimal
)
{
assert
(
from
==
NMT_summary
||
from
==
NMT_detail
,
"Just check"
);
// Clean up virtual memory tracking data structures.
ThreadCritical
tc
;
// Check for potential race with other thread calling transition
if
(
_reserved_regions
!=
NULL
)
{
delete
_reserved_regions
;
_reserved_regions
=
NULL
;
...
...
src/share/vm/services/virtualMemoryTracker.hpp
浏览文件 @
06e5d445
...
...
@@ -62,11 +62,6 @@ class VirtualMemory VALUE_OBJ_CLASS_SPEC {
_committed
-=
sz
;
}
void
reset
()
{
_reserved
=
0
;
_committed
=
0
;
}
inline
size_t
reserved
()
const
{
return
_reserved
;
}
inline
size_t
committed
()
const
{
return
_committed
;
}
};
...
...
@@ -123,12 +118,6 @@ class VirtualMemorySnapshot : public ResourceObj {
return
amount
;
}
inline
void
reset
()
{
for
(
int
index
=
0
;
index
<
mt_number_of_types
;
index
++
)
{
_virtual_memory
[
index
].
reset
();
}
}
void
copy_to
(
VirtualMemorySnapshot
*
s
)
{
for
(
int
index
=
0
;
index
<
mt_number_of_types
;
index
++
)
{
s
->
_virtual_memory
[
index
]
=
_virtual_memory
[
index
];
...
...
@@ -174,10 +163,6 @@ class VirtualMemorySummary : AllStatic {
as_snapshot
()
->
copy_to
(
s
);
}
static
inline
void
reset
()
{
as_snapshot
()
->
reset
();
}
static
VirtualMemorySnapshot
*
as_snapshot
()
{
return
(
VirtualMemorySnapshot
*
)
_snapshot
;
}
...
...
src/share/vm/utilities/vmError.cpp
浏览文件 @
06e5d445
...
...
@@ -774,7 +774,7 @@ void VMError::report(outputStream* st) {
STEP
(
228
,
"(Native Memory Tracking)"
)
if
(
_verbose
)
{
MemTracker
::
final
_report
(
st
);
MemTracker
::
error
_report
(
st
);
}
STEP
(
230
,
""
)
...
...
test/Makefile
浏览文件 @
06e5d445
#
# Copyright (c) 1995, 201
3
, Oracle and/or its affiliates. All rights reserved.
# Copyright (c) 1995, 201
4
, Oracle and/or its affiliates. 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
...
...
@@ -23,14 +23,36 @@
#
#
# Makefile to run various
jdk
tests
# Makefile to run various
hotspot
tests
#
GETMIXEDPATH
=
echo
# Get OS/ARCH specifics
OSNAME
=
$(
shell
uname
-s
)
ifeq
($(OSNAME), SunOS)
# Utilities used
AWK
=
awk
CAT
=
cat
CD
=
cd
CHMOD
=
chmod
CP
=
cp
CUT
=
cut
DIRNAME
=
dirname
ECHO
=
echo
EGREP
=
egrep
EXPAND
=
expand
FIND
=
find
MKDIR
=
mkdir
PWD
=
pwd
SED
=
sed
SORT
=
sort
TEE
=
tee
UNAME
=
uname
UNIQ
=
uniq
WC
=
wc
ZIP
=
zip
# Get OS name from uname (Cygwin inexplicably adds _NT-5.1)
UNAME_S
:=
$(
shell
$(UNAME)
-s
|
$(CUT)
-f1
-d_
)
ifeq
($(UNAME_S), SunOS)
PLATFORM
=
solaris
SLASH_JAVA
=
/java
ARCH
=
$(
shell
uname
-p
)
...
...
@@ -38,7 +60,7 @@ ifeq ($(OSNAME), SunOS)
ARCH
=
i586
endif
endif
ifeq
($(
OSNAME
), Linux)
ifeq
($(
UNAME_S
), Linux)
PLATFORM
=
linux
SLASH_JAVA
=
/java
ARCH
=
$(
shell
uname
-m
)
...
...
@@ -46,7 +68,7 @@ ifeq ($(OSNAME), Linux)
ARCH
=
i586
endif
endif
ifeq
($(
OSNAME
), Darwin)
ifeq
($(
UNAME_S
), Darwin)
PLATFORM
=
bsd
SLASH_JAVA
=
/java
ARCH
=
$(
shell
uname
-m
)
...
...
@@ -54,7 +76,7 @@ ifeq ($(OSNAME), Darwin)
ARCH
=
i586
endif
endif
ifeq
($(findstring BSD,$(
OSNAME
)), BSD)
ifeq
($(findstring BSD,$(
UNAME_S
)), BSD)
PLATFORM
=
bsd
SLASH_JAVA
=
/java
ARCH
=
$(
shell
uname
-m
)
...
...
@@ -63,12 +85,12 @@ ifeq ($(findstring BSD,$(OSNAME)), BSD)
endif
endif
ifeq
($(PLATFORM),)
# detect wether we're running in MKS or cygwin
ifeq
($(
OSNAME
), Windows_NT)
# MKS
# detect w
h
ether we're running in MKS or cygwin
ifeq
($(
UNAME_S
), Windows_NT)
# MKS
GETMIXEDPATH
=
dosname
-s
endif
ifeq
($(findstring CYGWIN,$(
OSNAME
)), CYGWIN)
GETMIXEDPATH
=
cygpath
-m
-s
ifeq
($(findstring CYGWIN,$(
UNAME_S
)), CYGWIN)
GETMIXEDPATH
=
cygpath
-m
endif
PLATFORM
=
windows
SLASH_JAVA
=
J:
...
...
@@ -92,13 +114,6 @@ ifdef ALT_SLASH_JAVA
SLASH_JAVA
=
$(ALT_SLASH_JAVA)
endif
# Utilities used
CD
=
cd
CP
=
cp
ECHO
=
echo
MKDIR
=
mkdir
ZIP
=
zip
# Root of this test area (important to use full paths in some places)
TEST_ROOT
:=
$(
shell
pwd
)
...
...
@@ -136,21 +151,82 @@ ifdef JPRT_ARCHIVE_BUNDLE
endif
# How to create the test bundle (pass or fail, we want to create this)
BUNDLE_UP
=
(
$(MKDIR)
-p
`
dirname
$(ARCHIVE_BUNDLE)
`
\
# Follow command with ";$(BUNDLE_UP_AND_EXIT)", so it always gets executed.
ZIP_UP_RESULTS
=
(
$(MKDIR)
-p
`
$(DIRNAME)
$(ARCHIVE_BUNDLE)
`
\
&&
$(CD)
$(ABS_TEST_OUTPUT_DIR)
\
&&
$(CHMOD)
-R
a+r
.
\
&&
$(ZIP)
-q
-r
$(ARCHIVE_BUNDLE)
.
)
BUNDLE_UP_FAILED
=
(
exitCode
=
$$
?
&&
$(BUNDLE_UP)
&&
exit
$
${exitCode}
)
# important results files
SUMMARY_TXT
=
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
/JTreport/text/summary.txt"
)
STATS_TXT_NAME
=
Stats.txt
STATS_TXT
=
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
/
$(STATS_TXT_NAME)
"
)
RUNLIST
=
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
/runlist.txt"
)
PASSLIST
=
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
/passlist.txt"
)
FAILLIST
=
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
/faillist.txt"
)
EXITCODE
=
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
/exitcode.txt"
)
TESTEXIT
=
\
if
[
!
-s
$(EXITCODE)
]
;
then
\
$(ECHO)
"ERROR: EXITCODE file not filled in."
;
\
$(ECHO)
"1"
>
$(EXITCODE)
;
\
fi
;
\
testExitCode
=
`
$(CAT)
$(EXITCODE)
`
;
\
$(ECHO)
"EXIT CODE:
$
${testExitCode}
"
;
\
exit
$
${testExitCode}
BUNDLE_UP_AND_EXIT
=
\
(
\
jtregExitCode
=
$$
?
&&
\
_summary
=
"
$(SUMMARY_TXT)
"
;
\
$(RM)
-f
$(STATS_TXT)
$(RUNLIST)
$(PASSLIST)
$(FAILLIST)
$(EXITCODE)
;
\
$(ECHO)
"
$
${jtregExitCode}
"
>
$(EXITCODE)
;
\
if
[
-r
"
$
${_summary}
"
]
;
then
\
$(ECHO)
"Summary:
$(UNIQUE_DIR)
"
>
$(STATS_TXT)
;
\
$(EXPAND)
$
${_summary}
|
$(EGREP)
-v
' Not run\.'
>
$(RUNLIST)
;
\
$(EGREP)
' Passed\.'
$(RUNLIST)
\
|
$(EGREP)
-v
' Error\.'
\
|
$(EGREP)
-v
' Failed\.'
>
$(PASSLIST)
;
\
(
$(EGREP)
' Failed\.'
$(RUNLIST)
;
\
$(EGREP)
' Error\.'
$(RUNLIST)
;
\
$(EGREP)
-v
' Passed\.'
$(RUNLIST)
)
\
|
$(SORT)
|
$(UNIQ)
>
$(FAILLIST)
;
\
if
[
$
${jtregExitCode}
!=
0
-o
-s
$(FAILLIST)
]
;
then
\
$(EXPAND)
$(FAILLIST)
\
|
$(CUT)
-d
' '
-f1
\
|
$(SED)
-e
's@^@FAILED: @'
>>
$(STATS_TXT)
;
\
if
[
$
${jtregExitCode}
=
0
]
;
then
\
jtregExitCode
=
1
;
\
fi
;
\
fi
;
\
runc
=
"
`
$(CAT)
$(RUNLIST)
|
$(WC)
-l
|
$(AWK)
'{print $$1;}'
`
"
;
\
passc
=
"
`
$(CAT)
$(PASSLIST)
|
$(WC)
-l
|
$(AWK)
'{print $$1;}'
`
"
;
\
failc
=
"
`
$(CAT)
$(FAILLIST)
|
$(WC)
-l
|
$(AWK)
'{print $$1;}'
`
"
;
\
exclc
=
"FIXME CODETOOLS-7900176"
;
\
$(ECHO)
"TEST STATS: name=
$(UNIQUE_DIR)
run=
$
${runc}
pass=
$
${passc}
fail=
$
${failc}
"
\
>>
$(STATS_TXT)
;
\
else
\
$(ECHO)
"Missing file:
$
${_summary}
"
>>
$(STATS_TXT)
;
\
fi
;
\
if
[
-f
$(STATS_TXT)
]
;
then
\
$(CAT)
$(STATS_TXT)
;
\
fi
;
\
$(ZIP_UP_RESULTS)
;
\
$(TESTEXIT)
\
)
################################################################
# Default make rule (runs jtreg_tests)
all
:
jtreg_tests
all
:
hotspot_all
@
$(ECHO)
"Testing completed successfully"
# Support "hotspot_" prefixed test make targets too
# The hotspot_% targets are for example invoked by the top level Makefile
# Support "hotspot_" prefixed test make targets (too)
# The hotspot_% targets are used by the top level Makefile
# Unless explicitly defined below, hotspot_<x> is interpreted as a jtreg test group name
hotspot_%
:
$(MAKE)
$*
$(ECHO)
"Running tests:
$@
"
$(MAKE)
-j
1
TEST_SELECTION
=
":
$@
"
UNIQUE_DIR
=
$@
jtreg_tests
;
# Prep for output
prep
:
clean
...
...
@@ -168,41 +244,64 @@ clean:
# Expect JT_HOME to be set for jtreg tests. (home for jtreg)
ifndef
JT_HOME
JT_HOME
=
$(SLASH_JAVA)
/re/jtreg/4.0/promoted/latest/binaries/jtreg
endif
ifdef
JPRT_JTREG_HOME
JT_HOME
=
$(SLASH_JAVA)
/re/jtreg/4.1/promoted/latest/binaries/jtreg
ifdef
JPRT_JTREG_HOME
JT_HOME
=
$(JPRT_JTREG_HOME)
endif
endif
# Expect JPRT to set TESTDIRS to the jtreg test dirs
JTREG_TESTDIRS
=
demo/jvmti/gctest demo/jvmti/hprof
# When called from JPRT the TESTDIRS variable is set to the jtreg tests to run
ifdef
TESTDIRS
JTREG_TESTDIRS
=
$(TESTDIRS)
TEST_SELECTION
=
$(TESTDIRS)
endif
ifdef
CONCURRENCY
EXTRA_JTREG_OPTIONS
+=
-concurrency
:
$(CONCURRENCY)
endif
# Default JTREG to run
JTREG
=
$(JT_HOME)
/bin/jtreg
# Only run automatic tests
JTREG_BASIC_OPTIONS
+=
-a
# Report details on all failed or error tests, times too
JTREG_BASIC_OPTIONS
+=
-v
:fail,error,time
# Retain all files for failing tests
JTREG_BASIC_OPTIONS
+=
-retain
:fail,error
# Ignore tests are not run and completely silent about it
JTREG_IGNORE_OPTION
=
-ignore
:quiet
JTREG_BASIC_OPTIONS
+=
$(JTREG_IGNORE_OPTION)
# Add any extra options
JTREG_BASIC_OPTIONS
+=
$(EXTRA_JTREG_OPTIONS)
# Set other vm and test options
JTREG_TEST_OPTIONS
=
$
(
JAVA_ARGS:%
=
-javaoptions
:%
)
$
(
JAVA_OPTIONS:%
=
-vmoption
:%
)
$
(
JAVA_VM_ARGS:%
=
-vmoption
:%
)
# Option to tell jtreg to not run tests marked with "ignore"
ifeq
($(PLATFORM), windows)
JTREG_KEY_OPTION
=
-k
:!ignore
else
JTREG_KEY_OPTION
=
-k
:
\!
ignore
endif
#EXTRA_JTREG_OPTIONS =
jtreg_tests
:
prep $(JT_HOME) $(PRODUCT_HOME) $(JTREG)
$(JTREG)
-a
-v
:fail,error
\
$(JTREG_KEY_OPTION)
\
$(EXTRA_JTREG_OPTIONS)
\
-r
:
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
"
)
/JTreport
\
-w
:
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
"
)
/JTwork
\
JTREG_BASIC_OPTIONS
+=
$(JTREG_KEY_OPTION)
# Make sure jtreg exists
$(JTREG)
:
$(JT_HOME)
jtreg_tests
:
prep $(PRODUCT_HOME) $(JTREG)
(
\
(
JT_HOME
=
$(
shell
$(GETMIXEDPATH)
"
$(JT_HOME)
"
)
;
\
export
JT_HOME
;
\
$(
shell
$(GETMIXEDPATH)
"
$(JTREG)
"
)
\
$(JTREG_BASIC_OPTIONS)
\
-r
:
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
/JTreport"
)
\
-w
:
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
/JTwork"
)
\
-jdk
:
$(
shell
$(GETMIXEDPATH)
"
$(PRODUCT_HOME)
"
)
\
$
(
JAVA_OPTIONS:%
=
-vmoption
:%
)
\
$(JTREG_TESTDIRS)
\
||
$(BUNDLE_UP_FAILED)
$(BUNDLE_UP)
$(JTREG_EXCLUSIONS)
\
$(JTREG_TEST_OPTIONS)
\
$(TEST_SELECTION)
\
)
;
\
$(BUNDLE_UP_AND_EXIT)
\
)
2>&1 |
$(TEE)
$(ABS_TEST_OUTPUT_DIR)
/output.txt
;
$(TESTEXIT)
PHONY_LIST
+=
jtreg_tests
...
...
@@ -210,7 +309,7 @@ PHONY_LIST += jtreg_tests
# clienttest (make sure various basic java client options work)
clienttest
:
prep $(PRODUCT_HOME)
hotspot_clienttest
clienttest
:
prep $(PRODUCT_HOME)
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-version
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-help
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-X
...
...
@@ -218,73 +317,38 @@ clienttest: prep $(PRODUCT_HOME)
$(RM)
$(PRODUCT_HOME)
/jre/bin/client/classes.jsa
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-Xshare
:dump
PHONY_LIST
+=
clienttest
PHONY_LIST
+=
hotspot_clienttest
clienttest
################################################################
#
servertest (make sure various basic java server
options work)
#
minimaltest (make sure various basic java minimal
options work)
server
test
:
prep $(PRODUCT_HOME)
hotspot_minimaltest minimal
test
:
prep $(PRODUCT_HOME)
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-version
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-help
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-X
PHONY_LIST
+=
server
test
PHONY_LIST
+=
hotspot_minimaltest minimal
test
################################################################
# internalvmtests (run internal unit tests inside the VM)
internalvmtests
:
prep $(PRODUCT_HOME)
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-XX
:+ExecuteInternalVMTests
-version
PHONY_LIST
+=
internalvmtests
################################################################
# wbapitest (make sure the whitebox testing api classes work
# servertest (make sure various basic java server options work)
wbapitest
:
prep $(JT_HOME) $(PRODUCT_HOME) $(JTREG)
$(JTREG)
-a
-v
:fail,error
\
$(JTREG_KEY_OPTION)
\
$(EXTRA_JTREG_OPTIONS)
\
-r
:
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
"
)
/JTreport
\
-w
:
$(
shell
$(GETMIXEDPATH)
"
$(ABS_TEST_OUTPUT_DIR)
"
)
/JTwork
\
-jdk
:
$(
shell
$(GETMIXEDPATH)
"
$(PRODUCT_HOME)
"
)
\
$
(
JAVA_OPTIONS:%
=
-vmoption
:%
)
\
$(
shell
$(GETMIXEDPATH)
"
$(TEST_ROOT)
"
)
/sanity
\
||
$(BUNDLE_UP_FAILED)
$(BUNDLE_UP)
hotspot_servertest servertest
:
prep $(PRODUCT_HOME)
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-version
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-help
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-X
PHONY_LIST
+=
wbapi
test
PHONY_LIST
+=
hotspot_servertest server
test
################################################################
# packtest
# Expect JPRT to set JPRT_PACKTEST_HOME.
PACKTEST_HOME
=
/net/jprt-web.sfbay.sun.com/jprt/allproducts/packtest
ifdef
JPRT_PACKTEST_HOME
PACKTEST_HOME
=
$(JPRT_PACKTEST_HOME)
endif
#EXTRA_PACKTEST_OPTIONS =
packtest
:
prep $(PACKTEST_HOME)/ptest $(PRODUCT_HOME)
(
$(CD)
$(PACKTEST_HOME)
&&
\
$(PACKTEST_HOME)
/ptest
\
-t
"
$(PRODUCT_HOME)
"
\
$(PACKTEST_STRESS_OPTION)
\
$(EXTRA_PACKTEST_OPTIONS)
\
-W
$(ABS_TEST_OUTPUT_DIR)
\
$
(
JAVA_OPTIONS:%
=
-J
%
)
\
)
||
$(BUNDLE_UP_FAILED)
$(BUNDLE_UP)
# internalvmtests (run internal unit tests inside the VM)
packtest_stress
:
PACKTEST_STRESS_OPTION=-s
packtest_stress
:
packtest
hotspot_internalvmtests internalvmtests
:
prep $(PRODUCT_HOME)
$(PRODUCT_HOME)
/bin/java
$(JAVA_OPTIONS)
-XX
:+ExecuteInternalVMTests
-version
PHONY_LIST
+=
packtest packtest_stres
s
PHONY_LIST
+=
hotspot_internalvmtests internalvmtest
s
################################################################
...
...
@@ -292,4 +356,3 @@ PHONY_LIST += packtest packtest_stress
.PHONY
:
all clean prep $(PHONY_LIST)
################################################################
test/TEST.groups
浏览文件 @
06e5d445
...
...
@@ -125,6 +125,27 @@ compact3 = \
-:needs_jdk
# When called from top level the test suites use the hotspot_ prefix
hotspot_wbapitest = \
sanity/
hotspot_compiler = \
sanity/ExecuteInternalVMTests.java
hotspot_gc = \
sanity/ExecuteInternalVMTests.java
hotspot_runtime = \
sanity/ExecuteInternalVMTests.java
hotspot_serviceability = \
sanity/ExecuteInternalVMTests.java
hotspot_all = \
:hotspot_compiler \
:hotspot_gc \
:hotspot_runtime \
:hotspot_serviceability
# Tests that require compact3 API's
#
needs_compact3 = \
...
...
test/compiler/exceptions/CatchInlineExceptions.java
0 → 100644
浏览文件 @
06e5d445
/*
* Copyright (c) 2014, Oracle and/or its affiliates. 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/**
* @test
* @bug 8059299
* @summary assert(adr_type != NULL) failed: expecting TypeKlassPtr
* @run main/othervm -Xbatch CatchInlineExceptions
*/
class
Exception1
extends
Exception
{};
class
Exception2
extends
Exception
{};
public
class
CatchInlineExceptions
{
private
static
int
counter0
;
private
static
int
counter1
;
private
static
int
counter2
;
private
static
int
counter
;
static
void
foo
(
int
i
)
throws
Exception
{
if
((
i
&
1023
)
==
2
)
{
counter0
++;
throw
new
Exception2
();
}
}
static
void
test
(
int
i
)
throws
Exception
{
try
{
foo
(
i
);
}
catch
(
Exception
e
)
{
if
(
e
instanceof
Exception1
)
{
counter1
++;
}
else
if
(
e
instanceof
Exception2
)
{
counter2
++;
}
counter
++;
throw
e
;
}
}
public
static
void
main
(
String
[]
args
)
throws
Throwable
{
for
(
int
i
=
0
;
i
<
15000
;
i
++)
{
try
{
test
(
i
);
}
catch
(
Exception
e
)
{
// expected
}
}
if
(
counter1
!=
0
)
{
throw
new
RuntimeException
(
"Failed: counter1("
+
counter1
+
") != 0"
);
}
if
(
counter2
!=
counter0
)
{
throw
new
RuntimeException
(
"Failed: counter2("
+
counter2
+
") != counter0("
+
counter0
+
")"
);
}
if
(
counter2
!=
counter
)
{
throw
new
RuntimeException
(
"Failed: counter2("
+
counter2
+
") != counter("
+
counter
+
")"
);
}
System
.
out
.
println
(
"TEST PASSED"
);
}
}
test/runtime/NMT/ChangeTrackingLevel.java
0 → 100644
浏览文件 @
06e5d445
/*
* Copyright (c) 2013, 2014, Oracle and/or its affiliates. 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8059100
* @summary Test that you can decrease NMT tracking level but not increase it.
* @key nmt
* @library /testlibrary /testlibrary/whitebox
* @build ChangeTrackingLevel
* @run main ClassFileInstaller sun.hotspot.WhiteBox
* sun.hotspot.WhiteBox$WhiteBoxPermission
* @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -XX:NativeMemoryTracking=detail ChangeTrackingLevel
*/
import
com.oracle.java.testlibrary.*
;
import
sun.hotspot.WhiteBox
;
public
class
ChangeTrackingLevel
{
public
static
WhiteBox
wb
=
WhiteBox
.
getWhiteBox
();
public
static
void
main
(
String
args
[])
throws
Exception
{
boolean
testChangeLevel
=
wb
.
NMTChangeTrackingLevel
();
if
(
testChangeLevel
)
{
System
.
out
.
println
(
"NMT level change test passed."
);
}
else
{
// it also fails if the VM asserts.
throw
new
RuntimeException
(
"NMT level change test failed"
);
}
}
};
test/testlibrary/whitebox/sun/hotspot/WhiteBox.java
浏览文件 @
06e5d445
...
...
@@ -101,6 +101,7 @@ public class WhiteBox {
public
native
void
NMTOverflowHashBucket
(
long
num
);
public
native
long
NMTMallocWithPseudoStack
(
long
size
,
int
index
);
public
native
boolean
NMTIsDetailSupported
();
public
native
boolean
NMTChangeTrackingLevel
();
// Compiler
public
native
void
deoptimizeAll
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录