1 /*
2 * Copyright (c) 1999, 2025, 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
25 #ifndef SHARE_CI_CIKLASS_HPP
26 #define SHARE_CI_CIKLASS_HPP
27
28 #include "ci/ciType.hpp"
29 #include "oops/klass.hpp"
30
31 // ciKlass
32 //
33 // This class and its subclasses represent Klass*s in the
34 // HotSpot virtual machine. In the vm, each Klass* contains an
35 // embedded Klass object. ciKlass is subclassed to explicitly
36 // represent the kind of Klass embedded in the Klass*. For
37 // example, a Klass* with an embedded ObjArrayKlass object is
38 // represented in the ciObject hierarchy by the class
39 // ciObjArrayKlass.
40 class ciKlass : public ciType {
41 CI_PACKAGE_ACCESS
42 friend class ciEnv;
43 friend class ciField;
44 friend class ciMethod;
45 friend class ciMethodData;
46 friend class ciObjArrayKlass;
47 friend class ciReceiverTypeData;
48 friend class ciSignature;
49 friend class ciFlatArrayKlass;
50 friend class ciArrayKlass;
51
52 private:
53 ciSymbol* _name;
54 jint _layout_helper;
55
56 protected:
57 ciKlass(Klass* k, ciSymbol* name);
58 ciKlass(ciSymbol* name, BasicType bt);
59
60 Klass* get_Klass() const {
61 Klass* k = (Klass*)_metadata;
62 assert(k != nullptr, "illegal use of unloaded klass");
63 return k;
64 }
65
66 // Certain subklasses have an associated class loader.
67 virtual oop loader() { return nullptr; }
68 virtual jobject loader_handle() { return nullptr; }
69
70 const char* type_string() { return "ciKlass"; }
71
72 void print_impl(outputStream* st);
73
74 public:
75 ciKlass(Klass* k);
76
77 // What is the name of this klass?
78 ciSymbol* name() const { return _name; }
79
80 // What is its layout helper value?
81 jint layout_helper() { return _layout_helper; }
82
83 bool is_subtype_of(ciKlass* klass);
84 bool is_subclass_of(ciKlass* klass);
85 juint super_depth();
86 juint super_check_offset();
87 ciKlass* super_of_depth(juint i);
88 static juint primary_super_limit() { return Klass::primary_super_limit(); }
89
90 // Is this ciObject the ciInstanceKlass representing java.lang.Object()?
91 virtual bool is_java_lang_Object() const { return false; }
92
93 // Get the shared parent of two klasses.
94 ciKlass* least_common_ancestor(ciKlass* k);
95
96 virtual bool is_interface() {
97 return false;
98 }
99
100 virtual bool is_abstract() {
101 return false;
102 }
103
104 // Does this type (array, class, interface) have no subtypes?
105 virtual bool is_leaf_type() {
106 return false;
107 }
108
109 virtual bool can_be_inline_klass(bool is_exact = false) {
110 return false;
111 }
112
113 virtual bool can_be_inline_array_klass() {
114 return EnableValhalla && is_java_lang_Object();
115 }
116
117 bool is_in_encoding_range() {
118 Klass* k = get_Klass();
119 bool is_in_encoding_range = CompressedKlassPointers::is_encodable(k);
120 assert(is_in_encoding_range, "sanity");
121 return is_in_encoding_range;
122 }
123
124 // Attempt to get a klass using this ciKlass's loader.
125 ciKlass* find_klass(ciSymbol* klass_name);
126 // Note: To find a class from its name string, use ciSymbol::make,
127 // but consider adding to vmSymbols.hpp instead.
128
129 // Get the instance of java.lang.Class corresponding to this klass.
130 ciInstance* java_mirror();
131
132 // Fetch modifier flags.
133 jint modifier_flags();
134
135 // Fetch Klass::access_flags.
136 jint access_flags();
137
138 markWord prototype_header() const;
139
140 // Fetch Klass::misc_flags.
141 klass_flags_t misc_flags();
142
143 // What kind of ciObject is this?
144 bool is_klass() const { return true; }
145
146 virtual ciKlass* exact_klass() = 0;
147
148 void print_name_on(outputStream* st);
149
150 const char* external_name() const;
151
152 juint prototype_header_offset();
153 uintptr_t prototype_header();
154 };
155
156 #endif // SHARE_CI_CIKLASS_HPP