3 * Copyright 2012 Xamarin Inc
4 * Licensed under the MIT license. See LICENSE file in the project root for full license information.
6 #ifndef __MONO_METADATA_CLASS_INTERNALS_H__
7 #define __MONO_METADATA_CLASS_INTERNALS_H__
9 #include <mono/metadata/class.h>
10 #include <mono/metadata/object.h>
11 #include <mono/metadata/mempool.h>
12 #include <mono/metadata/metadata-internals.h>
13 #include <mono/metadata/property-bag.h>
14 #include "mono/utils/mono-compiler.h"
15 #include "mono/utils/mono-error.h"
16 #include "mono/sgen/gc-internal-agnostic.h"
18 #define MONO_CLASS_IS_ARRAY(c) ((c)->rank)
20 #define MONO_CLASS_HAS_STATIC_METADATA(klass) ((klass)->type_token && !(klass)->image->dynamic && !mono_class_is_ginst (klass))
22 #define MONO_DEFAULT_SUPERTABLE_SIZE 6
24 extern gboolean mono_print_vtable;
25 extern gboolean mono_align_small_structs;
27 typedef struct _MonoMethodWrapper MonoMethodWrapper;
28 typedef struct _MonoMethodInflated MonoMethodInflated;
29 typedef struct _MonoMethodPInvoke MonoMethodPInvoke;
31 /* Properties that applies to a group of structs should better use a higher number
32 * to avoid colision with type specific properties.
34 * This prop applies to class, method, property, event, assembly and image.
36 #define MONO_PROP_DYNAMIC_CATTR 0x1000
38 #ifdef ENABLE_ICALL_EXPORT
39 #pragma GCC diagnostic ignored "-Wmissing-prototypes"
40 #define ICALL_DECL_EXPORT MONO_API
41 #define ICALL_EXPORT MONO_API
43 #define ICALL_DECL_EXPORT
44 #define ICALL_EXPORT static
48 #define WRAPPER(e,n) MONO_WRAPPER_ ## e,
49 #include "wrapper-types.h"
55 MONO_TYPE_NAME_FORMAT_IL,
56 MONO_TYPE_NAME_FORMAT_REFLECTION,
57 MONO_TYPE_NAME_FORMAT_FULL_NAME,
58 MONO_TYPE_NAME_FORMAT_ASSEMBLY_QUALIFIED
62 MONO_REMOTING_TARGET_UNKNOWN,
63 MONO_REMOTING_TARGET_APPDOMAIN,
64 MONO_REMOTING_TARGET_COMINTEROP
67 #define MONO_METHOD_PROP_GENERIC_CONTAINER 0
70 guint16 flags; /* method flags */
71 guint16 iflags; /* method implementation flags */
73 MonoClass *klass; /* To what class does this method belong */
74 MonoMethodSignature *signature;
75 /* name is useful mostly for debugging */
77 /* this is used by the inlining algorithm */
78 unsigned int inline_info:1;
79 unsigned int inline_failure:1;
80 unsigned int wrapper_type:5;
81 unsigned int string_ctor:1;
82 unsigned int save_lmf:1;
83 unsigned int dynamic:1; /* created & destroyed during runtime */
84 unsigned int sre_method:1; /* created at runtime using Reflection.Emit */
85 unsigned int is_generic:1; /* whenever this is a generic method definition */
86 unsigned int is_inflated:1; /* whether we're a MonoMethodInflated */
87 unsigned int skip_visibility:1; /* whenever to skip JIT visibility checks */
88 unsigned int verification_success:1; /* whether this method has been verified successfully.*/
92 * If is_generic is TRUE, the generic_container is stored in image->property_hash,
93 * using the key MONO_METHOD_PROP_GENERIC_CONTAINER.
97 struct _MonoMethodWrapper {
99 MonoMethodHeader *header;
103 struct _MonoMethodPInvoke {
106 /* add marshal info */
107 guint16 piflags; /* pinvoke flags */
108 guint16 implmap_idx; /* index into IMPLMAP */
112 * Stores the default value / RVA of fields.
113 * This information is rarely needed, so it is stored separately from
116 typedef struct MonoFieldDefaultValue {
118 * If the field is constant, pointer to the metadata constant
120 * If the field has an RVA flag, pointer to the data.
125 /* If the field is constant, the type of the constant. */
126 MonoTypeEnum def_type;
127 } MonoFieldDefaultValue;
130 * MonoClassField is just a runtime representation of the metadata for
131 * field, it doesn't contain the data directly. Static fields are
132 * stored in MonoVTable->data. Instance fields are allocated in the
133 * objects after the object header.
135 struct _MonoClassField {
136 /* Type of the field */
141 /* Type where the field was defined */
145 * Offset where this field is stored; if it is an instance
146 * field, it's the offset from the start of the object, if
147 * it's static, it's from the start of the memory chunk
148 * allocated for statics for the class.
149 * For special static fields, this is set to -1 during vtable construction.
154 /* a field is ignored if it's named "_Deleted" and it has the specialname and rtspecialname flags set */
155 #define mono_field_is_deleted(field) (((field)->type->attrs & (FIELD_ATTRIBUTE_SPECIAL_NAME | FIELD_ATTRIBUTE_RT_SPECIAL_NAME)) \
156 && (strcmp (mono_field_get_name (field), "_Deleted") == 0))
158 /* a field is ignored if it's named "_Deleted" and it has the specialname and rtspecialname flags set */
159 /* Try to avoid loading the field's type */
160 #define mono_field_is_deleted_with_flags(field, flags) (((flags) & (FIELD_ATTRIBUTE_SPECIAL_NAME | FIELD_ATTRIBUTE_RT_SPECIAL_NAME)) \
161 && (strcmp (mono_field_get_name (field), "_Deleted") == 0))
164 MonoClassField *field;
166 MonoMarshalSpec *mspec;
170 MonoPropertyBagItem head;
172 guint32 native_size, min_align;
174 MonoMethod *ptr_to_str;
175 MonoMethod *str_to_ptr;
176 MonoMarshalField fields [MONO_ZERO_LEN_ARRAY];
179 #define MONO_SIZEOF_MARSHAL_TYPE (offsetof (MonoMarshalType, fields))
181 struct _MonoProperty {
195 #ifndef MONO_SMALL_CONFIG
201 /* type of exception being "on hold" for later processing (see exception_type) */
203 MONO_EXCEPTION_NONE = 0,
204 MONO_EXCEPTION_INVALID_PROGRAM = 3,
205 MONO_EXCEPTION_UNVERIFIABLE_IL = 4,
206 MONO_EXCEPTION_MISSING_METHOD = 5,
207 MONO_EXCEPTION_MISSING_FIELD = 6,
208 MONO_EXCEPTION_TYPE_LOAD = 7,
209 MONO_EXCEPTION_FILE_NOT_FOUND = 8,
210 MONO_EXCEPTION_METHOD_ACCESS = 9,
211 MONO_EXCEPTION_FIELD_ACCESS = 10,
212 MONO_EXCEPTION_GENERIC_SHARING_FAILED = 11,
213 MONO_EXCEPTION_BAD_IMAGE = 12,
214 MONO_EXCEPTION_OBJECT_SUPPLIED = 13, /*The exception object is already created.*/
215 MONO_EXCEPTION_OUT_OF_MEMORY = 14,
216 MONO_EXCEPTION_INLINE_FAILED = 15,
217 MONO_EXCEPTION_MONO_ERROR = 16,
218 /* add other exception type */
221 /* This struct collects the info needed for the runtime use of a class,
222 * like the vtables for a domain, the GC descriptor, etc.
226 /* domain_vtables is indexed by the domain id and the size is max_domain + 1 */
227 MonoVTable *domain_vtables [MONO_ZERO_LEN_ARRAY];
228 } MonoClassRuntimeInfo;
230 #define MONO_SIZEOF_CLASS_RUNTIME_INFO (sizeof (MonoClassRuntimeInfo) - MONO_ZERO_LEN_ARRAY * SIZEOF_VOID_P)
233 MonoPropertyBagItem head;
235 MonoProperty *properties;
236 guint32 first, count;
237 MonoFieldDefaultValue *def_values;
238 } MonoClassPropertyInfo;
241 MonoPropertyBagItem head;
243 /* Initialized by a call to mono_class_setup_events () */
245 guint32 first, count;
246 } MonoClassEventInfo;
249 MONO_CLASS_DEF = 1, /* non-generic type */
250 MONO_CLASS_GTD, /* generic type definition */
251 MONO_CLASS_GINST, /* generic instantiation */
252 MONO_CLASS_GPARAM, /* generic parameter */
253 MONO_CLASS_ARRAY, /* vector or array, bounded or not */
254 MONO_CLASS_POINTER, /* pointer of function pointer*/
258 /* element class for arrays and enum basetype for enums */
259 MonoClass *element_class;
260 /* used for subtype checks */
261 MonoClass *cast_class;
263 /* for fast subtype checks */
264 MonoClass **supertypes;
267 /* array dimension */
270 int instance_size; /* object instance size */
274 /* A class contains static and non static data. Static data can be
275 * of the same type as the class itselfs, but it does not influence
276 * the instance size of the class. To avoid cyclic calls to
277 * mono_class_init (from mono_class_instance_size ()) we first
278 * initialise all non static fields. After that we set size_inited
279 * to 1, because we know the instance size now. After that we
280 * initialise all static fields.
283 /* ALL BITFIELDS SHOULD BE WRITTEN WHILE HOLDING THE LOADER LOCK */
284 guint size_inited : 1;
285 guint valuetype : 1; /* derives from System.ValueType */
286 guint enumtype : 1; /* derives from System.Enum */
287 guint blittable : 1; /* class is blittable */
288 guint unicode : 1; /* class uses unicode char when marshalled */
289 guint wastypebuilder : 1; /* class was created at runtime from a TypeBuilder */
290 guint is_array_special_interface : 1; /* gtd or ginst of once of the magic interfaces that arrays implement */
296 guint packing_size : 4;
297 guint ghcimpl : 1; /* class has its own GetHashCode impl */
298 guint has_finalize : 1; /* class has its own Finalize impl */
299 #ifndef DISABLE_REMOTING
300 guint marshalbyref : 1; /* class is a MarshalByRefObject */
301 guint contextbound : 1; /* class is a ContextBoundObject */
304 guint delegate : 1; /* class is a Delegate */
305 guint gc_descr_inited : 1; /* gc_descr is initialized */
306 guint has_cctor : 1; /* class has a cctor */
307 guint has_references : 1; /* it has GC-tracked references in the instance */
308 guint has_static_refs : 1; /* it has static fields that are GC-tracked */
309 guint no_special_static_fields : 1; /* has no thread/context static fields */
310 /* directly or indirectly derives from ComImport attributed class.
311 * this means we need to create a proxy for instances of this class
312 * for COM Interop. set this flag on loading so all we need is a quick check
313 * during object creation rather than having to traverse supertypes
315 guint is_com_object : 1;
316 guint nested_classes_inited : 1; /* Whenever nested_class is initialized */
319 guint class_kind : 3; /* One of the values from MonoTypeKind */
320 guint interfaces_inited : 1; /* interfaces is initialized */
321 guint simd_type : 1; /* class is a simd intrinsic type */
322 guint has_finalize_inited : 1; /* has_finalize is initialized */
323 guint fields_inited : 1; /* setup_fields () has finished */
324 guint has_failure : 1; /* See mono_class_get_exception_data () for a MonoErrorBoxed with the details */
327 MonoClass *nested_in;
331 const char *name_space;
334 int vtable_size; /* number of slots */
336 guint16 interface_count;
337 guint32 interface_id; /* unique inderface id (for interfaces) */
338 guint32 max_interface_id;
340 guint16 interface_offsets_count;
341 MonoClass **interfaces_packed;
342 guint16 *interface_offsets_packed;
343 /* enabled only with small config for now: we might want to do it unconditionally */
344 #ifdef MONO_SMALL_CONFIG
345 #define COMPRESSED_INTERFACE_BITMAP 1
347 guint8 *interface_bitmap;
349 MonoClass **interfaces;
352 int class_size; /* size of area for static fields */
353 int element_size; /* for array types */
354 int generic_param_token; /* for generic param types, both var and mvar */
358 * Field information: Type and location from object base
360 MonoClassField *fields;
362 MonoMethod **methods;
364 /* used as the type of the this argument and when passing the arg by value */
368 MonoGCDescriptor gc_descr;
370 MonoClassRuntimeInfo *runtime_info;
372 /* Generic vtable. Initialized by a call to mono_class_setup_vtable () */
375 /* Infrequently used items. See class-accessors.c: InfrequentDataKind for what goes into here. */
376 MonoPropertyBag infrequent_data;
383 * From the TypeDef table
385 guint32 first_method_idx;
386 guint32 first_field_idx;
387 guint32 method_count, field_count;
388 /* next element in the class_cache hash list (in MonoImage) */
389 MonoClass *next_class_cache;
394 MonoGenericContainer *generic_container;
395 /* The canonical GENERICINST where we instantiate a generic type definition with its own generic parameters.*/
396 /* Suppose we have class T`2<A,B> {...}. canonical_inst is the GTD T`2 applied to A and B. */
397 MonoType canonical_inst;
402 MonoGenericClass *generic_class;
403 } MonoClassGenericInst;
407 } MonoClassGenericParam;
411 guint32 method_count;
418 #ifdef COMPRESSED_INTERFACE_BITMAP
419 int mono_compress_bitmap (uint8_t *dest, const uint8_t *bitmap, int size);
420 int mono_class_interface_match (const uint8_t *bitmap, int id);
422 #define mono_class_interface_match(bmap,uiid) ((bmap) [(uiid) >> 3] & (1 << ((uiid)&7)))
425 #define MONO_CLASS_IMPLEMENTS_INTERFACE(k,uiid) (((uiid) <= (k)->max_interface_id) && mono_class_interface_match ((k)->interface_bitmap, (uiid)))
427 #define MONO_VTABLE_AVAILABLE_GC_BITS 4
429 #ifdef DISABLE_REMOTING
430 #define mono_class_is_marshalbyref(klass) (FALSE)
431 #define mono_class_is_contextbound(klass) (FALSE)
432 #define mono_vtable_is_remote(vtable) (FALSE)
433 #define mono_vtable_set_is_remote(vtable,enable) do {} while (0)
435 #define mono_class_is_marshalbyref(klass) ((klass)->marshalbyref)
436 #define mono_class_is_contextbound(klass) ((klass)->contextbound)
437 #define mono_vtable_is_remote(vtable) ((vtable)->remote)
438 #define mono_vtable_set_is_remote(vtable,enable) do { (vtable)->remote = enable ? 1 : 0; } while (0)
442 #define mono_class_is_com_object(klass) (FALSE)
444 #define mono_class_is_com_object(klass) ((klass)->is_com_object)
448 MONO_API int mono_class_interface_offset (MonoClass *klass, MonoClass *itf);
449 int mono_class_interface_offset_with_variance (MonoClass *klass, MonoClass *itf, gboolean *non_exact_match);
451 typedef gpointer MonoRuntimeGenericContext;
453 /* the interface_offsets array is stored in memory before this struct */
457 * According to comments in gc_gcj.h, this should be the second word in
460 MonoGCDescriptor gc_descr;
461 MonoDomain *domain; /* each object/vtable belongs to exactly one domain */
462 gpointer type; /* System.Type type for klass */
463 guint8 *interface_bitmap;
464 guint32 max_interface_id;
466 /* Keep this a guint8, the jit depends on it */
467 guint8 initialized; /* cctor has been run */
468 guint remote : 1; /* class is remotely activated */
469 guint init_failed : 1; /* cctor execution failed */
470 guint has_static_fields : 1; /* pointer to the data stored at the end of the vtable array */
471 guint gc_bits : MONO_VTABLE_AVAILABLE_GC_BITS; /* Those bits are reserved for the usaged of the GC */
473 guint32 imt_collisions_bitmap;
474 MonoRuntimeGenericContext *runtime_generic_context;
475 /* do not add any fields after vtable, the structure is dynamically extended */
476 /* vtable contains function pointers to methods or their trampolines, at the
477 end there may be a slot containing the pointer to the static fields */
478 gpointer vtable [MONO_ZERO_LEN_ARRAY];
481 #define MONO_SIZEOF_VTABLE (sizeof (MonoVTable) - MONO_ZERO_LEN_ARRAY * SIZEOF_VOID_P)
483 #define MONO_VTABLE_IMPLEMENTS_INTERFACE(vt,uiid) (((uiid) <= (vt)->max_interface_id) && mono_class_interface_match ((vt)->interface_bitmap, (uiid)))
486 * Generic instantiation data type encoding.
490 * A particular generic instantiation:
492 * All instantiations are cached and we don't distinguish between class and method
493 * instantiations here.
495 struct _MonoGenericInst {
496 #ifndef MONO_SMALL_CONFIG
497 gint32 id; /* unique ID for debugging */
499 guint type_argc : 22; /* number of type arguments */
500 guint is_open : 1; /* if this is an open type */
501 MonoType *type_argv [MONO_ZERO_LEN_ARRAY];
504 #define MONO_SIZEOF_GENERIC_INST (sizeof (MonoGenericInst) - MONO_ZERO_LEN_ARRAY * SIZEOF_VOID_P)
506 * The generic context: an instantiation of a set of class and method generic parameters.
508 * NOTE: Never allocate this directly on the heap. It have to be either allocated on the stack,
509 * or embedded within other objects. Don't store pointers to this, because it may be on the stack.
510 * If you really have to, ensure you store a pointer to the embedding object along with it.
512 struct _MonoGenericContext {
513 /* The instantiation corresponding to the class generic parameters */
514 MonoGenericInst *class_inst;
515 /* The instantiation corresponding to the method generic parameters */
516 MonoGenericInst *method_inst;
520 * Inflated generic method.
522 struct _MonoMethodInflated {
525 MonoMethodPInvoke pinvoke;
527 MonoMethod *declaring; /* the generic method definition. */
528 MonoGenericContext context; /* The current instantiation */
529 MonoImageSet *owner; /* The image set that the inflated method belongs to. */
533 * A particular instantiation of a generic type.
535 struct _MonoGenericClass {
536 MonoClass *container_class; /* the generic type definition */
537 MonoGenericContext context; /* a context that contains the type instantiation doesn't contain any method instantiation */ /* FIXME: Only the class_inst member of "context" is ever used, so this field could be replaced with just a monogenericinst */
538 guint is_dynamic : 1; /* Contains dynamic types */
539 guint is_tb_open : 1; /* This is the fully open instantiation for a type_builder. Quite ugly, but it's temporary.*/
540 guint need_sync : 1; /* Only if dynamic. Need to be synchronized with its container class after its finished. */
541 MonoClass *cached_class; /* if present, the MonoClass corresponding to the instantiation. */
544 * The image set which owns this generic class. Memory owned by the generic class
545 * including cached_class should be allocated from the mempool of the image set,
546 * so it is easy to free.
554 struct _MonoGenericParam {
556 * Type or method this parameter was defined in.
558 MonoGenericContainer *owner;
561 * If != NULL, this is a generated generic param used by the JIT to implement generic
564 MonoType *gshared_constraint;
567 /* Additional details about a MonoGenericParam */
568 /* Keep in sync with managed Mono.RuntimeStructs.GenericParamInfo */
570 MonoClass *pklass; /* The corresponding `MonoClass'. */
573 // See GenericParameterAttributes
578 // Constraints on type parameters
579 MonoClass** constraints; /* NULL means end of list */
580 } MonoGenericParamInfo;
583 MonoGenericParam param;
584 MonoGenericParamInfo info;
585 } MonoGenericParamFull;
588 * The generic container.
590 * Stores the type parameters of a generic type definition or a generic method definition.
592 struct _MonoGenericContainer {
593 MonoGenericContext context;
594 /* If we're a generic method definition in a generic type definition,
595 the generic container of the containing class. */
596 MonoGenericContainer *parent;
597 /* the generic type definition or the generic method definition corresponding to this container */
598 /* Union rules: If is_anonymous, image field is valid; else if is_method, method field is valid; else klass is valid. */
604 int type_argc : 29; // Per the ECMA spec, this value is capped at 16 bits
605 /* If true, we're a generic method, otherwise a generic type definition. */
606 /* Invariant: parent != NULL => is_method */
608 /* If true, this container has no associated class/method and only the image is known. This can happen:
609 1. For the special anonymous containers kept by MonoImage.
610 2. During container creation via the mono_metadata_load_generic_params path-- in this case the caller
611 sets the owner, so temporarily while load_generic_params is completing the container is anonymous.
612 3. When user code creates a generic parameter via SRE, but has not yet set an owner. */
613 int is_anonymous : 1;
614 /* If false, all params in this container are full-size. If true, all params are just param structs. */
615 /* This field is always == to the is_anonymous field, except in "temporary" cases (2) and (3) above. */
616 /* TODO: Merge GenericParam and GenericParamFull, remove this field. Benefit is marginal. */
617 int is_small_param : 1;
618 /* Our type parameters. */
619 MonoGenericParamFull *type_params;
622 static inline MonoGenericParam *
623 mono_generic_container_get_param (MonoGenericContainer *gc, int i)
625 return (MonoGenericParam *) &gc->type_params [i];
628 static inline MonoGenericParamInfo *
629 mono_generic_container_get_param_info (MonoGenericContainer *gc, int i)
631 return &gc->type_params [i].info;
634 static inline MonoGenericContainer *
635 mono_generic_param_owner (MonoGenericParam *p)
641 mono_generic_param_num (MonoGenericParam *p)
646 static inline gboolean
647 mono_generic_param_is_fullsize (MonoGenericParam *p)
649 return !mono_generic_param_owner (p)->is_small_param;
652 static inline MonoGenericParamInfo *
653 mono_generic_param_info (MonoGenericParam *p)
655 if (mono_generic_param_is_fullsize (p))
656 return &((MonoGenericParamFull *) p)->info;
660 static inline const char *
661 mono_generic_param_name (MonoGenericParam *p)
663 if (mono_generic_param_is_fullsize (p))
664 return ((MonoGenericParamFull *) p)->info.name;
668 static inline MonoGenericContainer *
669 mono_type_get_generic_param_owner (MonoType *t)
671 return mono_generic_param_owner (t->data.generic_param);
675 mono_type_get_generic_param_num (MonoType *t)
677 return mono_generic_param_num (t->data.generic_param);
681 * Class information which might be cached by the runtime in the AOT file for
682 * example. Caching this allows us to avoid computing a generic vtable
683 * (class->vtable) in most cases, saving time and avoiding creation of lots of
684 * MonoMethod structures.
686 typedef struct MonoCachedClassInfo {
688 guint has_finalize : 1;
691 guint has_nested_classes : 1;
693 guint has_references : 1;
694 guint has_static_refs : 1;
695 guint no_special_static_fields : 1;
696 guint is_generic_container : 1;
698 MonoImage *finalize_image;
699 guint32 finalize_token;
700 guint32 instance_size;
702 guint32 packing_size;
704 } MonoCachedClassInfo;
709 gconstpointer wrapper;
710 gconstpointer trampoline;
711 MonoMethodSignature *sig;
712 const char *c_symbol;
713 MonoMethod *wrapper_method;
718 mono_class_setup_supertypes (MonoClass *klass);
721 mono_class_setup_fields (MonoClass *klass);
724 * Only call this function if you can ensure both @klass and @parent
725 * have supertype information initialized.
726 * This can be accomplished by mono_class_setup_supertypes or mono_class_init.
727 * If unsure, use mono_class_has_parent.
729 static inline gboolean
730 mono_class_has_parent_fast (MonoClass *klass, MonoClass *parent)
732 return (klass->idepth >= parent->idepth) && (klass->supertypes [parent->idepth - 1] == parent);
735 static inline gboolean
736 mono_class_has_parent (MonoClass *klass, MonoClass *parent)
738 if (G_UNLIKELY (!klass->supertypes))
739 mono_class_setup_supertypes (klass);
741 if (G_UNLIKELY (!parent->supertypes))
742 mono_class_setup_supertypes (parent);
744 return mono_class_has_parent_fast (klass, parent);
748 MonoVTable *default_vtable;
749 MonoVTable *xdomain_vtable;
750 MonoClass *proxy_class;
751 char* proxy_class_name;
752 uint32_t interface_count;
753 MonoClass *interfaces [MONO_ZERO_LEN_ARRAY];
756 #define MONO_SIZEOF_REMOTE_CLASS (sizeof (MonoRemoteClass) - MONO_ZERO_LEN_ARRAY * SIZEOF_VOID_P)
759 guint64 new_object_count;
760 size_t initialized_class_count;
761 size_t generic_vtable_count;
762 size_t used_class_count;
764 size_t class_vtable_size;
765 size_t class_static_data_size;
766 size_t generic_instance_count;
767 size_t generic_class_count;
768 size_t inflated_method_count;
769 size_t inflated_method_count_2;
770 size_t inflated_type_count;
771 size_t generics_metadata_size;
772 size_t delegate_creations;
773 size_t imt_tables_size;
774 size_t imt_number_of_tables;
775 size_t imt_number_of_methods;
776 size_t imt_used_slots;
777 size_t imt_slots_with_collisions;
778 size_t imt_max_collisions_in_slot;
779 size_t imt_method_count_when_max_collisions;
780 size_t imt_trampolines_size;
781 size_t jit_info_table_insert_count;
782 size_t jit_info_table_remove_count;
783 size_t jit_info_table_lookup_count;
784 size_t generics_sharable_methods;
785 size_t generics_unsharable_methods;
786 size_t generics_shared_methods;
787 size_t gsharedvt_methods;
788 size_t minor_gc_count;
789 size_t major_gc_count;
790 size_t minor_gc_time_usecs;
791 size_t major_gc_time_usecs;
796 * new structure to hold performace counters values that are exported
798 * Note: never remove fields from this structure and only add them to the end.
799 * Size of fields and type should not be changed as well.
806 guint32 jit_failures;
807 /* Exceptions category */
808 guint32 exceptions_thrown;
809 guint32 exceptions_filters;
810 guint32 exceptions_finallys;
811 guint32 exceptions_depth;
812 guint32 aspnet_requests_queued;
813 guint32 aspnet_requests;
814 /* Memory category */
815 guint32 gc_collections0;
816 guint32 gc_collections1;
817 guint32 gc_collections2;
818 guint32 gc_promotions0;
819 guint32 gc_promotions1;
820 guint32 gc_promotion_finalizers;
825 guint32 gc_fin_survivors;
826 guint32 gc_num_handles;
827 guint32 gc_allocated;
830 guint32 gc_total_bytes;
831 guint32 gc_committed_bytes;
832 guint32 gc_reserved_bytes;
833 guint32 gc_num_pinned;
834 guint32 gc_sync_blocks;
835 /* Remoting category */
836 guint32 remoting_calls;
837 guint32 remoting_channels;
838 guint32 remoting_proxies;
839 guint32 remoting_classes;
840 guint32 remoting_objects;
841 guint32 remoting_contexts;
842 /* Loader category */
843 guint32 loader_classes;
844 guint32 loader_total_classes;
845 guint32 loader_appdomains;
846 guint32 loader_total_appdomains;
847 guint32 loader_assemblies;
848 guint32 loader_total_assemblies;
849 guint32 loader_failures;
850 guint32 loader_bytes;
851 guint32 loader_appdomains_uloaded;
852 /* Threads and Locks category */
853 guint32 thread_contentions;
854 guint32 thread_queue_len;
855 guint32 thread_queue_max;
856 guint32 thread_num_logical;
857 guint32 thread_num_physical;
858 guint32 thread_cur_recognized;
859 guint32 thread_num_recognized;
860 /* Interop category */
861 guint32 interop_num_ccw;
862 guint32 interop_num_stubs;
863 guint32 interop_num_marshals;
864 /* Security category */
865 guint32 security_num_checks;
866 guint32 security_num_link_checks;
867 guint32 security_time;
868 guint32 security_depth;
871 guint64 threadpool_workitems;
872 guint64 threadpool_ioworkitems;
873 guint threadpool_threads;
874 guint threadpool_iothreads;
877 extern MonoPerfCounters *mono_perfcounters;
879 MONO_API void mono_perfcounters_init (void);
882 * The definition of the first field in SafeHandle,
883 * Keep in sync with SafeHandle.cs, this is only used
884 * to access the `handle' parameter.
892 * Keep in sync with HandleRef.cs
899 extern MonoStats mono_stats;
901 typedef gboolean (*MonoGetCachedClassInfo) (MonoClass *klass, MonoCachedClassInfo *res);
903 typedef gboolean (*MonoGetClassFromName) (MonoImage *image, const char *name_space, const char *name, MonoClass **res);
905 static inline gboolean
906 method_is_dynamic (MonoMethod *method)
908 #ifdef DISABLE_REFLECTION_EMIT
911 return method->dynamic;
916 mono_classes_init (void);
919 mono_classes_cleanup (void);
922 mono_class_layout_fields (MonoClass *klass, int base_instance_size, int packing_size, gboolean sre);
925 mono_class_setup_interface_offsets (MonoClass *klass);
928 mono_class_setup_vtable_general (MonoClass *klass, MonoMethod **overrides, int onum, GList *in_setup);
931 mono_class_setup_vtable (MonoClass *klass);
934 mono_class_setup_methods (MonoClass *klass);
937 mono_class_setup_mono_type (MonoClass *klass);
940 mono_class_setup_parent (MonoClass *klass, MonoClass *parent);
943 mono_class_get_method_by_index (MonoClass *klass, int index);
946 mono_class_get_inflated_method (MonoClass *klass, MonoMethod *method);
949 mono_class_get_vtable_entry (MonoClass *klass, int offset);
952 mono_class_get_implemented_interfaces (MonoClass *klass, MonoError *error);
955 mono_class_get_vtable_size (MonoClass *klass);
958 mono_class_is_open_constructed_type (MonoType *t);
961 mono_class_get_overrides_full (MonoImage *image, guint32 type_token, MonoMethod ***overrides, gint32 *num_overrides,
962 MonoGenericContext *generic_context);
965 mono_class_get_cctor (MonoClass *klass) MONO_LLVM_INTERNAL;
968 mono_class_get_finalizer (MonoClass *klass);
971 mono_class_needs_cctor_run (MonoClass *klass, MonoMethod *caller);
974 mono_class_field_is_special_static (MonoClassField *field);
977 mono_class_field_get_special_static_type (MonoClassField *field);
980 mono_class_has_special_static_fields (MonoClass *klass);
983 mono_class_get_field_default_value (MonoClassField *field, MonoTypeEnum *def_type);
986 mono_class_get_property_default_value (MonoProperty *property, MonoTypeEnum *def_type);
989 mono_lookup_dynamic_token (MonoImage *image, guint32 token, MonoGenericContext *context, MonoError *error);
992 mono_lookup_dynamic_token_class (MonoImage *image, guint32 token, gboolean check_token, MonoClass **handle_class, MonoGenericContext *context, MonoError *error);
995 mono_runtime_create_jump_trampoline (MonoDomain *domain, MonoMethod *method, gboolean add_sync_wrapper, MonoError *error);
998 mono_runtime_create_delegate_trampoline (MonoClass *klass);
1001 mono_install_get_cached_class_info (MonoGetCachedClassInfo func);
1004 mono_install_get_class_from_name (MonoGetClassFromName func);
1006 MONO_PROFILER_API MonoGenericContext*
1007 mono_class_get_context (MonoClass *klass);
1009 MONO_PROFILER_API MonoMethodSignature*
1010 mono_method_signature_checked (MonoMethod *m, MonoError *err);
1013 mono_method_get_context_general (MonoMethod *method, gboolean uninflated);
1015 MONO_PROFILER_API MonoGenericContext*
1016 mono_method_get_context (MonoMethod *method);
1018 /* Used by monodis, thus cannot be MONO_INTERNAL */
1019 MONO_API MonoGenericContainer*
1020 mono_method_get_generic_container (MonoMethod *method);
1023 mono_generic_class_get_context (MonoGenericClass *gclass);
1026 mono_generic_class_get_class (MonoGenericClass *gclass);
1029 mono_method_set_generic_container (MonoMethod *method, MonoGenericContainer* container);
1032 mono_class_inflate_generic_method_full (MonoMethod *method, MonoClass *klass_hint, MonoGenericContext *context);
1035 mono_class_inflate_generic_method_full_checked (MonoMethod *method, MonoClass *klass_hint, MonoGenericContext *context, MonoError *error);
1038 mono_class_inflate_generic_method_checked (MonoMethod *method, MonoGenericContext *context, MonoError *error);
1041 mono_metadata_get_image_set_for_method (MonoMethodInflated *method);
1043 MONO_API MonoMethodSignature *
1044 mono_metadata_get_inflated_signature (MonoMethodSignature *sig, MonoGenericContext *context);
1047 mono_class_inflate_generic_type_with_mempool (MonoImage *image, MonoType *type, MonoGenericContext *context, MonoError *error);
1050 mono_class_inflate_generic_type_checked (MonoType *type, MonoGenericContext *context, MonoError *error);
1053 mono_metadata_free_inflated_signature (MonoMethodSignature *sig);
1055 MonoMethodSignature*
1056 mono_inflate_generic_signature (MonoMethodSignature *sig, MonoGenericContext *context, MonoError *error);
1060 MonoClass *object_class;
1061 MonoClass *byte_class;
1062 MonoClass *void_class;
1063 MonoClass *boolean_class;
1064 MonoClass *sbyte_class;
1065 MonoClass *int16_class;
1066 MonoClass *uint16_class;
1067 MonoClass *int32_class;
1068 MonoClass *uint32_class;
1069 MonoClass *int_class;
1070 MonoClass *uint_class;
1071 MonoClass *int64_class;
1072 MonoClass *uint64_class;
1073 MonoClass *single_class;
1074 MonoClass *double_class;
1075 MonoClass *char_class;
1076 MonoClass *string_class;
1077 MonoClass *enum_class;
1078 MonoClass *array_class;
1079 MonoClass *delegate_class;
1080 MonoClass *multicastdelegate_class;
1081 MonoClass *asyncresult_class;
1082 MonoClass *manualresetevent_class;
1083 MonoClass *typehandle_class;
1084 MonoClass *fieldhandle_class;
1085 MonoClass *methodhandle_class;
1086 MonoClass *systemtype_class;
1087 MonoClass *runtimetype_class;
1088 MonoClass *exception_class;
1089 MonoClass *threadabortexception_class;
1090 MonoClass *thread_class;
1091 MonoClass *internal_thread_class;
1092 #ifndef DISABLE_REMOTING
1093 MonoClass *transparent_proxy_class;
1094 MonoClass *real_proxy_class;
1095 MonoClass *marshalbyrefobject_class;
1096 MonoClass *iremotingtypeinfo_class;
1098 MonoClass *mono_method_message_class;
1099 MonoClass *appdomain_class;
1100 MonoClass *field_info_class;
1101 MonoClass *method_info_class;
1102 MonoClass *stringbuilder_class;
1103 MonoClass *math_class;
1104 MonoClass *stack_frame_class;
1105 MonoClass *stack_trace_class;
1106 MonoClass *marshal_class;
1107 MonoClass *typed_reference_class;
1108 MonoClass *argumenthandle_class;
1109 MonoClass *monitor_class;
1110 MonoClass *generic_ilist_class;
1111 MonoClass *generic_nullable_class;
1112 MonoClass *handleref_class;
1113 MonoClass *attribute_class;
1114 MonoClass *customattribute_data_class;
1115 MonoClass *critical_finalizer_object; /* MAYBE NULL */
1116 MonoClass *generic_ireadonlylist_class;
1117 MonoClass *threadpool_wait_callback_class;
1118 MonoMethod *threadpool_perform_wait_callback_method;
1121 #ifdef DISABLE_REMOTING
1122 #define mono_class_is_transparent_proxy(klass) (FALSE)
1123 #define mono_class_is_real_proxy(klass) (FALSE)
1125 #define mono_class_is_transparent_proxy(klass) ((klass) == mono_defaults.transparent_proxy_class)
1126 #define mono_class_is_real_proxy(klass) ((klass) == mono_defaults.real_proxy_class)
1129 #define mono_object_is_transparent_proxy(object) (mono_class_is_transparent_proxy (mono_object_class (object)))
1132 #define GENERATE_GET_CLASS_WITH_CACHE_DECL(shortname) \
1133 MonoClass* mono_class_get_##shortname##_class (void);
1135 #define GENERATE_TRY_GET_CLASS_WITH_CACHE_DECL(shortname) \
1136 MonoClass* mono_class_try_get_##shortname##_class (void);
1138 #define GENERATE_GET_CLASS_WITH_CACHE(shortname,name_space,name) \
1140 mono_class_get_##shortname##_class (void) \
1142 static MonoClass *tmp_class; \
1143 MonoClass *klass = tmp_class; \
1145 klass = mono_class_load_from_name (mono_defaults.corlib, name_space, name); \
1146 mono_memory_barrier (); \
1147 tmp_class = klass; \
1152 #define GENERATE_TRY_GET_CLASS_WITH_CACHE(shortname,name_space,name) \
1154 mono_class_try_get_##shortname##_class (void) \
1156 static volatile MonoClass *tmp_class; \
1157 static volatile gboolean inited; \
1158 MonoClass *klass = (MonoClass *)tmp_class; \
1159 mono_memory_barrier (); \
1161 klass = mono_class_try_load_from_name (mono_defaults.corlib, name_space, name); \
1162 tmp_class = klass; \
1163 mono_memory_barrier (); \
1169 GENERATE_TRY_GET_CLASS_WITH_CACHE_DECL (safehandle)
1173 GENERATE_GET_CLASS_WITH_CACHE_DECL (interop_proxy)
1174 GENERATE_GET_CLASS_WITH_CACHE_DECL (idispatch)
1175 GENERATE_GET_CLASS_WITH_CACHE_DECL (iunknown)
1176 GENERATE_GET_CLASS_WITH_CACHE_DECL (com_object)
1177 GENERATE_GET_CLASS_WITH_CACHE_DECL (variant)
1181 extern MonoDefaults mono_defaults;
1184 mono_loader_init (void);
1187 mono_loader_cleanup (void);
1190 mono_loader_lock (void) MONO_LLVM_INTERNAL;
1193 mono_loader_unlock (void) MONO_LLVM_INTERNAL;
1196 mono_loader_lock_track_ownership (gboolean track);
1199 mono_loader_lock_is_owned_by_self (void);
1202 mono_loader_lock_if_inited (void);
1205 mono_loader_unlock_if_inited (void);
1208 mono_reflection_init (void);
1211 mono_icall_init (void);
1214 mono_icall_cleanup (void);
1217 mono_method_get_wrapper_data (MonoMethod *method, guint32 id);
1220 mono_metadata_has_generic_params (MonoImage *image, guint32 token);
1222 MONO_API MonoGenericContainer *
1223 mono_metadata_load_generic_params (MonoImage *image, guint32 token,
1224 MonoGenericContainer *parent_container);
1227 mono_metadata_load_generic_param_constraints_checked (MonoImage *image, guint32 token,
1228 MonoGenericContainer *container, MonoError *error);
1230 MonoMethodSignature*
1231 mono_create_icall_signature (const char *sigstr);
1234 mono_register_jit_icall (gconstpointer func, const char *name, MonoMethodSignature *sig, gboolean is_save);
1237 mono_register_jit_icall_full (gconstpointer func, const char *name, MonoMethodSignature *sig, gboolean is_save, gboolean no_raise, const char *c_symbol);
1240 mono_register_jit_icall_wrapper (MonoJitICallInfo *info, gconstpointer wrapper);
1243 mono_find_jit_icall_by_name (const char *name) MONO_LLVM_INTERNAL;
1246 mono_find_jit_icall_by_addr (gconstpointer addr) MONO_LLVM_INTERNAL;
1249 mono_get_jit_icall_info (void);
1252 mono_lookup_jit_icall_symbol (const char *name);
1255 mono_class_set_type_load_failure (MonoClass *klass, const char * fmt, ...) MONO_ATTR_FORMAT_PRINTF(2,3);
1258 mono_class_get_exception_for_failure (MonoClass *klass);
1261 mono_type_get_name_full (MonoType *type, MonoTypeNameFormat format);
1264 mono_type_get_full_name (MonoClass *klass);
1267 mono_method_get_name_full (MonoMethod *method, gboolean signature, gboolean ret, MonoTypeNameFormat format);
1270 mono_method_get_full_name (MonoMethod *method);
1272 MonoArrayType *mono_dup_array_type (MonoImage *image, MonoArrayType *a);
1273 MonoMethodSignature *mono_metadata_signature_deep_dup (MonoImage *image, MonoMethodSignature *sig);
1276 mono_image_init_name_cache (MonoImage *image);
1278 gboolean mono_class_is_nullable (MonoClass *klass);
1279 MonoClass *mono_class_get_nullable_param (MonoClass *klass);
1281 /* object debugging functions, for use inside gdb */
1282 MONO_API void mono_object_describe (MonoObject *obj);
1283 MONO_API void mono_object_describe_fields (MonoObject *obj);
1284 MONO_API void mono_value_describe_fields (MonoClass* klass, const char* addr);
1285 MONO_API void mono_class_describe_statics (MonoClass* klass);
1287 /* method debugging functions, for use inside gdb */
1288 MONO_API void mono_method_print_code (MonoMethod *method);
1290 MONO_PROFILER_API char *mono_signature_full_name (MonoMethodSignature *sig);
1292 /*Enum validation related functions*/
1294 mono_type_is_valid_enum_basetype (MonoType * type);
1297 mono_class_is_valid_enum (MonoClass *klass);
1299 MONO_PROFILER_API gboolean
1300 mono_type_is_primitive (MonoType *type);
1303 mono_type_get_checked (MonoImage *image, guint32 type_token, MonoGenericContext *context, MonoError *error);
1306 mono_generic_class_is_generic_type_definition (MonoGenericClass *gklass);
1309 mono_class_get_method_generic (MonoClass *klass, MonoMethod *method);
1312 mono_type_get_basic_type_from_generic (MonoType *type);
1315 mono_method_can_access_method_full (MonoMethod *method, MonoMethod *called, MonoClass *context_klass);
1318 mono_method_can_access_field_full (MonoMethod *method, MonoClassField *field, MonoClass *context_klass);
1321 mono_class_can_access_class (MonoClass *access_class, MonoClass *target_class);
1324 mono_class_get_generic_type_definition (MonoClass *klass);
1327 mono_class_has_parent_and_ignore_generics (MonoClass *klass, MonoClass *parent);
1330 mono_method_get_vtable_slot (MonoMethod *method);
1333 mono_method_get_vtable_index (MonoMethod *method);
1336 mono_method_get_base_method (MonoMethod *method, gboolean definition, MonoError *error);
1339 mono_method_search_in_array_class (MonoClass *klass, const char *name, MonoMethodSignature *sig);
1342 mono_class_setup_interface_id (MonoClass *klass);
1344 MonoGenericContainer*
1345 mono_class_get_generic_container (MonoClass *klass);
1348 mono_class_alloc (MonoClass *klass, int size);
1351 mono_class_alloc0 (MonoClass *klass, int size);
1354 mono_class_setup_interfaces (MonoClass *klass, MonoError *error);
1357 mono_class_get_field_from_name_full (MonoClass *klass, const char *name, MonoType *type);
1360 mono_class_vtable_full (MonoDomain *domain, MonoClass *klass, MonoError *error);
1363 mono_class_is_assignable_from_slow (MonoClass *target, MonoClass *candidate);
1366 mono_class_has_variant_generic_params (MonoClass *klass);
1369 mono_class_is_variant_compatible (MonoClass *klass, MonoClass *oklass, gboolean check_for_reference_conv);
1371 gboolean mono_is_corlib_image (MonoImage *image);
1374 mono_field_get_type_checked (MonoClassField *field, MonoError *error);
1377 mono_class_get_fields_lazy (MonoClass* klass, gpointer *iter);
1380 mono_class_check_vtable_constraints (MonoClass *klass, GList *in_setup);
1383 mono_class_has_finalizer (MonoClass *klass);
1386 mono_unload_interface_id (MonoClass *klass);
1389 mono_class_get_methods_by_name (MonoClass *klass, const char *name, guint32 bflags, gboolean ignore_case, gboolean allow_ctors, MonoError *error);
1392 mono_class_full_name (MonoClass *klass);
1395 mono_class_inflate_generic_class_checked (MonoClass *gklass, MonoGenericContext *context, MonoError *error);
1398 mono_class_get_checked (MonoImage *image, guint32 type_token, MonoError *error);
1401 mono_class_get_and_inflate_typespec_checked (MonoImage *image, guint32 type_token, MonoGenericContext *context, MonoError *error);
1404 mono_class_from_name_checked (MonoImage *image, const char* name_space, const char *name, MonoError *error);
1407 mono_class_from_name_case_checked (MonoImage *image, const char* name_space, const char *name, MonoError *error);
1410 mono_field_from_token_checked (MonoImage *image, uint32_t token, MonoClass **retklass, MonoGenericContext *context, MonoError *error);
1413 mono_ldtoken_checked (MonoImage *image, guint32 token, MonoClass **handle_class, MonoGenericContext *context, MonoError *error);
1416 mono_class_from_generic_parameter_internal (MonoGenericParam *param);
1419 get_image_for_generic_param (MonoGenericParam *param);
1422 make_generic_name_string (MonoImage *image, int num);
1425 mono_class_load_from_name (MonoImage *image, const char* name_space, const char *name) MONO_LLVM_INTERNAL;
1428 mono_class_try_load_from_name (MonoImage *image, const char* name_space, const char *name);
1431 mono_error_set_for_class_failure (MonoError *orerror, const MonoClass *klass);
1434 mono_class_has_failure (const MonoClass *klass);
1436 /* Kind specific accessors */
1438 mono_class_get_generic_class (MonoClass *klass);
1441 mono_class_try_get_generic_class (MonoClass *klass);
1444 mono_class_set_flags (MonoClass *klass, guint32 flags);
1446 MonoGenericContainer*
1447 mono_class_try_get_generic_container (MonoClass *klass);
1450 mono_class_set_generic_container (MonoClass *klass, MonoGenericContainer *container);
1453 mono_class_gtd_get_canonical_inst (MonoClass *klass);
1456 mono_class_get_first_method_idx (MonoClass *klass);
1459 mono_class_set_first_method_idx (MonoClass *klass, guint32 idx);
1462 mono_class_get_first_field_idx (MonoClass *klass);
1465 mono_class_set_first_field_idx (MonoClass *klass, guint32 idx);
1468 mono_class_get_method_count (MonoClass *klass);
1471 mono_class_set_method_count (MonoClass *klass, guint32 count);
1474 mono_class_get_field_count (MonoClass *klass);
1477 mono_class_set_field_count (MonoClass *klass, guint32 count);
1480 mono_class_get_marshal_info (MonoClass *class);
1483 mono_class_set_marshal_info (MonoClass *class, MonoMarshalType *marshal_info);
1486 mono_class_get_ref_info_handle (MonoClass *class);
1489 mono_class_set_ref_info_handle (MonoClass *class, guint32 value);
1492 mono_class_get_exception_data (MonoClass *klass);
1495 mono_class_set_exception_data (MonoClass *klass, MonoErrorBoxed *value);
1498 mono_class_get_nested_classes_property (MonoClass *klass);
1501 mono_class_set_nested_classes_property (MonoClass *klass, GList *value);
1503 MonoClassPropertyInfo*
1504 mono_class_get_property_info (MonoClass *klass);
1507 mono_class_set_property_info (MonoClass *klass, MonoClassPropertyInfo *info);
1510 mono_class_get_event_info (MonoClass *klass);
1513 mono_class_set_event_info (MonoClass *klass, MonoClassEventInfo *info);
1515 MonoFieldDefaultValue*
1516 mono_class_get_field_def_values (MonoClass *klass);
1519 mono_class_set_field_def_values (MonoClass *klass, MonoFieldDefaultValue *values);
1522 mono_class_get_declsec_flags (MonoClass *class);
1525 mono_class_set_declsec_flags (MonoClass *class, guint32 value);
1528 mono_class_set_is_com_object (MonoClass *klass);
1530 /*Now that everything has been defined, let's include the inline functions */
1531 #include <mono/metadata/class-inlines.h>
1533 #endif /* __MONO_METADATA_CLASS_INTERNALS_H__ */