Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
677633f1
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看板
提交
677633f1
编写于
1月 26, 2011
作者:
J
johnc
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
477822c8
1498a56a
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
171 addition
and
36 deletion
+171
-36
src/share/vm/gc_implementation/g1/concurrentMark.cpp
src/share/vm/gc_implementation/g1/concurrentMark.cpp
+33
-21
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
+4
-1
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
+7
-5
src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp
src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp
+19
-2
src/share/vm/gc_implementation/g1/heapRegionRemSet.hpp
src/share/vm/gc_implementation/g1/heapRegionRemSet.hpp
+13
-4
src/share/vm/gc_implementation/g1/sparsePRT.cpp
src/share/vm/gc_implementation/g1/sparsePRT.cpp
+46
-1
src/share/vm/gc_implementation/g1/sparsePRT.hpp
src/share/vm/gc_implementation/g1/sparsePRT.hpp
+49
-2
未找到文件。
src/share/vm/gc_implementation/g1/concurrentMark.cpp
浏览文件 @
677633f1
...
@@ -1512,21 +1512,19 @@ class G1NoteEndOfConcMarkClosure : public HeapRegionClosure {
...
@@ -1512,21 +1512,19 @@ class G1NoteEndOfConcMarkClosure : public HeapRegionClosure {
size_t
_max_live_bytes
;
size_t
_max_live_bytes
;
size_t
_regions_claimed
;
size_t
_regions_claimed
;
size_t
_freed_bytes
;
size_t
_freed_bytes
;
FreeRegionList
_local_cleanup_list
;
FreeRegionList
*
_local_cleanup_list
;
HumongousRegionSet
_humongous_proxy_set
;
HumongousRegionSet
*
_humongous_proxy_set
;
HRRSCleanupTask
*
_hrrs_cleanup_task
;
double
_claimed_region_time
;
double
_claimed_region_time
;
double
_max_region_time
;
double
_max_region_time
;
public:
public:
G1NoteEndOfConcMarkClosure
(
G1CollectedHeap
*
g1
,
G1NoteEndOfConcMarkClosure
(
G1CollectedHeap
*
g1
,
int
worker_num
);
int
worker_num
,
FreeRegionList
*
local_cleanup_list
,
HumongousRegionSet
*
humongous_proxy_set
,
HRRSCleanupTask
*
hrrs_cleanup_task
);
size_t
freed_bytes
()
{
return
_freed_bytes
;
}
size_t
freed_bytes
()
{
return
_freed_bytes
;
}
FreeRegionList
*
local_cleanup_list
()
{
return
&
_local_cleanup_list
;
}
HumongousRegionSet
*
humongous_proxy_set
()
{
return
&
_humongous_proxy_set
;
}
bool
doHeapRegion
(
HeapRegion
*
r
);
bool
doHeapRegion
(
HeapRegion
*
r
);
...
@@ -1553,7 +1551,12 @@ public:
...
@@ -1553,7 +1551,12 @@ public:
void
work
(
int
i
)
{
void
work
(
int
i
)
{
double
start
=
os
::
elapsedTime
();
double
start
=
os
::
elapsedTime
();
G1NoteEndOfConcMarkClosure
g1_note_end
(
_g1h
,
i
);
FreeRegionList
local_cleanup_list
(
"Local Cleanup List"
);
HumongousRegionSet
humongous_proxy_set
(
"Local Cleanup Humongous Proxy Set"
);
HRRSCleanupTask
hrrs_cleanup_task
;
G1NoteEndOfConcMarkClosure
g1_note_end
(
_g1h
,
i
,
&
local_cleanup_list
,
&
humongous_proxy_set
,
&
hrrs_cleanup_task
);
if
(
G1CollectedHeap
::
use_parallel_gc_threads
())
{
if
(
G1CollectedHeap
::
use_parallel_gc_threads
())
{
_g1h
->
heap_region_par_iterate_chunked
(
&
g1_note_end
,
i
,
_g1h
->
heap_region_par_iterate_chunked
(
&
g1_note_end
,
i
,
HeapRegion
::
NoteEndClaimValue
);
HeapRegion
::
NoteEndClaimValue
);
...
@@ -1565,15 +1568,17 @@ public:
...
@@ -1565,15 +1568,17 @@ public:
// Now update the lists
// Now update the lists
_g1h
->
update_sets_after_freeing_regions
(
g1_note_end
.
freed_bytes
(),
_g1h
->
update_sets_after_freeing_regions
(
g1_note_end
.
freed_bytes
(),
NULL
/* free_list */
,
NULL
/* free_list */
,
g1_note_end
.
humongous_proxy_set
()
,
&
humongous_proxy_set
,
true
/* par */
);
true
/* par */
);
{
{
MutexLockerEx
x
(
ParGCRareEvent_lock
,
Mutex
::
_no_safepoint_check_flag
);
MutexLockerEx
x
(
ParGCRareEvent_lock
,
Mutex
::
_no_safepoint_check_flag
);
_max_live_bytes
+=
g1_note_end
.
max_live_bytes
();
_max_live_bytes
+=
g1_note_end
.
max_live_bytes
();
_freed_bytes
+=
g1_note_end
.
freed_bytes
();
_freed_bytes
+=
g1_note_end
.
freed_bytes
();
_cleanup_list
->
add_as_tail
(
g1_note_end
.
local_cleanup_list
());
_cleanup_list
->
add_as_tail
(
&
local_cleanup_list
);
assert
(
g1_note_end
.
local_cleanup_list
()
->
is_empty
(),
"post-condition"
);
assert
(
local_cleanup_list
.
is_empty
(),
"post-condition"
);
HeapRegionRemSet
::
finish_cleanup_task
(
&
hrrs_cleanup_task
);
}
}
double
end
=
os
::
elapsedTime
();
double
end
=
os
::
elapsedTime
();
if
(
G1PrintParCleanupStats
)
{
if
(
G1PrintParCleanupStats
)
{
...
@@ -1614,13 +1619,17 @@ public:
...
@@ -1614,13 +1619,17 @@ public:
G1NoteEndOfConcMarkClosure
::
G1NoteEndOfConcMarkClosure
::
G1NoteEndOfConcMarkClosure
(
G1CollectedHeap
*
g1
,
G1NoteEndOfConcMarkClosure
(
G1CollectedHeap
*
g1
,
int
worker_num
)
int
worker_num
,
FreeRegionList
*
local_cleanup_list
,
HumongousRegionSet
*
humongous_proxy_set
,
HRRSCleanupTask
*
hrrs_cleanup_task
)
:
_g1
(
g1
),
_worker_num
(
worker_num
),
:
_g1
(
g1
),
_worker_num
(
worker_num
),
_max_live_bytes
(
0
),
_regions_claimed
(
0
),
_max_live_bytes
(
0
),
_regions_claimed
(
0
),
_freed_bytes
(
0
),
_freed_bytes
(
0
),
_claimed_region_time
(
0.0
),
_max_region_time
(
0.0
),
_claimed_region_time
(
0.0
),
_max_region_time
(
0.0
),
_local_cleanup_list
(
"Local Cleanup List"
),
_local_cleanup_list
(
local_cleanup_list
),
_humongous_proxy_set
(
"Local Cleanup Humongous Proxy Set"
)
{
}
_humongous_proxy_set
(
humongous_proxy_set
),
_hrrs_cleanup_task
(
hrrs_cleanup_task
)
{
}
bool
G1NoteEndOfConcMarkClosure
::
doHeapRegion
(
HeapRegion
*
hr
)
{
bool
G1NoteEndOfConcMarkClosure
::
doHeapRegion
(
HeapRegion
*
hr
)
{
// We use a claim value of zero here because all regions
// We use a claim value of zero here because all regions
...
@@ -1631,11 +1640,12 @@ bool G1NoteEndOfConcMarkClosure::doHeapRegion(HeapRegion *hr) {
...
@@ -1631,11 +1640,12 @@ bool G1NoteEndOfConcMarkClosure::doHeapRegion(HeapRegion *hr) {
_regions_claimed
++
;
_regions_claimed
++
;
hr
->
note_end_of_marking
();
hr
->
note_end_of_marking
();
_max_live_bytes
+=
hr
->
max_live_bytes
();
_max_live_bytes
+=
hr
->
max_live_bytes
();
_g1
->
free_region_if_totally_empty
(
hr
,
_g1
->
free_region_if_empty
(
hr
,
&
_freed_bytes
,
&
_freed_bytes
,
&
_local_cleanup_list
,
_local_cleanup_list
,
&
_humongous_proxy_set
,
_humongous_proxy_set
,
true
/* par */
);
_hrrs_cleanup_task
,
true
/* par */
);
double
region_time
=
(
os
::
elapsedTime
()
-
start
);
double
region_time
=
(
os
::
elapsedTime
()
-
start
);
_claimed_region_time
+=
region_time
;
_claimed_region_time
+=
region_time
;
if
(
region_time
>
_max_region_time
)
_max_region_time
=
region_time
;
if
(
region_time
>
_max_region_time
)
_max_region_time
=
region_time
;
...
@@ -1671,6 +1681,8 @@ void ConcurrentMark::cleanup() {
...
@@ -1671,6 +1681,8 @@ void ConcurrentMark::cleanup() {
double
start
=
os
::
elapsedTime
();
double
start
=
os
::
elapsedTime
();
HeapRegionRemSet
::
reset_for_cleanup_tasks
();
// Do counting once more with the world stopped for good measure.
// Do counting once more with the world stopped for good measure.
G1ParFinalCountTask
g1_par_count_task
(
g1h
,
nextMarkBitMap
(),
G1ParFinalCountTask
g1_par_count_task
(
g1h
,
nextMarkBitMap
(),
&
_region_bm
,
&
_card_bm
);
&
_region_bm
,
&
_card_bm
);
...
...
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
浏览文件 @
677633f1
...
@@ -4925,10 +4925,11 @@ void G1CollectedHeap::evacuate_collection_set() {
...
@@ -4925,10 +4925,11 @@ void G1CollectedHeap::evacuate_collection_set() {
COMPILER2_PRESENT
(
DerivedPointerTable
::
update_pointers
());
COMPILER2_PRESENT
(
DerivedPointerTable
::
update_pointers
());
}
}
void
G1CollectedHeap
::
free_region_if_
totally_
empty
(
HeapRegion
*
hr
,
void
G1CollectedHeap
::
free_region_if_empty
(
HeapRegion
*
hr
,
size_t
*
pre_used
,
size_t
*
pre_used
,
FreeRegionList
*
free_list
,
FreeRegionList
*
free_list
,
HumongousRegionSet
*
humongous_proxy_set
,
HumongousRegionSet
*
humongous_proxy_set
,
HRRSCleanupTask
*
hrrs_cleanup_task
,
bool
par
)
{
bool
par
)
{
if
(
hr
->
used
()
>
0
&&
hr
->
max_live_bytes
()
==
0
&&
!
hr
->
is_young
())
{
if
(
hr
->
used
()
>
0
&&
hr
->
max_live_bytes
()
==
0
&&
!
hr
->
is_young
())
{
if
(
hr
->
isHumongous
())
{
if
(
hr
->
isHumongous
())
{
...
@@ -4937,6 +4938,8 @@ void G1CollectedHeap::free_region_if_totally_empty(HeapRegion* hr,
...
@@ -4937,6 +4938,8 @@ void G1CollectedHeap::free_region_if_totally_empty(HeapRegion* hr,
}
else
{
}
else
{
free_region
(
hr
,
pre_used
,
free_list
,
par
);
free_region
(
hr
,
pre_used
,
free_list
,
par
);
}
}
}
else
{
hr
->
rem_set
()
->
do_cleanup_work
(
hrrs_cleanup_task
);
}
}
}
}
...
...
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
浏览文件 @
677633f1
...
@@ -40,6 +40,7 @@
...
@@ -40,6 +40,7 @@
class
HeapRegion
;
class
HeapRegion
;
class
HeapRegionSeq
;
class
HeapRegionSeq
;
class
HRRSCleanupTask
;
class
PermanentGenerationSpec
;
class
PermanentGenerationSpec
;
class
GenerationSpec
;
class
GenerationSpec
;
class
OopsInHeapRegionClosure
;
class
OopsInHeapRegionClosure
;
...
@@ -1099,11 +1100,12 @@ public:
...
@@ -1099,11 +1100,12 @@ public:
// all dead. It calls either free_region() or
// all dead. It calls either free_region() or
// free_humongous_region() depending on the type of the region that
// free_humongous_region() depending on the type of the region that
// is passed to it.
// is passed to it.
void
free_region_if_totally_empty
(
HeapRegion
*
hr
,
void
free_region_if_empty
(
HeapRegion
*
hr
,
size_t
*
pre_used
,
size_t
*
pre_used
,
FreeRegionList
*
free_list
,
FreeRegionList
*
free_list
,
HumongousRegionSet
*
humongous_proxy_set
,
HumongousRegionSet
*
humongous_proxy_set
,
bool
par
);
HRRSCleanupTask
*
hrrs_cleanup_task
,
bool
par
);
// It appends the free list to the master free list and updates the
// It appends the free list to the master free list and updates the
// master humongous list according to the contents of the proxy
// master humongous list according to the contents of the proxy
...
...
src/share/vm/gc_implementation/g1/heapRegionRemSet.cpp
浏览文件 @
677633f1
/*
/*
* Copyright (c) 2001, 201
0
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2001, 201
1
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -463,7 +463,6 @@ public:
...
@@ -463,7 +463,6 @@ public:
}
}
static
void
par_contract_all
();
static
void
par_contract_all
();
};
};
void
PosParPRT
::
par_contract_all
()
{
void
PosParPRT
::
par_contract_all
()
{
...
@@ -1070,6 +1069,11 @@ bool OtherRegionsTable::contains_reference_locked(OopOrNarrowOopStar from) const
...
@@ -1070,6 +1069,11 @@ bool OtherRegionsTable::contains_reference_locked(OopOrNarrowOopStar from) const
}
}
void
OtherRegionsTable
::
do_cleanup_work
(
HRRSCleanupTask
*
hrrs_cleanup_task
)
{
_sparse_table
.
do_cleanup_work
(
hrrs_cleanup_task
);
}
// Determines how many threads can add records to an rset in parallel.
// Determines how many threads can add records to an rset in parallel.
// This can be done by either mutator threads together with the
// This can be done by either mutator threads together with the
// concurrent refinement threads or GC threads.
// concurrent refinement threads or GC threads.
...
@@ -1384,6 +1388,19 @@ void HeapRegionRemSet::print_recorded() {
...
@@ -1384,6 +1388,19 @@ void HeapRegionRemSet::print_recorded() {
}
}
}
}
void
HeapRegionRemSet
::
reset_for_cleanup_tasks
()
{
SparsePRT
::
reset_for_cleanup_tasks
();
}
void
HeapRegionRemSet
::
do_cleanup_work
(
HRRSCleanupTask
*
hrrs_cleanup_task
)
{
_other_regions
.
do_cleanup_work
(
hrrs_cleanup_task
);
}
void
HeapRegionRemSet
::
finish_cleanup_task
(
HRRSCleanupTask
*
hrrs_cleanup_task
)
{
SparsePRT
::
finish_cleanup_task
(
hrrs_cleanup_task
);
}
#ifndef PRODUCT
#ifndef PRODUCT
void
HeapRegionRemSet
::
test
()
{
void
HeapRegionRemSet
::
test
()
{
os
::
sleep
(
Thread
::
current
(),
(
jlong
)
5000
,
false
);
os
::
sleep
(
Thread
::
current
(),
(
jlong
)
5000
,
false
);
...
...
src/share/vm/gc_implementation/g1/heapRegionRemSet.hpp
浏览文件 @
677633f1
/*
/*
* Copyright (c) 2001, 201
0
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2001, 201
1
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -38,6 +38,10 @@ class HeapRegionRemSetIterator;
...
@@ -38,6 +38,10 @@ class HeapRegionRemSetIterator;
class
PosParPRT
;
class
PosParPRT
;
class
SparsePRT
;
class
SparsePRT
;
// Essentially a wrapper around SparsePRTCleanupTask. See
// sparsePRT.hpp for more details.
class
HRRSCleanupTask
:
public
SparsePRTCleanupTask
{
};
// The "_coarse_map" is a bitmap with one bit for each region, where set
// The "_coarse_map" is a bitmap with one bit for each region, where set
// bits indicate that the corresponding region may contain some pointer
// bits indicate that the corresponding region may contain some pointer
...
@@ -156,6 +160,8 @@ public:
...
@@ -156,6 +160,8 @@ public:
// "from_hr" is being cleared; remove any entries from it.
// "from_hr" is being cleared; remove any entries from it.
void
clear_incoming_entry
(
HeapRegion
*
from_hr
);
void
clear_incoming_entry
(
HeapRegion
*
from_hr
);
void
do_cleanup_work
(
HRRSCleanupTask
*
hrrs_cleanup_task
);
// Declare the heap size (in # of regions) to the OtherRegionsTable.
// Declare the heap size (in # of regions) to the OtherRegionsTable.
// (Uses it to initialize from_card_cache).
// (Uses it to initialize from_card_cache).
static
void
init_from_card_cache
(
size_t
max_regions
);
static
void
init_from_card_cache
(
size_t
max_regions
);
...
@@ -165,10 +171,8 @@ public:
...
@@ -165,10 +171,8 @@ public:
static
void
shrink_from_card_cache
(
size_t
new_n_regs
);
static
void
shrink_from_card_cache
(
size_t
new_n_regs
);
static
void
print_from_card_cache
();
static
void
print_from_card_cache
();
};
};
class
HeapRegionRemSet
:
public
CHeapObj
{
class
HeapRegionRemSet
:
public
CHeapObj
{
friend
class
VMStructs
;
friend
class
VMStructs
;
friend
class
HeapRegionRemSetIterator
;
friend
class
HeapRegionRemSetIterator
;
...
@@ -342,11 +346,16 @@ public:
...
@@ -342,11 +346,16 @@ public:
static
void
print_recorded
();
static
void
print_recorded
();
static
void
record_event
(
Event
evnt
);
static
void
record_event
(
Event
evnt
);
// These are wrappers for the similarly-named methods on
// SparsePRT. Look at sparsePRT.hpp for more details.
static
void
reset_for_cleanup_tasks
();
void
do_cleanup_work
(
HRRSCleanupTask
*
hrrs_cleanup_task
);
static
void
finish_cleanup_task
(
HRRSCleanupTask
*
hrrs_cleanup_task
);
// Run unit tests.
// Run unit tests.
#ifndef PRODUCT
#ifndef PRODUCT
static
void
test
();
static
void
test
();
#endif
#endif
};
};
class
HeapRegionRemSetIterator
:
public
CHeapObj
{
class
HeapRegionRemSetIterator
:
public
CHeapObj
{
...
...
src/share/vm/gc_implementation/g1/sparsePRT.cpp
浏览文件 @
677633f1
/*
/*
* Copyright (c) 2001, 201
0
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2001, 201
1
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -415,6 +415,38 @@ SparsePRT* SparsePRT::get_from_expanded_list() {
...
@@ -415,6 +415,38 @@ SparsePRT* SparsePRT::get_from_expanded_list() {
return
NULL
;
return
NULL
;
}
}
void
SparsePRT
::
reset_for_cleanup_tasks
()
{
_head_expanded_list
=
NULL
;
}
void
SparsePRT
::
do_cleanup_work
(
SparsePRTCleanupTask
*
sprt_cleanup_task
)
{
if
(
should_be_on_expanded_list
())
{
sprt_cleanup_task
->
add
(
this
);
}
}
void
SparsePRT
::
finish_cleanup_task
(
SparsePRTCleanupTask
*
sprt_cleanup_task
)
{
assert
(
ParGCRareEvent_lock
->
owned_by_self
(),
"pre-condition"
);
SparsePRT
*
head
=
sprt_cleanup_task
->
head
();
SparsePRT
*
tail
=
sprt_cleanup_task
->
tail
();
if
(
head
!=
NULL
)
{
assert
(
tail
!=
NULL
,
"if head is not NULL, so should tail"
);
tail
->
set_next_expanded
(
_head_expanded_list
);
_head_expanded_list
=
head
;
}
else
{
assert
(
tail
==
NULL
,
"if head is NULL, so should tail"
);
}
}
bool
SparsePRT
::
should_be_on_expanded_list
()
{
if
(
_expanded
)
{
assert
(
_cur
!=
_next
,
"if _expanded is true, cur should be != _next"
);
}
else
{
assert
(
_cur
==
_next
,
"if _expanded is false, cur should be == _next"
);
}
return
expanded
();
}
void
SparsePRT
::
cleanup_all
()
{
void
SparsePRT
::
cleanup_all
()
{
// First clean up all expanded tables so they agree on next and cur.
// First clean up all expanded tables so they agree on next and cur.
...
@@ -484,6 +516,7 @@ void SparsePRT::clear() {
...
@@ -484,6 +516,7 @@ void SparsePRT::clear() {
_cur
->
clear
();
_cur
->
clear
();
}
}
_next
=
_cur
;
_next
=
_cur
;
_expanded
=
false
;
}
}
void
SparsePRT
::
cleanup
()
{
void
SparsePRT
::
cleanup
()
{
...
@@ -518,3 +551,15 @@ void SparsePRT::expand() {
...
@@ -518,3 +551,15 @@ void SparsePRT::expand() {
}
}
add_to_expanded_list
(
this
);
add_to_expanded_list
(
this
);
}
}
void
SparsePRTCleanupTask
::
add
(
SparsePRT
*
sprt
)
{
assert
(
sprt
->
should_be_on_expanded_list
(),
"pre-condition"
);
sprt
->
set_next_expanded
(
NULL
);
if
(
_tail
!=
NULL
)
{
_tail
->
set_next_expanded
(
sprt
);
}
else
{
_head
=
sprt
;
}
_tail
=
sprt
;
}
src/share/vm/gc_implementation/g1/sparsePRT.hpp
浏览文件 @
677633f1
/*
/*
* Copyright (c) 2001, 201
0
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2001, 201
1
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -212,8 +212,11 @@ public:
...
@@ -212,8 +212,11 @@ public:
// mutex.
// mutex.
class
SparsePRTIter
;
class
SparsePRTIter
;
class
SparsePRTCleanupTask
;
class
SparsePRT
VALUE_OBJ_CLASS_SPEC
{
class
SparsePRT
VALUE_OBJ_CLASS_SPEC
{
friend
class
SparsePRTCleanupTask
;
// Iterations are done on the _cur hash table, since they only need to
// Iterations are done on the _cur hash table, since they only need to
// see entries visible at the start of a collection pause.
// see entries visible at the start of a collection pause.
// All other operations are done using the _next hash table.
// All other operations are done using the _next hash table.
...
@@ -238,6 +241,8 @@ class SparsePRT VALUE_OBJ_CLASS_SPEC {
...
@@ -238,6 +241,8 @@ class SparsePRT VALUE_OBJ_CLASS_SPEC {
SparsePRT
*
next_expanded
()
{
return
_next_expanded
;
}
SparsePRT
*
next_expanded
()
{
return
_next_expanded
;
}
void
set_next_expanded
(
SparsePRT
*
nxt
)
{
_next_expanded
=
nxt
;
}
void
set_next_expanded
(
SparsePRT
*
nxt
)
{
_next_expanded
=
nxt
;
}
bool
should_be_on_expanded_list
();
static
SparsePRT
*
_head_expanded_list
;
static
SparsePRT
*
_head_expanded_list
;
public:
public:
...
@@ -284,12 +289,36 @@ public:
...
@@ -284,12 +289,36 @@ public:
static
void
add_to_expanded_list
(
SparsePRT
*
sprt
);
static
void
add_to_expanded_list
(
SparsePRT
*
sprt
);
static
SparsePRT
*
get_from_expanded_list
();
static
SparsePRT
*
get_from_expanded_list
();
// The purpose of these three methods is to help the GC workers
// during the cleanup pause to recreate the expanded list, purging
// any tables from it that belong to regions that are freed during
// cleanup (if we don't purge those tables, there is a race that
// causes various crashes; see CR 7014261).
//
// We chose to recreate the expanded list, instead of purging
// entries from it by iterating over it, to avoid this serial phase
// at the end of the cleanup pause.
//
// The three methods below work as follows:
// * reset_for_cleanup_tasks() : Nulls the expanded list head at the
// start of the cleanup pause.
// * do_cleanup_work() : Called by the cleanup workers for every
// region that is not free / is being freed by the cleanup
// pause. It creates a list of expanded tables whose head / tail
// are on the thread-local SparsePRTCleanupTask object.
// * finish_cleanup_task() : Called by the cleanup workers after
// they complete their cleanup task. It adds the local list into
// the global expanded list. It assumes that the
// ParGCRareEvent_lock is being held to ensure MT-safety.
static
void
reset_for_cleanup_tasks
();
void
do_cleanup_work
(
SparsePRTCleanupTask
*
sprt_cleanup_task
);
static
void
finish_cleanup_task
(
SparsePRTCleanupTask
*
sprt_cleanup_task
);
bool
contains_card
(
RegionIdx_t
region_id
,
CardIdx_t
card_index
)
const
{
bool
contains_card
(
RegionIdx_t
region_id
,
CardIdx_t
card_index
)
const
{
return
_next
->
contains_card
(
region_id
,
card_index
);
return
_next
->
contains_card
(
region_id
,
card_index
);
}
}
};
};
class
SparsePRTIter
:
public
RSHashTableIter
{
class
SparsePRTIter
:
public
RSHashTableIter
{
public:
public:
void
init
(
const
SparsePRT
*
sprt
)
{
void
init
(
const
SparsePRT
*
sprt
)
{
...
@@ -300,4 +329,22 @@ public:
...
@@ -300,4 +329,22 @@ public:
}
}
};
};
// This allows each worker during a cleanup pause to create a
// thread-local list of sparse tables that have been expanded and need
// to be processed at the beginning of the next GC pause. This lists
// are concatenated into the single expanded list at the end of the
// cleanup pause.
class
SparsePRTCleanupTask
VALUE_OBJ_CLASS_SPEC
{
private:
SparsePRT
*
_head
;
SparsePRT
*
_tail
;
public:
SparsePRTCleanupTask
()
:
_head
(
NULL
),
_tail
(
NULL
)
{
}
void
add
(
SparsePRT
*
sprt
);
SparsePRT
*
head
()
{
return
_head
;
}
SparsePRT
*
tail
()
{
return
_tail
;
}
};
#endif // SHARE_VM_GC_IMPLEMENTATION_G1_SPARSEPRT_HPP
#endif // SHARE_VM_GC_IMPLEMENTATION_G1_SPARSEPRT_HPP
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录