Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
aea2819e
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看板
提交
aea2819e
编写于
12月 23, 2010
作者:
J
johnc
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
ed371f07
e32f3633
变更
10
显示空白变更内容
内联
并排
Showing
10 changed file
with
94 addition
and
51 deletion
+94
-51
src/share/vm/gc_implementation/g1/concurrentMark.cpp
src/share/vm/gc_implementation/g1/concurrentMark.cpp
+13
-26
src/share/vm/gc_implementation/g1/concurrentMark.hpp
src/share/vm/gc_implementation/g1/concurrentMark.hpp
+19
-0
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
+11
-6
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
+7
-1
src/share/vm/gc_implementation/parNew/parNewGeneration.cpp
src/share/vm/gc_implementation/parNew/parNewGeneration.cpp
+4
-3
src/share/vm/gc_implementation/parallelScavenge/psScavenge.cpp
...hare/vm/gc_implementation/parallelScavenge/psScavenge.cpp
+2
-0
src/share/vm/gc_implementation/shared/vmGCOperations.hpp
src/share/vm/gc_implementation/shared/vmGCOperations.hpp
+11
-0
src/share/vm/memory/defNewGeneration.cpp
src/share/vm/memory/defNewGeneration.cpp
+11
-6
src/share/vm/memory/defNewGeneration.hpp
src/share/vm/memory/defNewGeneration.hpp
+1
-0
src/share/vm/oops/markOop.inline.hpp
src/share/vm/oops/markOop.inline.hpp
+15
-9
未找到文件。
src/share/vm/gc_implementation/g1/concurrentMark.cpp
浏览文件 @
aea2819e
...
@@ -1825,23 +1825,11 @@ void ConcurrentMark::completeCleanup() {
...
@@ -1825,23 +1825,11 @@ void ConcurrentMark::completeCleanup() {
}
}
}
}
bool
G1CMIsAliveClosure
::
do_object_b
(
oop
obj
)
{
class
G1CMIsAliveClosure
:
public
BoolObjectClosure
{
G1CollectedHeap
*
_g1
;
public:
G1CMIsAliveClosure
(
G1CollectedHeap
*
g1
)
:
_g1
(
g1
)
{}
void
do_object
(
oop
obj
)
{
assert
(
false
,
"not to be invoked"
);
}
bool
do_object_b
(
oop
obj
)
{
HeapWord
*
addr
=
(
HeapWord
*
)
obj
;
HeapWord
*
addr
=
(
HeapWord
*
)
obj
;
return
addr
!=
NULL
&&
return
addr
!=
NULL
&&
(
!
_g1
->
is_in_g1_reserved
(
addr
)
||
!
_g1
->
is_obj_ill
(
obj
));
(
!
_g1
->
is_in_g1_reserved
(
addr
)
||
!
_g1
->
is_obj_ill
(
obj
));
}
}
};
class
G1CMKeepAliveClosure
:
public
OopClosure
{
class
G1CMKeepAliveClosure
:
public
OopClosure
{
G1CollectedHeap
*
_g1
;
G1CollectedHeap
*
_g1
;
...
@@ -1896,16 +1884,15 @@ void ConcurrentMark::weakRefsWork(bool clear_all_soft_refs) {
...
@@ -1896,16 +1884,15 @@ void ConcurrentMark::weakRefsWork(bool clear_all_soft_refs) {
rp
->
setup_policy
(
clear_all_soft_refs
);
rp
->
setup_policy
(
clear_all_soft_refs
);
assert
(
_markStack
.
isEmpty
(),
"mark stack should be empty"
);
assert
(
_markStack
.
isEmpty
(),
"mark stack should be empty"
);
G1CMIsAliveClosure
g1
IsAliveClosure
(
g1h
);
G1CMIsAliveClosure
g1
_is_alive
(
g1h
);
G1CMKeepAliveClosure
g1
KeepAliveClosur
e
(
g1h
,
this
,
nextMarkBitMap
());
G1CMKeepAliveClosure
g1
_keep_aliv
e
(
g1h
,
this
,
nextMarkBitMap
());
G1CMDrainMarkingStackClosure
G1CMDrainMarkingStackClosure
g1DrainMarkingStackClosure
(
nextMarkBitMap
(),
&
_markStack
,
g1_drain_mark_stack
(
nextMarkBitMap
(),
&
_markStack
,
&
g1_keep_alive
);
&
g1KeepAliveClosure
);
// XXXYYY Also: copy the parallel ref processing code from CMS.
// XXXYYY Also: copy the parallel ref processing code from CMS.
rp
->
process_discovered_references
(
&
g1
IsAliveClosur
e
,
rp
->
process_discovered_references
(
&
g1
_is_aliv
e
,
&
g1
KeepAliveClosur
e
,
&
g1
_keep_aliv
e
,
&
g1
DrainMarkingStackClosure
,
&
g1
_drain_mark_stack
,
NULL
);
NULL
);
assert
(
_markStack
.
overflow
()
||
_markStack
.
isEmpty
(),
assert
(
_markStack
.
overflow
()
||
_markStack
.
isEmpty
(),
"mark stack should be empty (unless it overflowed)"
);
"mark stack should be empty (unless it overflowed)"
);
...
@@ -1918,8 +1905,8 @@ void ConcurrentMark::weakRefsWork(bool clear_all_soft_refs) {
...
@@ -1918,8 +1905,8 @@ void ConcurrentMark::weakRefsWork(bool clear_all_soft_refs) {
assert
(
!
rp
->
discovery_enabled
(),
"should have been disabled"
);
assert
(
!
rp
->
discovery_enabled
(),
"should have been disabled"
);
// Now clean up stale oops in SymbolTable and StringTable
// Now clean up stale oops in SymbolTable and StringTable
SymbolTable
::
unlink
(
&
g1
IsAliveClosur
e
);
SymbolTable
::
unlink
(
&
g1
_is_aliv
e
);
StringTable
::
unlink
(
&
g1
IsAliveClosur
e
);
StringTable
::
unlink
(
&
g1
_is_aliv
e
);
}
}
void
ConcurrentMark
::
swapMarkBitMaps
()
{
void
ConcurrentMark
::
swapMarkBitMaps
()
{
...
...
src/share/vm/gc_implementation/g1/concurrentMark.hpp
浏览文件 @
aea2819e
...
@@ -33,6 +33,25 @@ class CMTask;
...
@@ -33,6 +33,25 @@ class CMTask;
typedef
GenericTaskQueue
<
oop
>
CMTaskQueue
;
typedef
GenericTaskQueue
<
oop
>
CMTaskQueue
;
typedef
GenericTaskQueueSet
<
CMTaskQueue
>
CMTaskQueueSet
;
typedef
GenericTaskQueueSet
<
CMTaskQueue
>
CMTaskQueueSet
;
// Closure used by CM during concurrent reference discovery
// and reference processing (during remarking) to determine
// if a particular object is alive. It is primarily used
// to determine if referents of discovered reference objects
// are alive. An instance is also embedded into the
// reference processor as the _is_alive_non_header field
class
G1CMIsAliveClosure
:
public
BoolObjectClosure
{
G1CollectedHeap
*
_g1
;
public:
G1CMIsAliveClosure
(
G1CollectedHeap
*
g1
)
:
_g1
(
g1
)
{}
void
do_object
(
oop
obj
)
{
ShouldNotCallThis
();
}
bool
do_object_b
(
oop
obj
);
};
// A generic CM bit map. This is essentially a wrapper around the BitMap
// A generic CM bit map. This is essentially a wrapper around the BitMap
// class, with one bit per (1<<_shifter) HeapWords.
// class, with one bit per (1<<_shifter) HeapWords.
...
...
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
浏览文件 @
aea2819e
...
@@ -1192,6 +1192,7 @@ bool G1CollectedHeap::do_collection(bool explicit_gc,
...
@@ -1192,6 +1192,7 @@ bool G1CollectedHeap::do_collection(bool explicit_gc,
return
false
;
return
false
;
}
}
DTraceGCProbeMarker
gc_probe_marker
(
true
/* full */
);
ResourceMark
rm
;
ResourceMark
rm
;
if
(
PrintHeapAtGC
)
{
if
(
PrintHeapAtGC
)
{
...
@@ -1768,6 +1769,7 @@ G1CollectedHeap::G1CollectedHeap(G1CollectorPolicy* policy_) :
...
@@ -1768,6 +1769,7 @@ G1CollectedHeap::G1CollectedHeap(G1CollectorPolicy* policy_) :
_g1_policy
(
policy_
),
_g1_policy
(
policy_
),
_dirty_card_queue_set
(
false
),
_dirty_card_queue_set
(
false
),
_into_cset_dirty_card_queue_set
(
false
),
_into_cset_dirty_card_queue_set
(
false
),
_is_alive_closure
(
this
),
_ref_processor
(
NULL
),
_ref_processor
(
NULL
),
_process_strong_tasks
(
new
SubTasksDone
(
G1H_PS_NumElements
)),
_process_strong_tasks
(
new
SubTasksDone
(
G1H_PS_NumElements
)),
_bot_shared
(
NULL
),
_bot_shared
(
NULL
),
...
@@ -2061,7 +2063,8 @@ void G1CollectedHeap::ref_processing_init() {
...
@@ -2061,7 +2063,8 @@ void G1CollectedHeap::ref_processing_init() {
mr
,
// span
mr
,
// span
false
,
// Reference discovery is not atomic
false
,
// Reference discovery is not atomic
true
,
// mt_discovery
true
,
// mt_discovery
NULL
,
// is alive closure: need to fill this in for efficiency
&
_is_alive_closure
,
// is alive closure
// for efficiency
ParallelGCThreads
,
ParallelGCThreads
,
ParallelRefProcEnabled
,
ParallelRefProcEnabled
,
true
);
// Setting next fields of discovered
true
);
// Setting next fields of discovered
...
@@ -3211,13 +3214,14 @@ G1CollectedHeap::do_collection_pause_at_safepoint(double target_pause_time_ms) {
...
@@ -3211,13 +3214,14 @@ G1CollectedHeap::do_collection_pause_at_safepoint(double target_pause_time_ms) {
return
false
;
return
false
;
}
}
DTraceGCProbeMarker
gc_probe_marker
(
false
/* full */
);
ResourceMark
rm
;
if
(
PrintHeapAtGC
)
{
if
(
PrintHeapAtGC
)
{
Universe
::
print_heap_before_gc
();
Universe
::
print_heap_before_gc
();
}
}
{
{
ResourceMark
rm
;
// This call will decide whether this pause is an initial-mark
// This call will decide whether this pause is an initial-mark
// pause. If it is, during_initial_mark_pause() will return true
// pause. If it is, during_initial_mark_pause() will return true
// for the duration of this pause.
// for the duration of this pause.
...
@@ -3956,8 +3960,6 @@ void G1CollectedHeap::remove_self_forwarding_pointers() {
...
@@ -3956,8 +3960,6 @@ void G1CollectedHeap::remove_self_forwarding_pointers() {
// Now restore saved marks, if any.
// Now restore saved marks, if any.
if
(
_objs_with_preserved_marks
!=
NULL
)
{
if
(
_objs_with_preserved_marks
!=
NULL
)
{
assert
(
_preserved_marks_of_objs
!=
NULL
,
"Both or none."
);
assert
(
_preserved_marks_of_objs
!=
NULL
,
"Both or none."
);
assert
(
_objs_with_preserved_marks
->
length
()
==
_preserved_marks_of_objs
->
length
(),
"Both or none."
);
guarantee
(
_objs_with_preserved_marks
->
length
()
==
guarantee
(
_objs_with_preserved_marks
->
length
()
==
_preserved_marks_of_objs
->
length
(),
"Both or none."
);
_preserved_marks_of_objs
->
length
(),
"Both or none."
);
for
(
int
i
=
0
;
i
<
_objs_with_preserved_marks
->
length
();
i
++
)
{
for
(
int
i
=
0
;
i
<
_objs_with_preserved_marks
->
length
();
i
++
)
{
...
@@ -4052,7 +4054,10 @@ void G1CollectedHeap::handle_evacuation_failure_common(oop old, markOop m) {
...
@@ -4052,7 +4054,10 @@ void G1CollectedHeap::handle_evacuation_failure_common(oop old, markOop m) {
}
}
void
G1CollectedHeap
::
preserve_mark_if_necessary
(
oop
obj
,
markOop
m
)
{
void
G1CollectedHeap
::
preserve_mark_if_necessary
(
oop
obj
,
markOop
m
)
{
if
(
m
!=
markOopDesc
::
prototype
())
{
assert
(
evacuation_failed
(),
"Oversaving!"
);
// We want to call the "for_promotion_failure" version only in the
// case of a promotion failure.
if
(
m
->
must_be_preserved_for_promotion_failure
(
obj
))
{
if
(
_objs_with_preserved_marks
==
NULL
)
{
if
(
_objs_with_preserved_marks
==
NULL
)
{
assert
(
_preserved_marks_of_objs
==
NULL
,
"Both or none."
);
assert
(
_preserved_marks_of_objs
==
NULL
,
"Both or none."
);
_objs_with_preserved_marks
=
_objs_with_preserved_marks
=
...
...
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
浏览文件 @
aea2819e
...
@@ -849,6 +849,12 @@ protected:
...
@@ -849,6 +849,12 @@ protected:
void
print_gc_alloc_regions
();
void
print_gc_alloc_regions
();
#endif // !PRODUCT
#endif // !PRODUCT
// Instance of the concurrent mark is_alive closure for embedding
// into the reference processor as the is_alive_non_header. This
// prevents unnecessary additions to the discovered lists during
// concurrent discovery.
G1CMIsAliveClosure
_is_alive_closure
;
// ("Weak") Reference processing support
// ("Weak") Reference processing support
ReferenceProcessor
*
_ref_processor
;
ReferenceProcessor
*
_ref_processor
;
...
@@ -893,7 +899,7 @@ public:
...
@@ -893,7 +899,7 @@ public:
// specified by the policy object.
// specified by the policy object.
jint
initialize
();
jint
initialize
();
void
ref_processing_init
();
v
irtual
v
oid
ref_processing_init
();
void
set_par_threads
(
int
t
)
{
void
set_par_threads
(
int
t
)
{
SharedHeap
::
set_par_threads
(
t
);
SharedHeap
::
set_par_threads
(
t
);
...
...
src/share/vm/gc_implementation/parNew/parNewGeneration.cpp
浏览文件 @
aea2819e
...
@@ -1058,10 +1058,11 @@ bool ParNewGeneration::is_legal_forward_ptr(oop p) {
...
@@ -1058,10 +1058,11 @@ bool ParNewGeneration::is_legal_forward_ptr(oop p) {
#endif
#endif
void
ParNewGeneration
::
preserve_mark_if_necessary
(
oop
obj
,
markOop
m
)
{
void
ParNewGeneration
::
preserve_mark_if_necessary
(
oop
obj
,
markOop
m
)
{
if
((
m
!=
markOopDesc
::
prototype
())
&&
if
(
m
->
must_be_preserved_for_promotion_failure
(
obj
))
{
(
!
UseBiasedLocking
||
(
m
!=
markOopDesc
::
biased_locking_prototype
())))
{
// We should really have separate per-worker stacks, rather
// than use locking of a common pair of stacks.
MutexLocker
ml
(
ParGCRareEvent_lock
);
MutexLocker
ml
(
ParGCRareEvent_lock
);
DefNewGeneration
::
preserve_mark_if_necessary
(
obj
,
m
);
preserve_mark
(
obj
,
m
);
}
}
}
}
...
...
src/share/vm/gc_implementation/parallelScavenge/psScavenge.cpp
浏览文件 @
aea2819e
...
@@ -694,6 +694,8 @@ void PSScavenge::clean_up_failed_promotion() {
...
@@ -694,6 +694,8 @@ void PSScavenge::clean_up_failed_promotion() {
void
PSScavenge
::
oop_promotion_failed
(
oop
obj
,
markOop
obj_mark
)
{
void
PSScavenge
::
oop_promotion_failed
(
oop
obj
,
markOop
obj_mark
)
{
_promotion_failed
=
true
;
_promotion_failed
=
true
;
if
(
obj_mark
->
must_be_preserved_for_promotion_failure
(
obj
))
{
if
(
obj_mark
->
must_be_preserved_for_promotion_failure
(
obj
))
{
// Should use per-worker private stakcs hetre rather than
// locking a common pair of stacks.
ThreadCritical
tc
;
ThreadCritical
tc
;
_preserved_oop_stack
.
push
(
obj
);
_preserved_oop_stack
.
push
(
obj
);
_preserved_mark_stack
.
push
(
obj_mark
);
_preserved_mark_stack
.
push
(
obj_mark
);
...
...
src/share/vm/gc_implementation/shared/vmGCOperations.hpp
浏览文件 @
aea2819e
...
@@ -209,4 +209,15 @@ class VM_GenCollectForPermanentAllocation: public VM_GC_Operation {
...
@@ -209,4 +209,15 @@ class VM_GenCollectForPermanentAllocation: public VM_GC_Operation {
HeapWord
*
result
()
const
{
return
_res
;
}
HeapWord
*
result
()
const
{
return
_res
;
}
};
};
class
DTraceGCProbeMarker
:
public
StackObj
{
public:
DTraceGCProbeMarker
(
bool
full
)
{
VM_GC_Operation
::
notify_gc_begin
(
full
);
}
~
DTraceGCProbeMarker
()
{
VM_GC_Operation
::
notify_gc_end
();
}
};
#endif // SHARE_VM_GC_IMPLEMENTATION_SHARED_VMGCOPERATIONS_HPP
#endif // SHARE_VM_GC_IMPLEMENTATION_SHARED_VMGCOPERATIONS_HPP
src/share/vm/memory/defNewGeneration.cpp
浏览文件 @
aea2819e
...
@@ -684,23 +684,28 @@ void DefNewGeneration::remove_forwarding_pointers() {
...
@@ -684,23 +684,28 @@ void DefNewGeneration::remove_forwarding_pointers() {
_preserved_marks_of_objs
.
clear
(
true
);
_preserved_marks_of_objs
.
clear
(
true
);
}
}
void
DefNewGeneration
::
preserve_mark_if_necessary
(
oop
obj
,
markOop
m
)
{
void
DefNewGeneration
::
preserve_mark
(
oop
obj
,
markOop
m
)
{
if
(
m
->
must_be_preserved_for_promotion_failure
(
obj
))
{
assert
(
promotion_failed
()
&&
m
->
must_be_preserved_for_promotion_failure
(
obj
),
"Oversaving!"
);
_objs_with_preserved_marks
.
push
(
obj
);
_objs_with_preserved_marks
.
push
(
obj
);
_preserved_marks_of_objs
.
push
(
m
);
_preserved_marks_of_objs
.
push
(
m
);
}
void
DefNewGeneration
::
preserve_mark_if_necessary
(
oop
obj
,
markOop
m
)
{
if
(
m
->
must_be_preserved_for_promotion_failure
(
obj
))
{
preserve_mark
(
obj
,
m
);
}
}
}
}
void
DefNewGeneration
::
handle_promotion_failure
(
oop
old
)
{
void
DefNewGeneration
::
handle_promotion_failure
(
oop
old
)
{
preserve_mark_if_necessary
(
old
,
old
->
mark
());
if
(
PrintPromotionFailure
&&
!
_promotion_failed
)
{
if
(
!
_promotion_failed
&&
PrintPromotionFailure
)
{
gclog_or_tty
->
print
(
" (promotion failure size = "
SIZE_FORMAT
") "
,
gclog_or_tty
->
print
(
" (promotion failure size = "
SIZE_FORMAT
") "
,
old
->
size
());
old
->
size
());
}
}
_promotion_failed
=
true
;
preserve_mark_if_necessary
(
old
,
old
->
mark
());
// forward to self
// forward to self
old
->
forward_to
(
old
);
old
->
forward_to
(
old
);
_promotion_failed
=
true
;
_promo_failure_scan_stack
.
push
(
old
);
_promo_failure_scan_stack
.
push
(
old
);
...
...
src/share/vm/memory/defNewGeneration.hpp
浏览文件 @
aea2819e
...
@@ -85,6 +85,7 @@ protected:
...
@@ -85,6 +85,7 @@ protected:
// Preserve the mark of "obj", if necessary, in preparation for its mark
// Preserve the mark of "obj", if necessary, in preparation for its mark
// word being overwritten with a self-forwarding-pointer.
// word being overwritten with a self-forwarding-pointer.
void
preserve_mark_if_necessary
(
oop
obj
,
markOop
m
);
void
preserve_mark_if_necessary
(
oop
obj
,
markOop
m
);
void
preserve_mark
(
oop
obj
,
markOop
m
);
// work routine used by the above
// Together, these keep <object with a preserved mark, mark value> pairs.
// Together, these keep <object with a preserved mark, mark value> pairs.
// They should always contain the same number of elements.
// They should always contain the same number of elements.
...
...
src/share/vm/oops/markOop.inline.hpp
浏览文件 @
aea2819e
...
@@ -30,7 +30,7 @@
...
@@ -30,7 +30,7 @@
#include "oops/markOop.hpp"
#include "oops/markOop.hpp"
#include "runtime/globals.hpp"
#include "runtime/globals.hpp"
// Should this header be preserved during GC?
// Should this header be preserved during GC
(when biased locking is enabled)
?
inline
bool
markOopDesc
::
must_be_preserved_with_bias
(
oop
obj_containing_mark
)
const
{
inline
bool
markOopDesc
::
must_be_preserved_with_bias
(
oop
obj_containing_mark
)
const
{
assert
(
UseBiasedLocking
,
"unexpected"
);
assert
(
UseBiasedLocking
,
"unexpected"
);
if
(
has_bias_pattern
())
{
if
(
has_bias_pattern
())
{
...
@@ -47,14 +47,15 @@ inline bool markOopDesc::must_be_preserved_with_bias(oop obj_containing_mark) co
...
@@ -47,14 +47,15 @@ inline bool markOopDesc::must_be_preserved_with_bias(oop obj_containing_mark) co
return
(
!
is_unlocked
()
||
!
has_no_hash
());
return
(
!
is_unlocked
()
||
!
has_no_hash
());
}
}
// Should this header be preserved during GC?
inline
bool
markOopDesc
::
must_be_preserved
(
oop
obj_containing_mark
)
const
{
inline
bool
markOopDesc
::
must_be_preserved
(
oop
obj_containing_mark
)
const
{
if
(
!
UseBiasedLocking
)
if
(
!
UseBiasedLocking
)
return
(
!
is_unlocked
()
||
!
has_no_hash
());
return
(
!
is_unlocked
()
||
!
has_no_hash
());
return
must_be_preserved_with_bias
(
obj_containing_mark
);
return
must_be_preserved_with_bias
(
obj_containing_mark
);
}
}
// Should this header
(including its age bits) be preserved in th
e
// Should this header
be preserved in the case of a promotion failur
e
//
case of a promotion failure during scavenge
?
//
during scavenge (when biased locking is enabled)
?
inline
bool
markOopDesc
::
must_be_preserved_with_bias_for_promotion_failure
(
oop
obj_containing_mark
)
const
{
inline
bool
markOopDesc
::
must_be_preserved_with_bias_for_promotion_failure
(
oop
obj_containing_mark
)
const
{
assert
(
UseBiasedLocking
,
"unexpected"
);
assert
(
UseBiasedLocking
,
"unexpected"
);
// We don't explicitly save off the mark words of biased and
// We don't explicitly save off the mark words of biased and
...
@@ -70,18 +71,20 @@ inline bool markOopDesc::must_be_preserved_with_bias_for_promotion_failure(oop o
...
@@ -70,18 +71,20 @@ inline bool markOopDesc::must_be_preserved_with_bias_for_promotion_failure(oop o
prototype_for_object
(
obj_containing_mark
)
->
has_bias_pattern
())
{
prototype_for_object
(
obj_containing_mark
)
->
has_bias_pattern
())
{
return
true
;
return
true
;
}
}
return
(
this
!=
prototype
());
return
(
!
is_unlocked
()
||
!
has_no_hash
());
}
}
// Should this header be preserved in the case of a promotion failure
// during scavenge?
inline
bool
markOopDesc
::
must_be_preserved_for_promotion_failure
(
oop
obj_containing_mark
)
const
{
inline
bool
markOopDesc
::
must_be_preserved_for_promotion_failure
(
oop
obj_containing_mark
)
const
{
if
(
!
UseBiasedLocking
)
if
(
!
UseBiasedLocking
)
return
(
this
!=
prototype
());
return
(
!
is_unlocked
()
||
!
has_no_hash
());
return
must_be_preserved_with_bias_for_promotion_failure
(
obj_containing_mark
);
return
must_be_preserved_with_bias_for_promotion_failure
(
obj_containing_mark
);
}
}
// S
hould this header (including its age bits) be preserved in the
// S
ame as must_be_preserved_with_bias_for_promotion_failure() except that
//
case of a scavenge in which CMS is the old generation?
//
it takes a klassOop argument, instead of the object of which this is the mark word.
inline
bool
markOopDesc
::
must_be_preserved_with_bias_for_cms_scavenge
(
klassOop
klass_of_obj_containing_mark
)
const
{
inline
bool
markOopDesc
::
must_be_preserved_with_bias_for_cms_scavenge
(
klassOop
klass_of_obj_containing_mark
)
const
{
assert
(
UseBiasedLocking
,
"unexpected"
);
assert
(
UseBiasedLocking
,
"unexpected"
);
// CMS scavenges preserve mark words in similar fashion to promotion failures; see above
// CMS scavenges preserve mark words in similar fashion to promotion failures; see above
...
@@ -89,11 +92,14 @@ inline bool markOopDesc::must_be_preserved_with_bias_for_cms_scavenge(klassOop k
...
@@ -89,11 +92,14 @@ inline bool markOopDesc::must_be_preserved_with_bias_for_cms_scavenge(klassOop k
klass_of_obj_containing_mark
->
klass_part
()
->
prototype_header
()
->
has_bias_pattern
())
{
klass_of_obj_containing_mark
->
klass_part
()
->
prototype_header
()
->
has_bias_pattern
())
{
return
true
;
return
true
;
}
}
return
(
this
!=
prototype
());
return
(
!
is_unlocked
()
||
!
has_no_hash
());
}
}
// Same as must_be_preserved_for_promotion_failure() except that
// it takes a klassOop argument, instead of the object of which this is the mark word.
inline
bool
markOopDesc
::
must_be_preserved_for_cms_scavenge
(
klassOop
klass_of_obj_containing_mark
)
const
{
inline
bool
markOopDesc
::
must_be_preserved_for_cms_scavenge
(
klassOop
klass_of_obj_containing_mark
)
const
{
if
(
!
UseBiasedLocking
)
if
(
!
UseBiasedLocking
)
return
(
this
!=
prototype
());
return
(
!
is_unlocked
()
||
!
has_no_hash
());
return
must_be_preserved_with_bias_for_cms_scavenge
(
klass_of_obj_containing_mark
);
return
must_be_preserved_with_bias_for_cms_scavenge
(
klass_of_obj_containing_mark
);
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录