Mon, 25 Aug 2014 00:13:36 -0700
8048150: Allow easy configurations for large CDS archives
Summary: Estimate the size of shared archive based on the number of classes in the classlist file
Reviewed-by: iklam, jiangli, minqi, dholmes
1 /*
2 * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
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 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 *
23 */
24 #ifndef SHARE_VM_MEMORY_METASPACE_SHARED_HPP
25 #define SHARE_VM_MEMORY_METASPACE_SHARED_HPP
27 #include "memory/allocation.hpp"
28 #include "memory/memRegion.hpp"
29 #include "runtime/virtualspace.hpp"
30 #include "utilities/exceptions.hpp"
31 #include "utilities/macros.hpp"
33 #define LargeSharedArchiveSize (300*M)
34 #define HugeSharedArchiveSize (800*M)
35 #define ReadOnlyRegionPercentage 0.4
36 #define ReadWriteRegionPercentage 0.55
37 #define MiscDataRegionPercentage 0.03
38 #define MiscCodeRegionPercentage 0.02
39 #define LargeThresholdClassCount 5000
40 #define HugeThresholdClassCount 40000
42 #define SET_ESTIMATED_SIZE(type, region) \
43 Shared ##region## Size = FLAG_IS_DEFAULT(Shared ##region## Size) ? \
44 (type ## SharedArchiveSize * region ## RegionPercentage) : Shared ## region ## Size
46 class FileMapInfo;
48 // Class Data Sharing Support
49 class MetaspaceShared : AllStatic {
51 // CDS support
52 static ReservedSpace* _shared_rs;
53 static int _max_alignment;
54 static bool _link_classes_made_progress;
55 static bool _check_classes_made_progress;
56 static bool _has_error_classes;
57 static bool _archive_loading_failed;
58 public:
59 enum {
60 vtbl_list_size = 17, // number of entries in the shared space vtable list.
61 num_virtuals = 200 // maximum number of virtual functions
62 // If virtual functions are added to Metadata,
63 // this number needs to be increased. Also,
64 // SharedMiscCodeSize will need to be increased.
65 };
67 enum {
68 ro = 0, // read-only shared space in the heap
69 rw = 1, // read-write shared space in the heap
70 md = 2, // miscellaneous data for initializing tables, etc.
71 mc = 3, // miscellaneous code - vtable replacement.
72 n_regions = 4
73 };
75 // Accessor functions to save shared space created for metadata, which has
76 // extra space allocated at the end for miscellaneous data and code.
77 static void set_max_alignment(int alignment) {
78 CDS_ONLY(_max_alignment = alignment);
79 }
81 static int max_alignment() {
82 CDS_ONLY(return _max_alignment);
83 NOT_CDS(return 0);
84 }
86 static void prepare_for_dumping() NOT_CDS_RETURN;
87 static void preload_and_dump(TRAPS) NOT_CDS_RETURN;
88 static int preload_and_dump(const char * class_list_path,
89 GrowableArray<Klass*>* class_promote_order,
90 TRAPS) NOT_CDS_RETURN;
92 static ReservedSpace* shared_rs() {
93 CDS_ONLY(return _shared_rs);
94 NOT_CDS(return NULL);
95 }
97 static void set_shared_rs(ReservedSpace* rs) {
98 CDS_ONLY(_shared_rs = rs;)
99 }
101 static void set_archive_loading_failed() {
102 _archive_loading_failed = true;
103 }
104 static bool map_shared_spaces(FileMapInfo* mapinfo) NOT_CDS_RETURN_(false);
105 static void initialize_shared_spaces() NOT_CDS_RETURN;
107 // Return true if given address is in the mapped shared space.
108 static bool is_in_shared_space(const void* p) NOT_CDS_RETURN_(false);
110 static void generate_vtable_methods(void** vtbl_list,
111 void** vtable,
112 char** md_top, char* md_end,
113 char** mc_top, char* mc_end);
114 static void serialize(SerializeClosure* sc);
116 // JVM/TI RedefineClasses() support:
117 // Remap the shared readonly space to shared readwrite, private if
118 // sharing is enabled. Simply returns true if sharing is not enabled
119 // or if the remapping has already been done by a prior call.
120 static bool remap_shared_readonly_as_readwrite() NOT_CDS_RETURN_(true);
122 static void print_shared_spaces();
124 static bool try_link_class(InstanceKlass* ik, TRAPS);
125 static void link_one_shared_class(Klass* obj, TRAPS);
126 static void check_one_shared_class(Klass* obj);
127 static void link_and_cleanup_shared_classes(TRAPS);
129 static int count_class(const char* classlist_file);
130 static void estimate_regions_size() NOT_CDS_RETURN;
131 };
132 #endif // SHARE_VM_MEMORY_METASPACE_SHARED_HPP