annotate src/share/vm/gc_implementation/parallelScavenge/adjoiningGenerations.hpp @ 453:c96030fff130

6684579: SoftReference processing can be made more efficient Summary: For current soft-ref clearing policies, we can decide at marking time if a soft-reference will definitely not be cleared, postponing the decision of whether it will definitely be cleared to the final reference processing phase. This can be especially beneficial in the case of concurrent collectors where the marking is usually concurrent but reference processing is usually not. Reviewed-by: jmasa
author ysr
date Thu, 20 Nov 2008 16:56:09 -0800
parents a61af66fc99e
children c18cbe5936b8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
2 * Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
a61af66fc99e Initial load
duke
parents:
diff changeset
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
a61af66fc99e Initial load
duke
parents:
diff changeset
20 * CA 95054 USA or visit www.sun.com if you need additional information or
a61af66fc99e Initial load
duke
parents:
diff changeset
21 * have any questions.
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
a61af66fc99e Initial load
duke
parents:
diff changeset
25
a61af66fc99e Initial load
duke
parents:
diff changeset
26 // Contains two generations that both use an AdjoiningVirtualSpaces.
a61af66fc99e Initial load
duke
parents:
diff changeset
27 // The two generations are adjacent in the reserved space for the
a61af66fc99e Initial load
duke
parents:
diff changeset
28 // heap. Each generation has a virtual space and shrinking and
a61af66fc99e Initial load
duke
parents:
diff changeset
29 // expanding of the generations can still be down with that
a61af66fc99e Initial load
duke
parents:
diff changeset
30 // virtual space as was previously done. If expanding of reserved
a61af66fc99e Initial load
duke
parents:
diff changeset
31 // size of a generation is required, the adjacent generation
a61af66fc99e Initial load
duke
parents:
diff changeset
32 // must be shrunk. Adjusting the boundary between the generations
a61af66fc99e Initial load
duke
parents:
diff changeset
33 // is called for in this class.
a61af66fc99e Initial load
duke
parents:
diff changeset
34
a61af66fc99e Initial load
duke
parents:
diff changeset
35 class AdjoiningGenerations : public CHeapObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
36 friend class VMStructs;
a61af66fc99e Initial load
duke
parents:
diff changeset
37 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
38 // The young generation and old generation, respectively
a61af66fc99e Initial load
duke
parents:
diff changeset
39 PSYoungGen* _young_gen;
a61af66fc99e Initial load
duke
parents:
diff changeset
40 PSOldGen* _old_gen;
a61af66fc99e Initial load
duke
parents:
diff changeset
41
a61af66fc99e Initial load
duke
parents:
diff changeset
42 // The spaces used by the two generations.
a61af66fc99e Initial load
duke
parents:
diff changeset
43 AdjoiningVirtualSpaces _virtual_spaces;
a61af66fc99e Initial load
duke
parents:
diff changeset
44
a61af66fc99e Initial load
duke
parents:
diff changeset
45 // Move boundary up to expand old gen. Checks are made to
a61af66fc99e Initial load
duke
parents:
diff changeset
46 // determine if the move can be done with specified limits.
a61af66fc99e Initial load
duke
parents:
diff changeset
47 void request_old_gen_expansion(size_t desired_change_in_bytes);
a61af66fc99e Initial load
duke
parents:
diff changeset
48 // Move boundary down to expand young gen.
a61af66fc99e Initial load
duke
parents:
diff changeset
49 bool request_young_gen_expansion(size_t desired_change_in_bytes);
a61af66fc99e Initial load
duke
parents:
diff changeset
50
a61af66fc99e Initial load
duke
parents:
diff changeset
51 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
52 AdjoiningGenerations(ReservedSpace rs,
a61af66fc99e Initial load
duke
parents:
diff changeset
53 size_t init_low_byte_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
54 size_t min_low_byte_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
55 size_t max_low_byte_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
56 size_t init_high_byte_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
57 size_t min_high_byte_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
58 size_t max_high_bytes_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
59 size_t alignment);
a61af66fc99e Initial load
duke
parents:
diff changeset
60
a61af66fc99e Initial load
duke
parents:
diff changeset
61 // Accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
62 PSYoungGen* young_gen() { return _young_gen; }
a61af66fc99e Initial load
duke
parents:
diff changeset
63 PSOldGen* old_gen() { return _old_gen; }
a61af66fc99e Initial load
duke
parents:
diff changeset
64
a61af66fc99e Initial load
duke
parents:
diff changeset
65 AdjoiningVirtualSpaces* virtual_spaces() { return &_virtual_spaces; }
a61af66fc99e Initial load
duke
parents:
diff changeset
66
a61af66fc99e Initial load
duke
parents:
diff changeset
67 // Additional space is needed in the old generation. Check
a61af66fc99e Initial load
duke
parents:
diff changeset
68 // the available space and attempt to move the boundary if more space
a61af66fc99e Initial load
duke
parents:
diff changeset
69 // is needed. The growth is not guaranteed to occur.
a61af66fc99e Initial load
duke
parents:
diff changeset
70 void adjust_boundary_for_old_gen_needs(size_t desired_change_in_bytes);
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // Similary for a growth of the young generation.
a61af66fc99e Initial load
duke
parents:
diff changeset
72 void adjust_boundary_for_young_gen_needs(size_t eden_size, size_t survivor_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
73
a61af66fc99e Initial load
duke
parents:
diff changeset
74 // Return the total byte size of the reserved space
a61af66fc99e Initial load
duke
parents:
diff changeset
75 // for the adjoining generations.
a61af66fc99e Initial load
duke
parents:
diff changeset
76 size_t reserved_byte_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
77 };