1 /*
2 * Copyright (c) 1997, 2026, 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_CLASSFILE_CLASSFILEPARSER_HPP
26 #define SHARE_CLASSFILE_CLASSFILEPARSER_HPP
27
28 #include "memory/referenceType.hpp"
29 #include "oops/annotations.hpp"
30 #include "oops/constantPool.hpp"
31 #include "oops/fieldInfo.hpp"
32 #include "oops/instanceKlass.hpp"
33 #include "oops/typeArrayOop.hpp"
34 #include "utilities/accessFlags.hpp"
35
36 class Annotations;
37 template <typename T>
38 class Array;
39 class ClassFileStream;
40 class ClassLoaderData;
41 class ClassLoadInfo;
42 class ClassInstanceInfo;
43 class CompressedLineNumberWriteStream;
44 class ConstMethod;
45 class FieldInfo;
46 template <typename T>
47 class GrowableArray;
48 class InstanceKlass;
49 class RecordComponent;
50 class Symbol;
51 class FieldLayoutBuilder;
52
53 // Utility to collect and compact oop maps during layout
54 class OopMapBlocksBuilder : public ResourceObj {
55 public:
56 OopMapBlock* _nonstatic_oop_maps;
57 unsigned int _nonstatic_oop_map_count;
58 unsigned int _max_nonstatic_oop_maps;
59
60 OopMapBlocksBuilder(unsigned int max_blocks);
61 OopMapBlock* last_oop_map() const;
62 void initialize_inherited_blocks(OopMapBlock* blocks, unsigned int nof_blocks);
63 void add(int offset, int count);
64 void copy(OopMapBlock* dst);
65 void compact();
66 void print_on(outputStream* st) const;
67 void print_value_on(outputStream* st) const;
68 };
69
70 struct AcmpMapSegment {
71 int _offset;
72 int _size;
73 AcmpMapSegment() = default;
74 AcmpMapSegment(int offset, int size)
75 : _offset(offset), _size(size) {}
76 };
77
78 // Values needed for oopmap and InstanceKlass creation
79 class FieldLayoutInfo : public ResourceObj {
80 public:
81 OopMapBlocksBuilder* oop_map_blocks;
82 GrowableArray<AcmpMapSegment>* _nonoop_acmp_map;
83 GrowableArray<int>* _oop_acmp_map;
84 int _instance_size;
85 int _nonstatic_field_size;
86 int _static_field_size;
87 int _payload_alignment;
88 int _payload_offset;
89 int _payload_size_in_bytes;
90 int _null_free_non_atomic_size_in_bytes;
91 int _null_free_non_atomic_alignment;
92 int _null_free_atomic_layout_size_in_bytes;
93 int _nullable_atomic_layout_size_in_bytes;
94 int _nullable_non_atomic_layout_size_in_bytes;
95 int _null_marker_offset;
96 int _null_reset_value_offset;
97 int _acmp_maps_offset;
98 bool _has_nonstatic_fields;
99 bool _is_naturally_atomic;
100 bool _must_be_atomic;
101 bool _has_inlined_fields;
102 bool _is_empty_inline_klass;
103 FieldLayoutInfo() : oop_map_blocks(nullptr), _nonoop_acmp_map(nullptr), _oop_acmp_map(nullptr),
104 _instance_size(-1), _nonstatic_field_size(-1), _static_field_size(-1),
105 _payload_alignment(-1), _payload_offset(-1), _payload_size_in_bytes(-1),
106 _null_free_non_atomic_size_in_bytes(-1), _null_free_non_atomic_alignment(-1),
107 _null_free_atomic_layout_size_in_bytes(-1), _nullable_atomic_layout_size_in_bytes(-1),
108 _nullable_non_atomic_layout_size_in_bytes(-1),
109 _null_marker_offset(-1), _null_reset_value_offset(-1), _acmp_maps_offset(-1),
110 _has_nonstatic_fields(false), _is_naturally_atomic(false), _must_be_atomic(false),
111 _has_inlined_fields(false), _is_empty_inline_klass(false) { }
112 };
113
114 // Parser for for .class files
115 //
116 // The bytes describing the class file structure is read from a Stream object
117
118 class ClassFileParser {
119 friend class FieldLayoutBuilder;
120 friend class FieldLayout;
121
122 class ClassAnnotationCollector;
123 class FieldAnnotationCollector;
124
125 public:
126 // The ClassFileParser has an associated "publicity" level
127 // It is used to control which subsystems (if any)
128 // will observe the parsing (logging, events, tracing).
129 // Default level is "BROADCAST", which is equivalent to
130 // a "public" parsing attempt.
131 //
132 // "INTERNAL" level should be entirely private to the
133 // caller - this allows for internal reuse of ClassFileParser
134 //
135 enum Publicity {
136 INTERNAL,
137 BROADCAST
138 };
139
140 enum { LegalClass, LegalField, LegalMethod }; // used to verify unqualified names
141
142 private:
143 // Potentially unaligned pointer to various 16-bit entries in the class file
144 typedef void unsafe_u2;
145
146 const ClassFileStream* _stream; // Actual input stream
147 Symbol* _class_name;
148 mutable ClassLoaderData* _loader_data;
149 const bool _is_hidden;
150 const bool _can_access_vm_annotations;
151 int _orig_cp_size;
152 unsigned int _static_oop_count;
153
154 // Metadata created before the instance klass is created. Must be deallocated
155 // if not transferred to the InstanceKlass upon successful class loading
156 // in which case these pointers have been set to null.
157 const InstanceKlass* _super_klass;
158 ConstantPool* _cp;
159 Array<u1>* _fieldinfo_stream;
160 Array<u1>* _fieldinfo_search_table;
161 Array<FieldStatus>* _fields_status;
162 Array<Method*>* _methods;
163 Array<u2>* _inner_classes;
164 Array<u2>* _nest_members;
165 u2 _nest_host;
166 Array<u2>* _permitted_subclasses;
167 Array<u2>* _loadable_descriptors;
168 Array<RecordComponent*>* _record_components;
169 Array<InstanceKlass*>* _local_interfaces;
170 Array<InstanceKlass*>* _transitive_interfaces;
171 Annotations* _combined_annotations;
172 AnnotationArray* _class_annotations;
173 AnnotationArray* _class_type_annotations;
174 Array<AnnotationArray*>* _fields_annotations;
175 Array<AnnotationArray*>* _fields_type_annotations;
176 InstanceKlass* _klass; // InstanceKlass* once created.
177 InstanceKlass* _klass_to_deallocate; // an InstanceKlass* to be destroyed
178
179 ClassAnnotationCollector* _parsed_annotations;
180 FieldLayoutInfo* _layout_info;
181 Array<InlineLayoutInfo>* _inline_layout_info_array;
182 GrowableArray<FieldInfo>* _temp_field_info;
183 const intArray* _method_ordering;
184 GrowableArray<Method*>* _all_mirandas;
185
186 enum { fixed_buffer_size = 128 };
187 u_char _linenumbertable_buffer[fixed_buffer_size];
188
189 // Size of Java vtable (in words)
190 int _vtable_size;
191 int _itable_size;
192
193 int _num_miranda_methods;
194
195
196 Handle _protection_domain;
197 AccessFlags _access_flags;
198
199 // for tracing and notifications
200 Publicity _pub_level;
201
202 // Used to keep track of whether a constant pool item 19 or 20 is found. These
203 // correspond to CONSTANT_Module and CONSTANT_Package tags and are not allowed
204 // in regular class files. For class file version >= 53, a CFE cannot be thrown
205 // immediately when these are seen because a NCDFE must be thrown if the class's
206 // access_flags have ACC_MODULE set. But, the access_flags haven't been looked
207 // at yet. So, the bad constant pool item is cached here. A value of zero
208 // means that no constant pool item 19 or 20 was found.
209 short _bad_constant_seen;
210
211 // class attributes parsed before the instance klass is created:
212 bool _synthetic_flag;
213 int _sde_length;
214 const char* _sde_buffer;
215 u2 _sourcefile_index;
216 u2 _generic_signature_index;
217
218 u2 _major_version;
219 u2 _minor_version;
220 u2 _this_class_index;
221 u2 _super_class_index;
222 u2 _itfs_len;
223 u2 _java_fields_count;
224
225 bool _need_verify;
226
227 bool _has_nonstatic_concrete_methods;
228 bool _declares_nonstatic_concrete_methods;
229 bool _has_localvariable_table;
230 bool _has_final_method;
231 bool _has_contended_fields;
232 bool _has_aot_runtime_setup_method;
233 bool _has_strict_static_fields;
234
235 bool _must_be_atomic;
236
237 // precomputed flags
238 bool _has_finalizer;
239 bool _has_empty_finalizer;
240 int _max_bootstrap_specifier_index; // detects BSS values
241
242 void parse_stream(const ClassFileStream* const stream, TRAPS);
243
244 void mangle_hidden_class_name(InstanceKlass* const ik);
245
246 void post_process_parsed_stream(const ClassFileStream* const stream,
247 ConstantPool* cp,
248 TRAPS);
249 void fetch_field_classes(ConstantPool* cp, TRAPS);
250
251 void fill_instance_klass(InstanceKlass* ik, bool cf_changed_in_CFLH,
252 const ClassInstanceInfo& cl_inst_info, TRAPS);
253
254 void set_klass(InstanceKlass* instance);
255
256 void set_inline_layout_info_klass(int field_index, InlineKlass* ik, TRAPS);
257
258 void set_class_bad_constant_seen(short bad_constant);
259 short class_bad_constant_seen() { return _bad_constant_seen; }
260 void set_class_synthetic_flag(bool x) { _synthetic_flag = x; }
261 void set_class_sourcefile_index(u2 x) { _sourcefile_index = x; }
262 void set_class_generic_signature_index(u2 x) { _generic_signature_index = x; }
263 void set_class_sde_buffer(const char* x, int len) { _sde_buffer = x; _sde_length = len; }
264
265 void create_combined_annotations(TRAPS);
266 void apply_parsed_class_attributes(InstanceKlass* k); // update k
267 void apply_parsed_class_metadata(InstanceKlass* k, int fields_count);
268 void clear_class_metadata();
269
270 // Constant pool parsing
271 void parse_constant_pool_entries(const ClassFileStream* const stream,
272 ConstantPool* cp,
273 const int length,
274 TRAPS);
275
276 void parse_constant_pool(const ClassFileStream* const cfs,
277 ConstantPool* const cp,
278 const int length,
279 TRAPS);
280
281 // Interface parsing
282 void parse_interfaces(const ClassFileStream* const stream,
283 const int itfs_len,
284 ConstantPool* const cp,
285 bool* has_nonstatic_concrete_methods,
286 TRAPS);
287
288 void check_super_class(ConstantPool* const cp,
289 const int super_class_index,
290 const bool need_verify,
291 TRAPS);
292
293 // Field parsing
294 void parse_field_attributes(const ClassFileStream* const cfs,
295 u2 attributes_count,
296 bool is_static,
297 u2 signature_index,
298 u2* const constantvalue_index_addr,
299 bool* const is_synthetic_addr,
300 u2* const generic_signature_index_addr,
301 FieldAnnotationCollector* parsed_annotations,
302 TRAPS);
303
304 void parse_fields(const ClassFileStream* const cfs,
305 AccessFlags class_access_flags,
306 ConstantPool* cp,
307 const int cp_size,
308 u2* const java_fields_count_ptr,
309 TRAPS);
310
311 // Method parsing
312 Method* parse_method(const ClassFileStream* const cfs,
313 bool is_interface,
314 const ConstantPool* cp,
315 bool* const has_localvariable_table,
316 TRAPS);
317
318 void parse_methods(const ClassFileStream* const cfs,
319 bool is_interface,
320 bool* const has_localvariable_table,
321 bool* const has_final_method,
322 bool* const declares_nonstatic_concrete_methods,
323 TRAPS);
324
325 const unsafe_u2* parse_exception_table(const ClassFileStream* const stream,
326 u4 code_length,
327 u4 exception_table_length,
328 TRAPS);
329
330 void parse_linenumber_table(u4 code_attribute_length,
331 u4 code_length,
332 CompressedLineNumberWriteStream**const write_stream,
333 TRAPS);
334
335 const unsafe_u2* parse_localvariable_table(const ClassFileStream* const cfs,
336 u4 code_length,
337 u2 max_locals,
338 u4 code_attribute_length,
339 u2* const localvariable_table_length,
340 bool isLVTT,
341 TRAPS);
342
343 const unsafe_u2* parse_checked_exceptions(const ClassFileStream* const cfs,
344 u2* const checked_exceptions_length,
345 u4 method_attribute_length,
346 TRAPS);
347
348 // Classfile attribute parsing
349 u2 parse_generic_signature_attribute(const ClassFileStream* const cfs, TRAPS);
350 void parse_classfile_sourcefile_attribute(const ClassFileStream* const cfs, TRAPS);
351 void parse_classfile_source_debug_extension_attribute(const ClassFileStream* const cfs,
352 int length,
353 TRAPS);
354
355 // Check for circularity in InnerClasses attribute.
356 bool check_inner_classes_circularity(const ConstantPool* cp, int length, TRAPS);
357
358 u2 parse_classfile_inner_classes_attribute(const ClassFileStream* const cfs,
359 const ConstantPool* cp,
360 const u1* const inner_classes_attribute_start,
361 bool parsed_enclosingmethod_attribute,
362 u2 enclosing_method_class_index,
363 u2 enclosing_method_method_index,
364 TRAPS);
365
366 u2 parse_classfile_nest_members_attribute(const ClassFileStream* const cfs,
367 const u1* const nest_members_attribute_start,
368 TRAPS);
369
370 u2 parse_classfile_permitted_subclasses_attribute(const ClassFileStream* const cfs,
371 const u1* const permitted_subclasses_attribute_start,
372 TRAPS);
373
374 u2 parse_classfile_loadable_descriptors_attribute(const ClassFileStream* const cfs,
375 const u1* const loadable_descriptors_attribute_start,
376 TRAPS);
377
378 u4 parse_classfile_record_attribute(const ClassFileStream* const cfs,
379 const ConstantPool* cp,
380 const u1* const record_attribute_start,
381 TRAPS);
382
383 void parse_classfile_attributes(const ClassFileStream* const cfs,
384 ConstantPool* cp,
385 ClassAnnotationCollector* parsed_annotations,
386 TRAPS);
387
388 void parse_classfile_synthetic_attribute();
389 void parse_classfile_signature_attribute(const ClassFileStream* const cfs, TRAPS);
390 void parse_classfile_bootstrap_methods_attribute(const ClassFileStream* const cfs,
391 ConstantPool* cp,
392 u4 attribute_length,
393 TRAPS);
394
395 // Annotations handling
396 AnnotationArray* allocate_annotations(const u1* const anno,
397 int anno_length,
398 TRAPS);
399
400 void set_precomputed_flags(InstanceKlass* k);
401
402 // Format checker methods
403 void classfile_parse_error(const char* msg, TRAPS) const;
404 void classfile_parse_error(const char* msg, int index, TRAPS) const;
405 void classfile_parse_error(const char* msg, const char *name, TRAPS) const;
406 void classfile_parse_error(const char* msg,
407 int index,
408 const char *name,
409 TRAPS) const;
410 void classfile_parse_error(const char* msg,
411 const char* name,
412 const char* signature,
413 TRAPS) const;
414
415 void classfile_icce_error(const char* msg,
416 const Klass* k,
417 TRAPS) const;
418
419 // Uses msg directly in the ICCE, with no additional content
420 void classfile_icce_error(const char* msg,
421 TRAPS) const;
422
423 void classfile_ucve_error(const char* msg,
424 const Symbol* class_name,
425 u2 major,
426 u2 minor,
427 TRAPS) const;
428
429 inline void guarantee_property(bool b, const char* msg, TRAPS) const {
430 if (!b) { classfile_parse_error(msg, THREAD); return; }
431 }
432
433 inline void guarantee_property(bool b,
434 const char* msg,
435 int index,
436 TRAPS) const {
437 if (!b) { classfile_parse_error(msg, index, THREAD); return; }
438 }
439
440 inline void guarantee_property(bool b,
441 const char* msg,
442 const char *name,
443 TRAPS) const {
444 if (!b) { classfile_parse_error(msg, name, THREAD); return; }
445 }
446
447 inline void guarantee_property(bool b,
448 const char* msg,
449 int index,
450 const char *name,
451 TRAPS) const {
452 if (!b) { classfile_parse_error(msg, index, name, THREAD); return; }
453 }
454
455 void throwIllegalSignature(const char* type,
456 const Symbol* name,
457 const Symbol* sig,
458 TRAPS) const;
459
460 void verify_constantvalue(const ConstantPool* const cp,
461 int constantvalue_index,
462 int signature_index,
463 TRAPS) const;
464
465 void verify_legal_utf8(const unsigned char* buffer, int length, TRAPS) const;
466 void verify_legal_class_name(const Symbol* name, TRAPS) const;
467 void verify_legal_field_name(const Symbol* name, TRAPS) const;
468 void verify_legal_method_name(const Symbol* name, TRAPS) const;
469
470 bool legal_field_signature(const Symbol* signature, TRAPS) const;
471
472 void verify_legal_field_signature(const Symbol* fieldname,
473 const Symbol* signature,
474 TRAPS) const;
475 int verify_legal_method_signature(const Symbol* methodname,
476 const Symbol* signature,
477 TRAPS) const;
478 void verify_legal_name_with_signature(const Symbol* name,
479 const Symbol* signature,
480 TRAPS) const;
481
482 void verify_class_version(u2 major, u2 minor, Symbol* class_name, TRAPS);
483
484 void verify_legal_class_modifiers(jint flags, Symbol* inner_name,
485 bool is_anonymous_inner_class, TRAPS) const;
486 void verify_legal_field_modifiers(jint flags, AccessFlags class_access_flags, TRAPS) const;
487 void verify_legal_method_modifiers(jint flags,
488 AccessFlags class_access_flags,
489 const Symbol* name,
490 TRAPS) const;
491
492 void check_super_class_access(const InstanceKlass* this_klass,
493 TRAPS);
494
495 void check_super_interface_access(const InstanceKlass* this_klass,
496 TRAPS);
497
498 const char* skip_over_field_signature(const char* signature,
499 bool void_ok,
500 unsigned int length,
501 TRAPS) const;
502
503 // Wrapper for constantTag.is_klass_[or_]reference.
504 // In older versions of the VM, Klass*s cannot sneak into early phases of
505 // constant pool construction, but in later versions they can.
506 // %%% Let's phase out the old is_klass_reference.
507 bool valid_klass_reference_at(int index) const {
508 return _cp->is_within_bounds(index) &&
509 _cp->tag_at(index).is_klass_or_reference();
510 }
511
512 // Checks that the cpool index is in range and is a utf8
513 bool valid_symbol_at(int cpool_index) const {
514 return _cp->is_within_bounds(cpool_index) &&
515 _cp->tag_at(cpool_index).is_utf8();
516 }
517
518 void copy_localvariable_table(const ConstMethod* cm,
519 int lvt_cnt,
520 u2* const localvariable_table_length,
521 const unsafe_u2** const localvariable_table_start,
522 int lvtt_cnt,
523 u2* const localvariable_type_table_length,
524 const unsafe_u2** const localvariable_type_table_start,
525 TRAPS);
526
527 void copy_method_annotations(ConstMethod* cm,
528 const u1* runtime_visible_annotations,
529 int runtime_visible_annotations_length,
530 const u1* runtime_visible_parameter_annotations,
531 int runtime_visible_parameter_annotations_length,
532 const u1* runtime_visible_type_annotations,
533 int runtime_visible_type_annotations_length,
534 const u1* annotation_default,
535 int annotation_default_length,
536 TRAPS);
537
538 void update_class_name(Symbol* new_name);
539
540 // Check if the class file supports inline types
541 bool supports_inline_types() const;
542
543 void create_acmp_maps(InstanceKlass* ik, TRAPS);
544 void set_fast_acmp_members(InlineKlass* vk) const;
545
546 public:
547 ClassFileParser(ClassFileStream* stream,
548 Symbol* name,
549 ClassLoaderData* loader_data,
550 const ClassLoadInfo* cl_info,
551 Publicity pub_level,
552 TRAPS);
553
554 ~ClassFileParser();
555
556 InstanceKlass* create_instance_klass(bool cf_changed_in_CFLH, const ClassInstanceInfo& cl_inst_info, TRAPS);
557
558 const ClassFileStream& stream() const { return *_stream; }
559
560 const ClassFileStream* clone_stream() const;
561
562 void set_klass_to_deallocate(InstanceKlass* klass);
563
564 int static_field_size() const;
565 int total_oop_map_count() const;
566 jint layout_size() const;
567
568 int vtable_size() const { return _vtable_size; }
569 int itable_size() const { return _itable_size; }
570
571 u2 this_class_index() const { return _this_class_index; }
572
573 bool is_hidden() const { return _is_hidden; }
574 bool is_interface() const { return _access_flags.is_interface(); }
575 // Being an inline type means being a concrete value class
576 bool is_inline_type() const { return !_access_flags.is_identity_class() && !_access_flags.is_interface() && !_access_flags.is_abstract(); }
577 bool is_identity_class() const { return _access_flags.is_identity_class(); }
578 bool has_inlined_fields() const { return _layout_info->_has_inlined_fields; }
579
580 u2 java_fields_count() const { return _java_fields_count; }
581 bool is_abstract() const { return _access_flags.is_abstract(); }
582
583 ClassLoaderData* loader_data() const { return _loader_data; }
584 const Symbol* class_name() const { return _class_name; }
585 const InstanceKlass* super_klass() const { return _super_klass; }
586
587 ReferenceType super_reference_type() const;
588 bool is_instance_ref_klass() const;
589 bool is_java_lang_ref_Reference_subclass() const;
590
591 AccessFlags access_flags() const { return _access_flags; }
592
593 bool is_internal() const { return INTERNAL == _pub_level; }
594
595 bool is_class_in_loadable_descriptors_attribute(Symbol *klass);
596
597 static bool verify_unqualified_name(const char* name, unsigned int length, int type);
598
599 #ifdef ASSERT
600 static bool is_internal_format(Symbol* class_name);
601 #endif
602
603 };
604
605 #endif // SHARE_CLASSFILE_CLASSFILEPARSER_HPP