author | brutisso |
Mon, 21 Nov 2011 07:47:34 +0100 | |
changeset 11170 | 7663e46f3a54 |
parent 7397 | 5b173b4ca846 |
child 22859 | 7b88983393b7 |
permissions | -rw-r--r-- |
1 | 1 |
/* |
7397 | 2 |
* Copyright (c) 2001, 2010, Oracle and/or its affiliates. All rights reserved. |
1 | 3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
* |
|
5 |
* This code is free software; you can redistribute it and/or modify it |
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
|
7 |
* published by the Free Software Foundation. |
|
8 |
* |
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
|
13 |
* accompanied this code). |
|
14 |
* |
|
15 |
* You should have received a copy of the GNU General Public License version |
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
18 |
* |
|
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
4886
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
4886
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
4886
diff
changeset
|
21 |
* questions. |
1 | 22 |
* |
23 |
*/ |
|
24 |
||
7397 | 25 |
#ifndef SHARE_VM_MEMORY_BARRIERSET_INLINE_HPP |
26 |
#define SHARE_VM_MEMORY_BARRIERSET_INLINE_HPP |
|
27 |
||
28 |
#include "memory/barrierSet.hpp" |
|
29 |
#include "memory/cardTableModRefBS.hpp" |
|
30 |
||
1 | 31 |
// Inline functions of BarrierSet, which de-virtualize certain |
3262
30d1c247fc25
6700789: G1: Enable use of compressed oops with G1 heaps
ysr
parents:
1388
diff
changeset
|
32 |
// performance-critical calls when the barrier is the most common |
1 | 33 |
// card-table kind. |
34 |
||
3262
30d1c247fc25
6700789: G1: Enable use of compressed oops with G1 heaps
ysr
parents:
1388
diff
changeset
|
35 |
template <class T> void BarrierSet::write_ref_field_pre(T* field, oop new_val) { |
1374
4c24294029a9
6711316: Open source the Garbage-First garbage collector
ysr
parents:
360
diff
changeset
|
36 |
if (kind() == CardTableModRef) { |
4c24294029a9
6711316: Open source the Garbage-First garbage collector
ysr
parents:
360
diff
changeset
|
37 |
((CardTableModRefBS*)this)->inline_write_ref_field_pre(field, new_val); |
4c24294029a9
6711316: Open source the Garbage-First garbage collector
ysr
parents:
360
diff
changeset
|
38 |
} else { |
4c24294029a9
6711316: Open source the Garbage-First garbage collector
ysr
parents:
360
diff
changeset
|
39 |
write_ref_field_pre_work(field, new_val); |
4c24294029a9
6711316: Open source the Garbage-First garbage collector
ysr
parents:
360
diff
changeset
|
40 |
} |
4c24294029a9
6711316: Open source the Garbage-First garbage collector
ysr
parents:
360
diff
changeset
|
41 |
} |
4c24294029a9
6711316: Open source the Garbage-First garbage collector
ysr
parents:
360
diff
changeset
|
42 |
|
360
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
1
diff
changeset
|
43 |
void BarrierSet::write_ref_field(void* field, oop new_val) { |
1 | 44 |
if (kind() == CardTableModRef) { |
45 |
((CardTableModRefBS*)this)->inline_write_ref_field(field, new_val); |
|
46 |
} else { |
|
47 |
write_ref_field_work(field, new_val); |
|
48 |
} |
|
49 |
} |
|
50 |
||
4461
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
51 |
// count is number of array elements being written |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
52 |
void BarrierSet::write_ref_array(HeapWord* start, size_t count) { |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
53 |
assert(count <= (size_t)max_intx, "count too large"); |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
54 |
HeapWord* end = (HeapWord*)((char*)start + (count*heapOopSize)); |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
55 |
// In the case of compressed oops, start and end may potentially be misaligned; |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
56 |
// so we need to conservatively align the first downward (this is not |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
57 |
// strictly necessary for current uses, but a case of good hygiene and, |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
58 |
// if you will, aesthetics) and the second upward (this is essential for |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
59 |
// current uses) to a HeapWord boundary, so we mark all cards overlapping |
4886
a2f9a66475b3
6904516: More object array barrier fixes, following up on 6906727
ysr
parents:
4461
diff
changeset
|
60 |
// this write. If this evolves in the future to calling a |
4461
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
61 |
// logging barrier of narrow oop granularity, like the pre-barrier for G1 |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
62 |
// (mentioned here merely by way of example), we will need to change this |
4886
a2f9a66475b3
6904516: More object array barrier fixes, following up on 6906727
ysr
parents:
4461
diff
changeset
|
63 |
// interface, so it is "exactly precise" (if i may be allowed the adverbial |
a2f9a66475b3
6904516: More object array barrier fixes, following up on 6906727
ysr
parents:
4461
diff
changeset
|
64 |
// redundancy for emphasis) and does not include narrow oop slots not |
a2f9a66475b3
6904516: More object array barrier fixes, following up on 6906727
ysr
parents:
4461
diff
changeset
|
65 |
// included in the original write interval. |
4461
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
66 |
HeapWord* aligned_start = (HeapWord*)align_size_down((uintptr_t)start, HeapWordSize); |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
67 |
HeapWord* aligned_end = (HeapWord*)align_size_up ((uintptr_t)end, HeapWordSize); |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
68 |
// If compressed oops were not being used, these should already be aligned |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
69 |
assert(UseCompressedOops || (aligned_start == start && aligned_end == end), |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
70 |
"Expected heap word alignment of start and end"); |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
71 |
#if 0 |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
72 |
warning("Post:\t" INTPTR_FORMAT "[" SIZE_FORMAT "] : [" INTPTR_FORMAT","INTPTR_FORMAT")\t", |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
73 |
start, count, aligned_start, aligned_end); |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
74 |
#endif |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
75 |
write_ref_array_work(MemRegion(aligned_start, aligned_end)); |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
76 |
} |
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
77 |
|
c17c526d36ef
6906727: UseCompressedOops: some card-marking fixes related to object arrays
ysr
parents:
3262
diff
changeset
|
78 |
|
1 | 79 |
void BarrierSet::write_region(MemRegion mr) { |
80 |
if (kind() == CardTableModRef) { |
|
81 |
((CardTableModRefBS*)this)->inline_write_region(mr); |
|
82 |
} else { |
|
83 |
write_region_work(mr); |
|
84 |
} |
|
85 |
} |
|
7397 | 86 |
|
87 |
#endif // SHARE_VM_MEMORY_BARRIERSET_INLINE_HPP |