#include <mono/metadata/object.h>
#include <mono/metadata/threads.h>
+#include <mono/metadata/monitor.h>
#include <mono/metadata/reflection.h>
#include <mono/metadata/assembly.h>
#include <mono/metadata/tabledefs.h>
#include <mono/metadata/unicode.h>
#include <mono/metadata/appdomain.h>
#include <mono/metadata/marshal.h>
-#include <mono/metadata/gc.h>
+#include <mono/metadata/gc-internal.h>
#include <mono/metadata/rand.h>
#include <mono/metadata/sysmath.h>
-#include <mono/metadata/debug-symfile.h>
#include <mono/metadata/string-icalls.h>
+#include <mono/metadata/debug-mono-symfile.h>
#include <mono/metadata/process.h>
+#include <mono/metadata/environment.h>
#include <mono/io-layer/io-layer.h>
#include <mono/utils/strtod.h>
#endif
#include "decimal.h"
+static MonoReflectionAssembly* ves_icall_System_Reflection_Assembly_GetCallingAssembly (void);
+
+
static MonoString *
mono_double_ToStringImpl (double value)
{
/* FIXME: Handle formats, etc. */
MonoString *s;
gchar *retVal;
+
+ MONO_ARCH_SAVE_REGS;
+
retVal = g_strdup_printf ("%.15g", value);
s = mono_string_new (mono_domain_get (), retVal);
g_free (retVal);
static double
mono_double_ParseImpl (char *ptr)
{
- return bsd_strtod (ptr, NULL);
+ gchar *endptr = NULL;
+ gdouble result;
+
+ MONO_ARCH_SAVE_REGS;
+
+ if (*ptr)
+ result = bsd_strtod (ptr, &endptr);
+
+ if (!*ptr || (endptr && *endptr))
+ mono_raise_exception (mono_exception_from_name (mono_defaults.corlib,
+ "System",
+ "FormatException"));
+
+ return result;
}
static MonoString *
mono_float_ToStringImpl (float value)
{
+ MONO_ARCH_SAVE_REGS;
+
return mono_double_ToStringImpl (value);
}
gint32 esize;
gpointer *ea;
+ MONO_ARCH_SAVE_REGS;
+
ao = (MonoArray *)this;
ac = (MonoClass *)ao->obj.vtable->klass;
MonoArray *ao, *io;
gint32 i, pos, *ind;
+ MONO_ARCH_SAVE_REGS;
+
MONO_CHECK_ARG_NULL (idxs);
io = (MonoArray *)idxs;
gint64 i64;
gdouble r64;
+ MONO_ARCH_SAVE_REGS;
+
if (value)
vc = value->vtable->klass;
else
MonoClass *ac, *ic;
gint32 i, pos, *ind;
+ MONO_ARCH_SAVE_REGS;
+
MONO_CHECK_ARG_NULL (idxs);
ic = idxs->obj.vtable->klass;
MonoArray *array;
gint32 *sizes, i;
+ MONO_ARCH_SAVE_REGS;
+
MONO_CHECK_ARG_NULL (type);
MONO_CHECK_ARG_NULL (lengths);
sizes [i + aklass->rank] = 0;
}
- array = mono_array_new_full (mono_domain_get (), aklass, sizes, sizes + aklass->rank);
+ array = mono_array_new_full (mono_object_domain (type), aklass, sizes, sizes + aklass->rank);
return array;
}
static gint32
ves_icall_System_Array_GetRank (MonoObject *this)
{
+ MONO_ARCH_SAVE_REGS;
+
return this->vtable->klass->rank;
}
ves_icall_System_Array_GetLength (MonoArray *this, gint32 dimension)
{
gint32 rank = ((MonoObject *)this)->vtable->klass->rank;
+
+ MONO_ARCH_SAVE_REGS;
+
if ((dimension < 0) || (dimension >= rank))
mono_raise_exception (mono_get_exception_index_out_of_range ());
ves_icall_System_Array_GetLowerBound (MonoArray *this, gint32 dimension)
{
gint32 rank = ((MonoObject *)this)->vtable->klass->rank;
+
+ MONO_ARCH_SAVE_REGS;
+
if ((dimension < 0) || (dimension >= rank))
mono_raise_exception (mono_get_exception_index_out_of_range ());
void * dest_addr = mono_array_addr_with_size (dest, element_size, dest_idx);
void * source_addr = mono_array_addr_with_size (source, element_size, source_idx);
+ MONO_ARCH_SAVE_REGS;
+
g_assert (dest_idx + length <= mono_array_length (dest));
g_assert (source_idx + length <= mono_array_length (source));
memmove (dest_addr, source_addr, element_size * length);
}
static void
-ves_icall_InitializeArray (MonoArray *array, MonoClassField *field_handle)
+ves_icall_System_Runtime_CompilerServices_RuntimeHelpers_InitializeArray (MonoArray *array, MonoClassField *field_handle)
{
MonoClass *klass = array->obj.vtable->klass;
guint32 size = mono_array_element_size (klass);
int i;
+ MONO_ARCH_SAVE_REGS;
+
if (array->bounds == NULL)
size *= array->max_length;
else
#endif
}
+static gint
+ves_icall_System_Runtime_CompilerServices_RuntimeHelpers_GetOffsetToStringData (void)
+{
+ MONO_ARCH_SAVE_REGS;
+
+ return offsetof (MonoString, chars);
+}
+
+static MonoObject *
+ves_icall_System_Runtime_CompilerServices_RuntimeHelpers_GetObjectValue (MonoObject *obj)
+{
+ MONO_ARCH_SAVE_REGS;
+
+ if ((obj == NULL) || (! (obj->vtable->klass->valuetype)))
+ return obj;
+ else
+ return mono_object_clone (obj);
+}
+
+static void
+ves_icall_System_Runtime_CompilerServices_RuntimeHelpers_RunClassConstructor (MonoType *handle)
+{
+ MonoClass *klass;
+
+ MONO_ARCH_SAVE_REGS;
+
+ MONO_CHECK_ARG_NULL (handle);
+
+ klass = mono_class_from_mono_type (handle);
+ MONO_CHECK_ARG (handle, klass);
+
+ /* This will call the type constructor */
+ if (! (klass->flags & TYPE_ATTRIBUTE_INTERFACE))
+ mono_class_vtable (mono_domain_get (), klass);
+}
+
static MonoObject *
ves_icall_System_Object_MemberwiseClone (MonoObject *this)
{
+ MONO_ARCH_SAVE_REGS;
+
return mono_object_clone (this);
}
ves_icall_System_Object_GetHashCode (MonoObject *this)
{
register guint32 key;
+
+ MONO_ARCH_SAVE_REGS;
+
key = (GPOINTER_TO_UINT (this) >> MONO_OBJECT_ALIGNMENT_SHIFT) * 2654435761u;
return key & 0x7fffffff;
const char *p;
guint h = 0;
+ MONO_ARCH_SAVE_REGS;
+
MONO_CHECK_ARG_NULL (this);
size = this->vtable->klass->instance_size - sizeof (MonoObject);
gint32 size;
const char *p, *s;
+ MONO_ARCH_SAVE_REGS;
+
MONO_CHECK_ARG_NULL (that);
if (this->vtable != that->vtable)
static MonoReflectionType *
ves_icall_System_Object_GetType (MonoObject *obj)
{
- return mono_type_get_object (mono_domain_get (), &obj->vtable->klass->byval_arg);
+ MONO_ARCH_SAVE_REGS;
+
+ return mono_type_get_object (mono_object_domain (obj), &obj->vtable->klass->byval_arg);
}
static void
mono_type_type_from_obj (MonoReflectionType *mtype, MonoObject *obj)
{
+ MONO_ARCH_SAVE_REGS;
+
mtype->type = &obj->vtable->klass->byval_arg;
g_assert (mtype->type->type);
}
static gint32
ves_icall_AssemblyBuilder_getToken (MonoReflectionAssemblyBuilder *assb, MonoObject *obj)
{
+ MONO_ARCH_SAVE_REGS;
+
return mono_image_create_token (assb->dynamic_assembly, obj);
}
MonoDynamicAssembly *ass = assb->dynamic_assembly;
char *p = mono_array_addr (buf, char, 0);
+ MONO_ARCH_SAVE_REGS;
+
mono_image_create_pefile (assb);
if (offset >= ass->pefile.index)
return count;
}
-static gboolean
-get_get_type_caller (MonoMethod *m, gint32 no, gint32 ilo, gpointer data) {
- MonoImage **dest = data;
+static void
+ves_icall_AssemblyBuilder_build_metadata (MonoReflectionAssemblyBuilder *assb)
+{
+ MONO_ARCH_SAVE_REGS;
- /* skip icalls and Type::GetType () */
- if (!m || m->wrapper_type || (m->iflags & METHOD_IMPL_ATTRIBUTE_INTERNAL_CALL) ||
- (strcmp (m->name, "GetType") == 0 && m->klass == mono_defaults.monotype_class->parent))
- return FALSE;
- *dest = m->klass->image;
- return TRUE;
+ mono_image_build_metadata (assb);
}
static MonoReflectionType*
-ves_icall_type_from_name (MonoString *name)
+ves_icall_type_from_name (MonoString *name,
+ MonoBoolean throwOnError,
+ MonoBoolean ignoreCase)
{
- MonoImage *image = NULL;
- MonoType *type;
gchar *str;
+ MonoType *type = NULL;
+ MonoAssembly *assembly;
+ MonoTypeNameParse info;
+
+ MONO_ARCH_SAVE_REGS;
- mono_stack_walk (get_get_type_caller, &image);
str = mono_string_to_utf8 (name);
- /*g_print ("requested type %s\n", str);*/
- type = mono_reflection_type_from_name (str, image);
+ if (!mono_reflection_parse_type (str, &info)) {
+ g_free (str);
+ g_list_free (info.modifiers);
+ g_list_free (info.nested);
+ if (throwOnError) /* uhm: this is a parse error, though... */
+ mono_raise_exception (mono_get_exception_type_load ());
+
+ return NULL;
+ }
+
+ if (info.assembly.name) {
+ assembly = mono_assembly_load (&info.assembly, NULL, NULL);
+ } else {
+ MonoReflectionAssembly *refass;
+
+ refass = ves_icall_System_Reflection_Assembly_GetCallingAssembly ();
+ assembly = refass->assembly;
+ }
+
+ if (assembly)
+ type = mono_reflection_get_type (assembly->image, &info, ignoreCase);
+
+ if (!info.assembly.name && !type) /* try mscorlib */
+ type = mono_reflection_get_type (NULL, &info, ignoreCase);
+
g_free (str);
- if (!type)
+ g_list_free (info.modifiers);
+ g_list_free (info.nested);
+ if (!type) {
+ if (throwOnError)
+ mono_raise_exception (mono_get_exception_type_load ());
+
return NULL;
- /*g_print ("got it\n");*/
- return mono_type_get_object (mono_object_domain (name), type);
+ }
+
+ return mono_type_get_object (mono_domain_get (), type);
}
static MonoReflectionType*
MonoDomain *domain = mono_domain_get ();
MonoClass *klass = mono_class_from_mono_type (handle);
+ MONO_ARCH_SAVE_REGS;
+
mono_class_init (klass);
return mono_type_get_object (domain, handle);
}
static guint32
ves_icall_type_Equals (MonoReflectionType *type, MonoReflectionType *c)
{
+ MONO_ARCH_SAVE_REGS;
+
if (type->type && c->type)
return mono_metadata_type_equal (type->type, c->type);
g_print ("type equals\n");
ves_icall_type_GetTypeCode (MonoReflectionType *type)
{
int t = type->type->type;
+
+ MONO_ARCH_SAVE_REGS;
+
handle_enum:
switch (t) {
case MONO_TYPE_VOID:
MonoClass *klass;
MonoClass *klassc;
+ MONO_ARCH_SAVE_REGS;
+
g_assert (type != NULL);
domain = ((MonoObject *)type)->vtable->domain;
{
MonoClass *klass = mono_class_from_mono_type (type->type);
+ MONO_ARCH_SAVE_REGS;
+
return klass->flags;
}
{
MonoDomain *domain = mono_domain_get ();
+ MONO_ARCH_SAVE_REGS;
+
info->parent = mono_type_get_object (domain, &method->klass->byval_arg);
info->ret = mono_type_get_object (domain, method->signature->ret);
info->attrs = method->flags;
MonoReflectionParameter** args;
int i;
+ MONO_ARCH_SAVE_REGS;
+
args = mono_param_get_objects (domain, method);
if (!System_Reflection_ParameterInfo)
System_Reflection_ParameterInfo = mono_class_from_name (
static void
ves_icall_get_field_info (MonoReflectionField *field, MonoFieldInfo *info)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (field);
+
+ MONO_ARCH_SAVE_REGS;
info->parent = mono_type_get_object (domain, &field->klass->byval_arg);
info->type = mono_type_get_object (domain, field->field->type);
}
static MonoObject *
-ves_icall_MonoField_GetValue (MonoReflectionField *field, MonoObject *obj) {
- MonoObject *res;
+ves_icall_MonoField_GetValueInternal (MonoReflectionField *field, MonoObject *obj)
+{
+ MonoObject *o;
+ MonoClassField *cf = field->field;
MonoClass *klass;
- MonoType *ftype = field->field->type;
- int type = ftype->type;
- char *p, *r;
- guint32 align;
+ MonoVTable *vtable;
+ MonoDomain *domain = mono_object_domain (field);
+ gchar *v;
+ gboolean is_static = FALSE;
+ gboolean is_ref = FALSE;
+
+ MONO_ARCH_SAVE_REGS;
mono_class_init (field->klass);
- if (ftype->attrs & FIELD_ATTRIBUTE_STATIC) {
- MonoVTable *vtable;
- vtable = mono_class_vtable (mono_domain_get (), field->klass);
- p = (char*)(vtable->data) + field->field->offset;
- } else {
- p = (char*)obj + field->field->offset;
- }
- switch (type) {
- case MONO_TYPE_OBJECT:
+ switch (cf->type->type) {
case MONO_TYPE_STRING:
- case MONO_TYPE_SZARRAY:
+ case MONO_TYPE_OBJECT:
+ case MONO_TYPE_CLASS:
case MONO_TYPE_ARRAY:
- return *(MonoObject**)p;
+ case MONO_TYPE_SZARRAY:
+ is_ref = TRUE;
+ break;
+ case MONO_TYPE_U1:
+ case MONO_TYPE_I1:
+ case MONO_TYPE_BOOLEAN:
+ case MONO_TYPE_U2:
+ case MONO_TYPE_I2:
+ case MONO_TYPE_CHAR:
+ case MONO_TYPE_U:
+ case MONO_TYPE_I:
+ case MONO_TYPE_U4:
+ case MONO_TYPE_I4:
+ case MONO_TYPE_R4:
+ case MONO_TYPE_U8:
+ case MONO_TYPE_I8:
+ case MONO_TYPE_R8:
+ case MONO_TYPE_VALUETYPE:
+ is_ref = cf->type->byref;
+ break;
+ default:
+ g_error ("type 0x%x not handled in "
+ "ves_icall_Monofield_GetValue", cf->type->type);
+ return NULL;
}
- klass = mono_class_from_mono_type (ftype);
- res = mono_object_new (mono_domain_get (), klass);
- r = (char*)res + sizeof (MonoObject);
- memcpy (r, p, mono_class_value_size (klass, &align));
- return res;
+ if (cf->type->attrs & FIELD_ATTRIBUTE_STATIC) {
+ is_static = TRUE;
+ vtable = mono_class_vtable (domain, field->klass);
+ }
+
+ if (is_ref) {
+ if (is_static) {
+ mono_field_static_get_value (vtable, cf, &o);
+ } else {
+ mono_field_get_value (obj, cf, &o);
+ }
+ return o;
+ }
+
+ /* boxed value type */
+ klass = mono_class_from_mono_type (cf->type);
+ o = mono_object_new (domain, klass);
+ v = ((gchar *) o) + sizeof (MonoObject);
+ if (is_static) {
+ mono_field_static_get_value (vtable, cf, v);
+ } else {
+ mono_field_get_value (obj, cf, v);
+ }
+
+ return o;
}
static void
MonoClassField *cf = field->field;
gchar *v;
+ MONO_ARCH_SAVE_REGS;
+
v = (gchar *) value;
if (!cf->type->byref) {
switch (cf->type->type) {
case MONO_TYPE_I:
case MONO_TYPE_U4:
case MONO_TYPE_I4:
+ case MONO_TYPE_R4:
case MONO_TYPE_U8:
case MONO_TYPE_I8:
+ case MONO_TYPE_R8:
case MONO_TYPE_VALUETYPE:
v += sizeof (MonoObject);
break;
}
if (cf->type->attrs & FIELD_ATTRIBUTE_STATIC) {
- MonoVTable *vtable = mono_class_vtable (mono_domain_get (), field->klass);
+ MonoVTable *vtable = mono_class_vtable (mono_object_domain (field), field->klass);
mono_field_static_set_value (vtable, cf, v);
} else {
mono_field_set_value (obj, cf, v);
static void
ves_icall_get_property_info (MonoReflectionProperty *property, MonoPropertyInfo *info)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (property);
+
+ MONO_ARCH_SAVE_REGS;
info->parent = mono_type_get_object (domain, &property->klass->byval_arg);
info->name = mono_string_new (domain, property->property->name);
static void
ves_icall_get_event_info (MonoReflectionEvent *event, MonoEventInfo *info)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (event);
+
+ MONO_ARCH_SAVE_REGS;
info->parent = mono_type_get_object (domain, &event->klass->byval_arg);
info->name = mono_string_new (domain, event->event->name);
static MonoArray*
ves_icall_Type_GetInterfaces (MonoReflectionType* type)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (type);
MonoArray *intf;
int ninterf, i;
MonoClass *class = mono_class_from_mono_type (type->type);
MonoClass *parent;
+ MONO_ARCH_SAVE_REGS;
+
ninterf = 0;
for (parent = class; parent; parent = parent->parent) {
ninterf += parent->interface_count;
return intf;
}
+static void
+ves_icall_Type_GetInterfaceMapData (MonoReflectionType *type, MonoReflectionType *iface, MonoArray **targets, MonoArray **methods)
+{
+ MonoClass *class = mono_class_from_mono_type (type->type);
+ MonoClass *iclass = mono_class_from_mono_type (iface->type);
+ MonoReflectionMethod *member;
+ int i, len, ioffset;
+ MonoDomain *domain;
+
+ MONO_ARCH_SAVE_REGS;
+
+ /* type doesn't implement iface: the exception is thrown in managed code */
+ if ((iclass->interface_id > class->max_interface_id) || !class->interface_offsets [iclass->interface_id])
+ return;
+
+ len = iclass->method.count;
+ ioffset = class->interface_offsets [iclass->interface_id];
+ domain = mono_object_domain (type);
+ *targets = mono_array_new (domain, mono_defaults.method_info_class, len);
+ *methods = mono_array_new (domain, mono_defaults.method_info_class, len);
+ for (i = 0; i < len; ++i) {
+ member = mono_method_get_object (domain, iclass->methods [i], iclass);
+ mono_array_set (*methods, gpointer, i, member);
+ member = mono_method_get_object (domain, class->vtable [i + ioffset], class);
+ mono_array_set (*targets, gpointer, i, member);
+ }
+}
+
static MonoReflectionType*
ves_icall_MonoType_GetElementType (MonoReflectionType *type)
{
MonoClass *class = mono_class_from_mono_type (type->type);
+
+ MONO_ARCH_SAVE_REGS;
+
if (class->enumtype && class->enum_basetype) /* types that are modifierd typebuilkders may not have enum_basetype set */
return mono_type_get_object (mono_object_domain (type), class->enum_basetype);
else if (class->element_class)
return NULL;
}
+static MonoReflectionType*
+ves_icall_get_type_parent (MonoReflectionType *type)
+{
+ MonoClass *class = mono_class_from_mono_type (type->type);
+
+ MONO_ARCH_SAVE_REGS;
+
+ return class->parent ? mono_type_get_object (mono_object_domain (type), &class->parent->byval_arg): NULL;
+}
+
+static MonoBoolean
+ves_icall_type_ispointer (MonoReflectionType *type)
+{
+ MONO_ARCH_SAVE_REGS;
+
+ return type->type->type == MONO_TYPE_PTR;
+}
+
+static MonoBoolean
+ves_icall_type_isbyref (MonoReflectionType *type)
+{
+ MONO_ARCH_SAVE_REGS;
+
+ return type->type->byref;
+}
+
+static MonoReflectionModule*
+ves_icall_MonoType_get_Module (MonoReflectionType *type)
+{
+ MonoClass *class = mono_class_from_mono_type (type->type);
+
+ MONO_ARCH_SAVE_REGS;
+
+ return mono_module_get_object (mono_object_domain (type), class->image);
+}
+
static void
ves_icall_get_type_info (MonoType *type, MonoTypeInfo *info)
{
MonoDomain *domain = mono_domain_get ();
MonoClass *class = mono_class_from_mono_type (type);
- info->parent = class->parent ? mono_type_get_object (domain, &class->parent->byval_arg): NULL;
+ MONO_ARCH_SAVE_REGS;
+
info->nested_in = class->nested_in ? mono_type_get_object (domain, &class->nested_in->byval_arg): NULL;
info->name = mono_string_new (domain, class->name);
info->name_space = mono_string_new (domain, class->name_space);
- info->attrs = class->flags;
info->rank = class->rank;
info->assembly = mono_assembly_get_object (domain, class->image->assembly);
if (class->enumtype && class->enum_basetype) /* types that are modifierd typebuilkders may not have enum_basetype set */
else
info->etype = NULL;
- info->isbyref = type->byref;
- info->ispointer = type->type == MONO_TYPE_PTR;
- info->isprimitive = (type->type >= MONO_TYPE_BOOLEAN) && (type->type <= MONO_TYPE_R8);
+ info->isprimitive = (!type->byref && (type->type >= MONO_TYPE_BOOLEAN) && (type->type <= MONO_TYPE_R8));
}
static MonoObject *
ves_icall_InternalInvoke (MonoReflectionMethod *method, MonoObject *this, MonoArray *params)
{
- return mono_runtime_invoke_array (method->method, this, params, NULL);
+ /*
+ * Invoke from reflection is supposed to always be a virtual call (the API
+ * is stupid), mono_runtime_invoke_*() calls the provided method, allowing
+ * greater flexibility.
+ */
+ MonoMethod *m = method->method;
+ int pcount;
+
+ MONO_ARCH_SAVE_REGS;
+
+ if (this) {
+ if (!mono_object_isinst (this, m->klass))
+ mono_raise_exception (mono_exception_from_name (mono_defaults.corlib, "System.Reflection", "TargetException"));
+ m = mono_object_get_virtual_method (this, m);
+ } else if (!(m->flags & METHOD_ATTRIBUTE_STATIC) && strcmp (m->name, ".ctor"))
+ mono_raise_exception (mono_exception_from_name (mono_defaults.corlib, "System.Reflection", "TargetException"));
+
+ pcount = params? mono_array_length (params): 0;
+ if (pcount != m->signature->param_count)
+ mono_raise_exception (mono_exception_from_name (mono_defaults.corlib, "System.Reflection", "TargetParameterCountException"));
+
+ return mono_runtime_invoke_array (m, this, params, NULL);
}
static MonoObject *
ves_icall_InternalExecute (MonoReflectionMethod *method, MonoObject *this, MonoArray *params, MonoArray **outArgs)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (method);
MonoMethod *m = method->method;
MonoMethodSignature *sig = m->signature;
MonoArray *out_args;
MonoObject *result;
int i, j, outarg_count = 0;
+ MONO_ARCH_SAVE_REGS;
+
if (m->klass == mono_defaults.object_class) {
if (!strcmp (m->name, "FieldGetter")) {
} else
*((gpointer *)this + k->fields [i].offset) = val;
- g_assert (result);
+ out_args = mono_array_new (domain, mono_defaults.object_class, 0);
+ *outArgs = out_args;
+
g_free (str);
return NULL;
}
static MonoObject *
ves_icall_System_Enum_ToObject (MonoReflectionType *type, MonoObject *obj)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain;
MonoClass *enumc, *objc;
gint32 s1, s2;
MonoObject *res;
+ MONO_ARCH_SAVE_REGS;
+
MONO_CHECK_ARG_NULL (type);
MONO_CHECK_ARG_NULL (obj);
+ domain = mono_object_domain (type);
enumc = mono_class_from_mono_type (type->type);
objc = obj->vtable->klass;
static MonoObject *
ves_icall_System_Enum_get_value (MonoObject *this)
{
- MonoDomain *domain = mono_domain_get ();
MonoObject *res;
MonoClass *enumc;
gpointer dst;
gpointer src;
int size;
+ MONO_ARCH_SAVE_REGS;
+
if (!this)
return NULL;
g_assert (this->vtable->klass->enumtype);
enumc = mono_class_from_mono_type (this->vtable->klass->enum_basetype);
- res = mono_object_new (domain, enumc);
+ res = mono_object_new (mono_object_domain (this), enumc);
dst = (char *)res + sizeof (MonoObject);
src = (char *)this + sizeof (MonoObject);
size = mono_class_value_size (enumc, NULL);
static void
ves_icall_get_enum_info (MonoReflectionType *type, MonoEnumInfo *info)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (type);
MonoClass *enumc = mono_class_from_mono_type (type->type);
guint i, j, nvalues, crow;
MonoClassField *field;
+ MONO_ARCH_SAVE_REGS;
+
info->utype = mono_type_get_object (domain, enumc->enum_basetype);
nvalues = enumc->field.count - 1;
info->names = mono_array_new (domain, mono_defaults.string_class, nvalues);
}
}
-static MonoMethod*
-search_method (MonoReflectionType *type, const char *name, guint32 flags, MonoArray *args)
-{
- MonoClass *klass, *start_class;
- MonoMethod *m;
- MonoReflectionType *paramt;
- int i, j;
-
- start_class = klass = mono_class_from_mono_type (type->type);
- while (klass) {
- for (i = 0; i < klass->method.count; ++i) {
- m = klass->methods [i];
- if (!((m->flags & flags) == flags))
- continue;
- if (strcmp(m->name, name))
- continue;
- if (!args)
- return m;
- if (m->signature->param_count != mono_array_length (args))
- continue;
- for (j = 0; j < m->signature->param_count; ++j) {
- paramt = mono_array_get (args, MonoReflectionType*, j);
- if (!mono_metadata_type_equal (paramt->type, m->signature->params [j]))
- break;
- }
- if (j == m->signature->param_count)
- return m;
- }
- klass = klass->parent;
- }
- //g_print ("Method %s.%s::%s (%d) not found\n", start_class->name_space, start_class->name, name, mono_array_length (args));
- return NULL;
-}
-
-static MonoReflectionMethod*
-ves_icall_get_constructor (MonoReflectionType *type, MonoArray *args)
-{
- MonoDomain *domain = mono_domain_get ();
- MonoMethod *m;
- MonoClass *refc = mono_class_from_mono_type (type->type);
-
- m = search_method (type, ".ctor", METHOD_ATTRIBUTE_RT_SPECIAL_NAME, args);
- if (m)
- return mono_method_get_object (domain, m, refc);
- return NULL;
-}
-
-static MonoReflectionMethod*
-ves_icall_get_method (MonoReflectionType *type, MonoString *name, MonoArray *args)
-{
- MonoDomain *domain = mono_domain_get ();
- MonoMethod *m;
- MonoClass *refc = mono_class_from_mono_type (type->type);
- char *n = mono_string_to_utf8 (name);
-
- m = search_method (type, n, 0, args);
- g_free (n);
- if (m)
- return mono_method_get_object (domain, m, refc);
- return NULL;
-}
-
-static MonoProperty*
-search_property (MonoClass *klass, char* name, MonoArray *args) {
- int i;
- MonoProperty *p;
-
- /* FIXME: handle args */
- for (i = 0; i < klass->property.count; ++i) {
- p = &klass->properties [i];
- if (strcmp (p->name, name) == 0)
- return p;
- }
- return NULL;
-}
-
-static MonoReflectionProperty*
-ves_icall_get_property (MonoReflectionType *type, MonoString *name, MonoArray *args)
-{
- MonoDomain *domain = mono_domain_get ();
- MonoProperty *p;
- MonoClass *class = mono_class_from_mono_type (type->type);
- char *n = mono_string_to_utf8 (name);
-
- p = search_property (class, n, args);
- g_free (n);
- if (p)
- return mono_property_get_object (domain, class, p);
- return NULL;
-}
-
enum {
BFLAGS_IgnoreCase = 1,
BFLAGS_DeclaredOnly = 2,
domain = ((MonoObject *)type)->vtable->domain;
klass = startklass = mono_class_from_mono_type (type->type);
+ MONO_ARCH_SAVE_REGS;
+
if (!name)
return NULL;
int i, len, match;
MonoClassField *field;
+ MONO_ARCH_SAVE_REGS;
+
domain = ((MonoObject *)type)->vtable->domain;
klass = startklass = mono_class_from_mono_type (type->type);
{
MonoDomain *domain;
GSList *l = NULL, *tmp;
- static MonoClass *System_Reflection_MethodInfo;
MonoClass *startklass, *klass;
MonoArray *res;
MonoMethod *method;
MonoObject *member;
int i, len, match;
+ GHashTable *method_slots = g_hash_table_new (NULL, NULL);
+ MONO_ARCH_SAVE_REGS;
+
domain = ((MonoObject *)type)->vtable->domain;
klass = startklass = mono_class_from_mono_type (type->type);
+ len = 0;
handle_parent:
for (i = 0; i < klass->method.count; ++i) {
if (!match)
continue;
match = 0;
+ if (g_hash_table_lookup (method_slots, GUINT_TO_POINTER (method->slot)))
+ continue;
+ g_hash_table_insert (method_slots, GUINT_TO_POINTER (method->slot), method);
member = (MonoObject*)mono_method_get_object (domain, method, startklass);
-
+
l = g_slist_prepend (l, member);
+ len++;
}
if (!(bflags & BFLAGS_DeclaredOnly) && (klass = klass->parent))
goto handle_parent;
- len = g_slist_length (l);
- if (!System_Reflection_MethodInfo)
- System_Reflection_MethodInfo = mono_class_from_name (
- mono_defaults.corlib, "System.Reflection", "MethodInfo");
- res = mono_array_new (domain, System_Reflection_MethodInfo, len);
+ res = mono_array_new (domain, mono_defaults.method_info_class, len);
i = 0;
tmp = l;
for (; tmp; tmp = tmp->next, ++i)
mono_array_set (res, gpointer, i, tmp->data);
g_slist_free (l);
-
+ g_hash_table_destroy (method_slots);
return res;
}
MonoObject *member;
int i, len, match;
+ MONO_ARCH_SAVE_REGS;
+
domain = ((MonoObject *)type)->vtable->domain;
klass = startklass = mono_class_from_mono_type (type->type);
-handle_parent:
for (i = 0; i < klass->method.count; ++i) {
match = 0;
method = klass->methods [i];
l = g_slist_prepend (l, member);
}
- if (!(bflags & BFLAGS_DeclaredOnly) && (klass = klass->parent))
- goto handle_parent;
len = g_slist_length (l);
if (!System_Reflection_ConstructorInfo)
System_Reflection_ConstructorInfo = mono_class_from_name (
MonoArray *res;
MonoMethod *method;
MonoProperty *prop;
- int i, len, match;
+ int i, match;
+ int len = 0;
+ GHashTable *method_slots = g_hash_table_new (NULL, NULL);
+
+ MONO_ARCH_SAVE_REGS;
domain = ((MonoObject *)type)->vtable->domain;
klass = startklass = mono_class_from_mono_type (type->type);
if (!match)
continue;
match = 0;
+
+ if (g_hash_table_lookup (method_slots, GUINT_TO_POINTER (method->slot)))
+ continue;
+ g_hash_table_insert (method_slots, GUINT_TO_POINTER (method->slot), prop);
+
l = g_slist_prepend (l, mono_property_get_object (domain, klass, prop));
+ len++;
}
if ((!(bflags & BFLAGS_DeclaredOnly) && (klass = klass->parent)))
goto handle_parent;
- len = g_slist_length (l);
if (!System_Reflection_PropertyInfo)
System_Reflection_PropertyInfo = mono_class_from_name (
mono_defaults.corlib, "System.Reflection", "PropertyInfo");
for (; tmp; tmp = tmp->next, ++i)
mono_array_set (res, gpointer, i, tmp->data);
g_slist_free (l);
+ g_hash_table_destroy (method_slots);
return res;
}
+static MonoReflectionEvent *
+ves_icall_MonoType_GetEvent (MonoReflectionType *type, MonoString *name, guint32 bflags)
+{
+ MonoDomain *domain;
+ MonoClass *klass;
+ gint i;
+ MonoEvent *event;
+ MonoMethod *method;
+ gchar *event_name;
+
+ MONO_ARCH_SAVE_REGS;
+
+ event_name = mono_string_to_utf8 (name);
+ klass = mono_class_from_mono_type (type->type);
+ domain = mono_object_domain (type);
+
+handle_parent:
+ for (i = 0; i < klass->event.count; i++) {
+ event = &klass->events [i];
+ if (strcmp (event->name, event_name))
+ continue;
+
+ method = event->add;
+ if (!method)
+ method = event->remove;
+
+ if ((method->flags & METHOD_ATTRIBUTE_MEMBER_ACCESS_MASK) == METHOD_ATTRIBUTE_PUBLIC) {
+ if (!(bflags & BFLAGS_Public))
+ continue;
+ } else {
+ if (!(bflags & BFLAGS_NonPublic))
+ continue;
+ }
+
+ g_free (event_name);
+ return mono_event_get_object (domain, klass, event);
+ }
+
+ if (!(bflags & BFLAGS_DeclaredOnly) && (klass = klass->parent))
+ goto handle_parent;
+
+ g_free (event_name);
+ return NULL;
+}
+
static MonoArray*
ves_icall_Type_GetEvents (MonoReflectionType *type, guint32 bflags)
{
MonoEvent *event;
int i, len, match;
+ MONO_ARCH_SAVE_REGS;
+
domain = ((MonoObject *)type)->vtable->domain;
klass = startklass = mono_class_from_mono_type (type->type);
int i, len, match;
MonoClass *nested;
+ MONO_ARCH_SAVE_REGS;
+
domain = ((MonoObject *)type)->vtable->domain;
klass = startklass = mono_class_from_mono_type (type->type);
}
static MonoReflectionType*
-ves_icall_System_Reflection_Assembly_GetType (MonoReflectionAssembly *assembly, MonoString *name, MonoBoolean throwOnError, MonoBoolean ignoreCase)
+ves_icall_System_Reflection_Assembly_InternalGetType (MonoReflectionAssembly *assembly, MonoString *name, MonoBoolean throwOnError, MonoBoolean ignoreCase)
{
- MonoDomain *domain = mono_domain_get ();
gchar *str;
MonoType *type;
MonoTypeNameParse info;
+ MONO_ARCH_SAVE_REGS;
+
str = mono_string_to_utf8 (name);
/*g_print ("requested type %s in %s\n", str, assembly->assembly->aname.name);*/
if (!mono_reflection_parse_type (str, &info)) {
return NULL;
}
/* g_print ("got it\n"); */
- return mono_type_get_object (domain, type);
+ return mono_type_get_object (mono_object_domain (assembly), type);
}
static MonoString *
ves_icall_System_Reflection_Assembly_get_code_base (MonoReflectionAssembly *assembly)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (assembly);
MonoString *res;
char *name = g_strconcat (
"file://", assembly->assembly->image->name, NULL);
+ MONO_ARCH_SAVE_REGS;
+
+ res = mono_string_new (domain, name);
+ g_free (name);
+ return res;
+}
+
+static MonoString *
+ves_icall_System_Reflection_Assembly_get_location (MonoReflectionAssembly *assembly)
+{
+ MonoDomain *domain = mono_object_domain (assembly);
+ MonoString *res;
+ char *name = g_build_filename (
+ assembly->assembly->basedir,
+ assembly->assembly->image->module_name, NULL);
+
+ MONO_ARCH_SAVE_REGS;
+
res = mono_string_new (domain, name);
g_free (name);
return res;
}
static MonoReflectionMethod*
-ves_icall_System_Reflection_Assembly_get_EntryPoint (MonoReflectionAssembly *assembly) {
+ves_icall_System_Reflection_Assembly_get_EntryPoint (MonoReflectionAssembly *assembly)
+{
guint32 token = mono_image_get_entry_point (assembly->assembly->image);
+
+ MONO_ARCH_SAVE_REGS;
+
if (!token)
return NULL;
return mono_method_get_object (mono_object_domain (assembly), mono_get_method (assembly->assembly->image, token, NULL), NULL);
}
static MonoArray*
-ves_icall_System_Reflection_Assembly_GetManifestResourceNames (MonoReflectionAssembly *assembly) {
+ves_icall_System_Reflection_Assembly_GetManifestResourceNames (MonoReflectionAssembly *assembly)
+{
MonoTableInfo *table = &assembly->assembly->image->tables [MONO_TABLE_MANIFESTRESOURCE];
MonoArray *result = mono_array_new (mono_object_domain (assembly), mono_defaults.string_class, table->rows);
int i;
const char *val;
+ MONO_ARCH_SAVE_REGS;
+
for (i = 0; i < table->rows; ++i) {
val = mono_metadata_string_heap (assembly->assembly->image, mono_metadata_decode_row_col (table, i, MONO_MANIFEST_NAME));
mono_array_set (result, gpointer, i, mono_string_new (mono_object_domain (assembly), val));
return result;
}
+static MonoArray*
+ves_icall_System_Reflection_Assembly_GetReferencedAssemblies (MonoReflectionAssembly *assembly)
+{
+ static MonoClass *System_Reflection_AssemblyName;
+ MonoArray *result;
+ MonoAssembly **ptr;
+ MonoDomain *domain = mono_object_domain (assembly);
+ int i, count = 0;
+
+ MONO_ARCH_SAVE_REGS;
+
+ if (!System_Reflection_AssemblyName)
+ System_Reflection_AssemblyName = mono_class_from_name (
+ mono_defaults.corlib, "System.Reflection", "AssemblyName");
+
+ for (ptr = assembly->assembly->image->references; ptr && *ptr; ptr++)
+ count++;
+
+ result = mono_array_new (mono_object_domain (assembly), System_Reflection_AssemblyName, count);
+
+ for (i = 0; i < count; i++) {
+ MonoAssembly *assem = assembly->assembly->image->references [i];
+ MonoReflectionAssemblyName *aname;
+ char *codebase;
+
+ aname = (MonoReflectionAssemblyName *) mono_object_new (
+ domain, System_Reflection_AssemblyName);
+
+ if (strcmp (assem->aname.name, "corlib") == 0)
+ aname->name = mono_string_new (domain, "mscorlib");
+ else
+ aname->name = mono_string_new (domain, assem->aname.name);
+ aname->major = assem->aname.major;
+
+ codebase = g_strconcat ("file://", assembly->assembly->image->references [i]->image->name, NULL);
+ aname->codebase = mono_string_new (domain, codebase);
+ g_free (codebase);
+ mono_array_set (result, gpointer, i, aname);
+ }
+ return result;
+}
+
/* move this in some file in mono/util/ */
static char *
g_concat_dir_and_file (const char *dir, const char *file)
}
static MonoObject*
-ves_icall_System_Reflection_Assembly_GetManifestResourceInternal (MonoReflectionAssembly *assembly, MonoString *name) {
+ves_icall_System_Reflection_Assembly_GetManifestResourceInternal (MonoReflectionAssembly *assembly, MonoString *name)
+{
char *n = mono_string_to_utf8 (name);
MonoTableInfo *table = &assembly->assembly->image->tables [MONO_TABLE_MANIFESTRESOURCE];
guint32 i;
const char *val;
MonoObject *result;
+ MONO_ARCH_SAVE_REGS;
+
for (i = 0; i < table->rows; ++i) {
mono_metadata_decode_row (table, i, cols, MONO_MANIFEST_SIZE);
val = mono_metadata_string_heap (assembly->assembly->image, cols [MONO_MANIFEST_NAME]);
}
static MonoObject*
-ves_icall_System_Reflection_Assembly_GetFilesInternal (MonoReflectionAssembly *assembly, MonoString *name) {
+ves_icall_System_Reflection_Assembly_GetFilesInternal (MonoReflectionAssembly *assembly, MonoString *name)
+{
MonoTableInfo *table = &assembly->assembly->image->tables [MONO_TABLE_FILE];
- MonoArray *result;
+ MonoArray *result = NULL;
int i;
const char *val;
char *n;
+ MONO_ARCH_SAVE_REGS;
+
/* check hash if needed */
if (name) {
n = mono_string_to_utf8 (name);
}
static MonoReflectionMethod*
-ves_icall_GetCurrentMethod (void) {
+ves_icall_GetCurrentMethod (void)
+{
MonoMethod *m = mono_method_get_last_managed ();
+
+ MONO_ARCH_SAVE_REGS;
+
return mono_method_get_object (mono_domain_get (), m, NULL);
}
ves_icall_System_Reflection_Assembly_GetExecutingAssembly (void)
{
MonoMethod *m = mono_method_get_last_managed ();
+
+ MONO_ARCH_SAVE_REGS;
+
return mono_assembly_get_object (mono_domain_get (), m->klass->image->assembly);
}
static gboolean
-get_caller (MonoMethod *m, gint32 no, gint32 ilo, gpointer data)
+get_caller (MonoMethod *m, gint32 no, gint32 ilo, gboolean managed, gpointer data)
{
MonoMethod **dest = data;
+
+ /* skip unmanaged frames */
+ if (!managed)
+ return FALSE;
+
if (m == *dest) {
*dest = NULL;
return FALSE;
ves_icall_System_Reflection_Assembly_GetEntryAssembly (void)
{
MonoDomain* domain = mono_domain_get ();
- g_assert (domain->entry_assembly);
+
+ MONO_ARCH_SAVE_REGS;
+
+ if (!domain->entry_assembly)
+ domain = mono_root_domain;
+
return mono_assembly_get_object (domain, domain->entry_assembly);
}
{
MonoMethod *m = mono_method_get_last_managed ();
MonoMethod *dest = m;
+
+ MONO_ARCH_SAVE_REGS;
+
mono_stack_walk (get_caller, &dest);
if (!dest)
dest = m;
static MonoString *
ves_icall_System_MonoType_getFullName (MonoReflectionType *object)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (object);
MonoString *res;
gchar *name;
+ MONO_ARCH_SAVE_REGS;
+
name = mono_type_get_name (object->type);
res = mono_string_new (domain, name);
g_free (name);
{
MonoAssemblyName *name = &assembly->assembly->aname;
+ MONO_ARCH_SAVE_REGS;
+
if (strcmp (name->name, "corlib") == 0)
aname->name = mono_string_new (mono_object_domain (assembly), "mscorlib");
else
aname->name = mono_string_new (mono_object_domain (assembly), name->name);
+
aname->major = name->major;
+ aname->minor = name->minor;
+ aname->build = name->build;
+ aname->revision = name->revision;
}
static MonoArray*
ves_icall_System_Reflection_Assembly_GetTypes (MonoReflectionAssembly *assembly, MonoBoolean exportedOnly)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (assembly);
MonoArray *res;
MonoClass *klass;
MonoTableInfo *tdef = &assembly->assembly->image->tables [MONO_TABLE_TYPEDEF];
int i, count;
guint32 attrs, visibility;
+ MONO_ARCH_SAVE_REGS;
+
/* we start the count from 1 because we skip the special type <Module> */
if (exportedOnly) {
count = 0;
char *str = mono_string_to_utf8 (smodifiers);
char *p;
+ MONO_ARCH_SAVE_REGS;
+
klass = mono_class_from_mono_type (tb->type.type);
p = str;
/* logic taken from mono_reflection_parse_type(): keep in sync */
isbyref = 1;
p++;
g_free (str);
- return mono_type_get_object (mono_domain_get (), &klass->this_arg);
+ return mono_type_get_object (mono_object_domain (tb), &klass->this_arg);
break;
case '*':
klass = mono_ptr_class_get (&klass->byval_arg);
}
}
g_free (str);
- return mono_type_get_object (mono_domain_get (), &klass->byval_arg);
+ return mono_type_get_object (mono_object_domain (tb), &klass->byval_arg);
}
static MonoObject *
MonoObject *delegate;
gpointer func;
+ MONO_ARCH_SAVE_REGS;
+
mono_assert (delegate_class->parent == mono_defaults.multicastdelegate_class);
- delegate = mono_object_new (target->vtable->domain, delegate_class);
+ delegate = mono_object_new (mono_object_domain (type), delegate_class);
func = mono_compile_method (info->method);
struct timeval tv;
gint64 res;
+ MONO_ARCH_SAVE_REGS;
+
if (gettimeofday (&tv, NULL) == 0) {
res = (((gint64)tv.tv_sec + EPOCH_ADJUST)* 1000000 + tv.tv_usec)*10;
return res;
long int gmtoff;
int is_daylight = 0, day;
+ char tzone[10];
+
+ MONO_ARCH_SAVE_REGS;
+
+ if ((year < 1900) || (year > 2100))
+ mono_raise_exception (mono_get_exception_not_implemented ());
memset (&start, 0, sizeof (start));
#endif
gmtoff = gmt_offset (start);
-
+
MONO_CHECK_ARG_NULL (data);
MONO_CHECK_ARG_NULL (names);
/* Daylight saving starts or ends here. */
if (gmt_offset (tt) != gmtoff) {
- char tzone[10];
struct tm tt1;
time_t t1;
gmtoff = gmt_offset (tt);
}
+
+ if (!is_daylight) {
+ strftime (tzone, 10, "%Z", &tt);
+ mono_array_set ((*names), gpointer, 0, mono_string_new (domain, tzone));
+ mono_array_set ((*names), gpointer, 1, mono_string_new (domain, tzone));
+ mono_array_set ((*data), gint64, 0, 0);
+ mono_array_set ((*data), gint64, 1, 0);
+ mono_array_set ((*data), gint64, 2, (gint64) gmtoff * 10000000L);
+ mono_array_set ((*data), gint64, 3, 0);
+ }
+
return 1;
#else
MonoDomain *domain = mono_domain_get ();
}
static gpointer
-ves_icall_System_Object_obj_address (MonoObject *this) {
+ves_icall_System_Object_obj_address (MonoObject *this)
+{
+ MONO_ARCH_SAVE_REGS;
+
return this;
}
/* System.Buffer */
static gint32
-ves_icall_System_Buffer_ByteLengthInternal (MonoArray *array) {
+ves_icall_System_Buffer_ByteLengthInternal (MonoArray *array)
+{
MonoClass *klass;
MonoTypeEnum etype;
int length, esize;
int i;
+ MONO_ARCH_SAVE_REGS;
+
klass = array->obj.vtable->klass;
etype = klass->element_class->byval_arg.type;
if (etype < MONO_TYPE_BOOLEAN || etype > MONO_TYPE_R8)
}
static gint8
-ves_icall_System_Buffer_GetByteInternal (MonoArray *array, gint32 idx) {
+ves_icall_System_Buffer_GetByteInternal (MonoArray *array, gint32 idx)
+{
+ MONO_ARCH_SAVE_REGS;
+
return mono_array_get (array, gint8, idx);
}
static void
-ves_icall_System_Buffer_SetByteInternal (MonoArray *array, gint32 idx, gint8 value) {
+ves_icall_System_Buffer_SetByteInternal (MonoArray *array, gint32 idx, gint8 value)
+{
+ MONO_ARCH_SAVE_REGS;
+
mono_array_set (array, gint8, idx, value);
}
static void
-ves_icall_System_Buffer_BlockCopyInternal (MonoArray *src, gint32 src_offset, MonoArray *dest, gint32 dest_offset, gint32 count) {
+ves_icall_System_Buffer_BlockCopyInternal (MonoArray *src, gint32 src_offset, MonoArray *dest, gint32 dest_offset, gint32 count)
+{
char *src_buf, *dest_buf;
+ MONO_ARCH_SAVE_REGS;
+
src_buf = (gint8 *)src->vector + src_offset;
dest_buf = (gint8 *)dest->vector + dest_offset;
static MonoObject *
ves_icall_Remoting_RealProxy_GetTransparentProxy (MonoObject *this)
{
- MonoDomain *domain = mono_domain_get ();
+ MonoDomain *domain = mono_object_domain (this);
MonoObject *res;
MonoRealProxy *rp = ((MonoRealProxy *)this);
MonoType *type;
MonoClass *klass;
+ MONO_ARCH_SAVE_REGS;
+
res = mono_object_new (domain, mono_defaults.transparent_proxy_class);
((MonoTransparentProxy *)res)->rp = rp;
buf = g_new (gunichar2, len);
result = NULL;
- if (GetComputerName (buf, &len))
+ if (GetComputerName (buf, (PDWORD) &len))
result = mono_string_new_utf16 (mono_domain_get (), buf, len);
g_free (buf);
int len;
MonoString *result;
+ MONO_ARCH_SAVE_REGS;
+
len = 256;
buf = g_new (gchar, len);
result = NULL;
- if (gethostname (buf, len) != 0)
+ if (gethostname (buf, len) == 0)
result = mono_string_new (mono_domain_get (), buf);
g_free (buf);
#endif
}
+static int
+ves_icall_System_Environment_get_Platform (void)
+{
+ MONO_ARCH_SAVE_REGS;
+
+#if defined (PLATFORM_WIN32)
+ /* Win32NT */
+ return 2;
+#else
+ /* Unix */
+ return 128;
+#endif
+}
+
static MonoString *
ves_icall_System_Environment_get_NewLine (void)
{
+ MONO_ARCH_SAVE_REGS;
+
#if defined (PLATFORM_WIN32)
return mono_string_new (mono_domain_get (), "\r\n");
#else
const gchar *value;
gchar *utf8_name;
+ MONO_ARCH_SAVE_REGS;
+
if (name == NULL)
return NULL;
gchar **e, **parts;
int n;
+ MONO_ARCH_SAVE_REGS;
+
n = 0;
for (e = environ; *e != 0; ++ e)
++ n;
struct timezone tz;
gint32 res;
+ MONO_ARCH_SAVE_REGS;
+
res = (gint32) gettimeofday (&tv, &tz);
if (res != -1)
static void
ves_icall_System_Environment_Exit (int result)
{
+ MONO_ARCH_SAVE_REGS;
+
/* we may need to do some cleanup here... */
exit (result);
}
+static MonoString*
+ves_icall_System_Text_Encoding_InternalCodePage (void)
+{
+ const char *cset;
+
+ MONO_ARCH_SAVE_REGS;
+
+ g_get_charset (&cset);
+ /* g_print ("charset: %s\n", cset); */
+ /* handle some common aliases */
+ switch (*cset) {
+ case 'A':
+ if (strcmp (cset, "ANSI_X3.4-1968") == 0)
+ cset = "us-ascii";
+ break;
+ }
+ return mono_string_new (mono_domain_get (), cset);
+}
+
static void
ves_icall_MonoMethodMessage_InitMessage (MonoMethodMessage *this,
MonoReflectionMethod *method,
MonoArray *out_args)
{
- MonoDomain *domain = mono_domain_get ();
-
- mono_message_init (domain, this, method, out_args);
+ MONO_ARCH_SAVE_REGS;
+
+ mono_message_init (mono_object_domain (this), this, method, out_args);
}
static MonoBoolean
ves_icall_IsTransparentProxy (MonoObject *proxy)
{
+ MONO_ARCH_SAVE_REGS;
+
if (!proxy)
return 0;
return 0;
}
+static void
+ves_icall_System_Runtime_Activation_ActivationServices_EnableProxyActivation (MonoReflectionType *type, MonoBoolean enable)
+{
+ MonoClass *klass;
+ MonoVTable* vtable;
+
+ MONO_ARCH_SAVE_REGS;
+
+ klass = mono_class_from_mono_type (type->type);
+ vtable = mono_class_vtable (mono_domain_get (), klass);
+
+ if (enable) vtable->remote = 1;
+ else vtable->remote = 0;
+}
+
+static MonoObject *
+ves_icall_System_Runtime_Activation_ActivationServices_AllocateUninitializedClassInstance (MonoReflectionType *type)
+{
+ MonoClass *klass;
+ MonoDomain *domain;
+
+ MONO_ARCH_SAVE_REGS;
+
+ domain = mono_object_domain (type);
+ klass = mono_class_from_mono_type (type->type);
+
+ // Bypass remoting object creation check
+ return mono_object_new_alloc_specific (mono_class_vtable (domain, klass));
+}
+
static MonoObject *
ves_icall_System_Runtime_Serialization_FormatterServices_GetUninitializedObject_Internal (MonoReflectionType *type)
{
MonoObject *obj;
MonoDomain *domain;
+ MONO_ARCH_SAVE_REGS;
+
domain = mono_object_domain (type);
klass = mono_class_from_mono_type (type->type);
return obj;
}
+static MonoString *
+ves_icall_System_IO_get_temp_path (void)
+{
+ MONO_ARCH_SAVE_REGS;
+
+ return mono_string_new (mono_domain_get (), g_get_tmp_dir ());
+}
+
+static gpointer
+ves_icall_RuntimeMethod_GetFunctionPointer (MonoMethod *method)
+{
+ MONO_ARCH_SAVE_REGS;
+
+ return mono_compile_method (method);
+}
+
+char const * mono_cfg_dir = "";
+
+void
+mono_install_get_config_dir (void)
+{
+#ifdef PLATFORM_WIN32
+ int i;
+#endif
+
+ mono_cfg_dir = getenv ("MONO_CFG_DIR");
+
+ if (!mono_cfg_dir) {
+#ifndef PLATFORM_WIN32
+ mono_cfg_dir = MONO_CFG_DIR;
+#else
+ mono_cfg_dir = g_strdup (MONO_CFG_DIR);
+ for (i = strlen (mono_cfg_dir) - 1; i >= 0; i--) {
+ if (mono_cfg_dir [i] == '/')
+ mono_cfg_dir [i] = '\\';
+ }
+#endif
+ }
+}
+
+
+static MonoString *
+ves_icall_System_Configuration_DefaultConfig_get_machine_config_path (void)
+{
+ static MonoString *mcpath;
+ gchar *path;
+
+ MONO_ARCH_SAVE_REGS;
+
+ if (mcpath != NULL)
+ return mcpath;
+
+ path = g_build_path (G_DIR_SEPARATOR_S, mono_cfg_dir, "mono", "machine.config", NULL);
+
+#if defined (PLATFORM_WIN32)
+ /* Avoid mixing '/' and '\\' */
+ {
+ gint i;
+ for (i = strlen (path) - 1; i >= 0; i--)
+ if (path [i] == '/')
+ path [i] = '\\';
+ }
+#endif
+ mcpath = mono_string_new (mono_domain_get (), path);
+ g_free (path);
+
+ return mcpath;
+}
+
+static void
+ves_icall_System_Diagnostics_DefaultTraceListener_WriteWindowsDebugString (MonoString *message)
+{
+#if defined (PLATFORM_WIN32)
+ static void (*output_debug) (gchar *);
+ static gboolean tried_loading = FALSE;
+ gchar *str;
+
+ MONO_ARCH_SAVE_REGS;
+
+ if (!tried_loading && output_debug == NULL) {
+ GModule *k32;
+
+ tried_loading = TRUE;
+ k32 = g_module_open ("kernel32", G_MODULE_BIND_LAZY);
+ if (!k32) {
+ gchar *error = g_strdup (g_module_error ());
+ g_warning ("Failed to load kernel32.dll: %s\n", error);
+ g_free (error);
+ return;
+ }
+
+ g_module_symbol (k32, "OutputDebugStringW", (gpointer *) &output_debug);
+ if (!output_debug) {
+ gchar *error = g_strdup (g_module_error ());
+ g_warning ("Failed to load OutputDebugStringW: %s\n", error);
+ g_free (error);
+ return;
+ }
+ }
+
+ if (output_debug == NULL)
+ return;
+
+ str = mono_string_to_utf8 (message);
+ output_debug (str);
+ g_free (str);
+#else
+ g_warning ("WriteWindowsDebugString called and PLATFORM_WIN32 not defined!\n");
+#endif
+}
+
+/* Only used for value types */
+static MonoObject *
+ves_icall_System_Activator_CreateInstanceInternal (MonoReflectionType *type)
+{
+ MonoClass *klass;
+ MonoDomain *domain;
+
+ MONO_ARCH_SAVE_REGS;
+
+ domain = mono_object_domain (type);
+ klass = mono_class_from_mono_type (type->type);
+
+ return mono_object_new (domain, klass);
+}
+
+static MonoReflectionMethod *
+ves_icall_MonoMethod_get_base_definition (MonoReflectionMethod *m)
+{
+ MonoClass *klass;
+ MonoMethod *method = m->method;
+ MonoMethod *result = NULL;
+
+ MONO_ARCH_SAVE_REGS;
+
+ if (!(method->flags & METHOD_ATTRIBUTE_VIRTUAL) ||
+ method->klass->flags & TYPE_ATTRIBUTE_INTERFACE ||
+ method->flags & METHOD_ATTRIBUTE_NEW_SLOT)
+ return m;
+
+ if (method->klass == NULL || (klass = method->klass->parent) == NULL)
+ return m;
+
+ if (klass->vtable_size > method->slot)
+ result = klass->vtable [method->slot];
+
+ if (result == NULL)
+ return m;
+
+ return mono_method_get_object (mono_domain_get (), result, NULL);
+}
+
/* icall map */
static gconstpointer icall_map [] = {
"System.String::InternalStrcpy(string,int,string,int,int)", ves_icall_System_String_InternalStrcpy_StrN,
"System.String::InternalIntern", ves_icall_System_String_InternalIntern,
"System.String::InternalIsInterned", ves_icall_System_String_InternalIsInterned,
- "System.String::InternalCompare(string,int,string,int,int,bool)", ves_icall_System_String_InternalCompareStr_N,
+ "System.String::InternalCompare(string,int,string,int,int,int)", ves_icall_System_String_InternalCompareStr_N,
"System.String::GetHashCode", ves_icall_System_String_GetHashCode,
"System.String::get_Chars", ves_icall_System_String_get_Chars,
"System.AppDomain::getFriendlyName", ves_icall_System_AppDomain_getFriendlyName,
"System.AppDomain::GetAssemblies", ves_icall_System_AppDomain_GetAssemblies,
"System.AppDomain::LoadAssembly", ves_icall_System_AppDomain_LoadAssembly,
- "System.AppDomain::Unload", ves_icall_System_AppDomain_Unload,
+ "System.AppDomain::InternalUnload", ves_icall_System_AppDomain_InternalUnload,
"System.AppDomain::ExecuteAssembly", ves_icall_System_AppDomain_ExecuteAssembly,
+ "System.AppDomain::InternalSetDomain", ves_icall_System_AppDomain_InternalSetDomain,
+ "System.AppDomain::InternalSetDomainByID", ves_icall_System_AppDomain_InternalSetDomainByID,
+ "System.AppDomain::InternalSetContext", ves_icall_System_AppDomain_InternalSetContext,
+ "System.AppDomain::InternalGetContext", ves_icall_System_AppDomain_InternalGetContext,
+ "System.AppDomain::InternalGetDefaultContext", ves_icall_System_AppDomain_InternalGetDefaultContext,
/*
* System.AppDomainSetup
* ModuleBuilder
*/
"System.Reflection.Emit.ModuleBuilder::create_modified_type", ves_icall_ModuleBuilder_create_modified_type,
+ "System.Reflection.Emit.ModuleBuilder::basic_init", mono_image_module_basic_init,
/*
* AssemblyBuilder
"System.Reflection.Emit.AssemblyBuilder::getUSIndex", mono_image_insert_string,
"System.Reflection.Emit.AssemblyBuilder::getToken", ves_icall_AssemblyBuilder_getToken,
"System.Reflection.Emit.AssemblyBuilder::basic_init", mono_image_basic_init,
+ "System.Reflection.Emit.AssemblyBuilder::build_metadata", ves_icall_AssemblyBuilder_build_metadata,
/*
* Reflection stuff.
"System.Reflection.MethodBase::GetCurrentMethod", ves_icall_GetCurrentMethod,
"System.MonoCustomAttrs::GetCustomAttributes", mono_reflection_get_custom_attrs,
"System.Reflection.Emit.CustomAttributeBuilder::GetBlob", mono_reflection_get_custom_attrs_blob,
- "System.Reflection.MonoField::GetValue", ves_icall_MonoField_GetValue,
- "System.Reflection.FieldInfo::SetValueInternal", ves_icall_FieldInfo_SetValueInternal,
+ "System.Reflection.MonoField::GetValueInternal", ves_icall_MonoField_GetValueInternal,
+ "System.Reflection.MonoField::SetValueInternal", ves_icall_FieldInfo_SetValueInternal,
"System.Reflection.Emit.SignatureHelper::get_signature_local", mono_reflection_sighelper_get_signature_local,
"System.Reflection.Emit.SignatureHelper::get_signature_field", mono_reflection_sighelper_get_signature_field,
+ "System.RuntimeMethodHandle::GetFunctionPointer", ves_icall_RuntimeMethod_GetFunctionPointer,
+ "System.Reflection.MonoMethod::get_base_definition", ves_icall_MonoMethod_get_base_definition,
/* System.Enum */
*/
"System.Type::internal_from_name", ves_icall_type_from_name,
"System.Type::internal_from_handle", ves_icall_type_from_handle,
- "System.Type::get_constructor", ves_icall_get_constructor,
- "System.Type::get_property", ves_icall_get_property,
- "System.MonoType::get_method", ves_icall_get_method,
"System.MonoType::get_attributes", ves_icall_get_attributes,
"System.Type::type_is_subtype_of", ves_icall_type_is_subtype_of,
"System.Type::Equals", ves_icall_type_Equals,
"System.Type::GetTypeCode", ves_icall_type_GetTypeCode,
+ "System.Type::GetInterfaceMapData", ves_icall_Type_GetInterfaceMapData,
/*
* System.Runtime.CompilerServices.RuntimeHelpers
*/
- "System.Runtime.CompilerServices.RuntimeHelpers::InitializeArray", ves_icall_InitializeArray,
+ "System.Runtime.CompilerServices.RuntimeHelpers::InitializeArray", ves_icall_System_Runtime_CompilerServices_RuntimeHelpers_InitializeArray,
+ "System.Runtime.CompilerServices.RuntimeHelpers::GetOffsetToStringData", ves_icall_System_Runtime_CompilerServices_RuntimeHelpers_GetOffsetToStringData,
+ "System.Runtime.CompilerServices.RuntimeHelpers::GetObjectValue", ves_icall_System_Runtime_CompilerServices_RuntimeHelpers_GetObjectValue,
+ "System.Runtime.CompilerServices.RuntimeHelpers::RunClassConstructor", ves_icall_System_Runtime_CompilerServices_RuntimeHelpers_RunClassConstructor,
/*
* System.Threading
"System.Threading.Thread::Start_internal", ves_icall_System_Threading_Thread_Start_internal,
"System.Threading.Thread::Sleep_internal", ves_icall_System_Threading_Thread_Sleep_internal,
"System.Threading.Thread::CurrentThread_internal", mono_thread_current,
- "System.Threading.Thread::CurrentThreadDomain_internal", ves_icall_System_Threading_Thread_CurrentThreadDomain_internal,
"System.Threading.Thread::Join_internal", ves_icall_System_Threading_Thread_Join_internal,
"System.Threading.Thread::SlotHash_lookup", ves_icall_System_Threading_Thread_SlotHash_lookup,
"System.Threading.Thread::SlotHash_store", ves_icall_System_Threading_Thread_SlotHash_store,
+ "System.Threading.Thread::GetDomainID", ves_icall_System_Threading_Thread_GetDomainID,
"System.Threading.Monitor::Monitor_exit", ves_icall_System_Threading_Monitor_Monitor_exit,
"System.Threading.Monitor::Monitor_test_owner", ves_icall_System_Threading_Monitor_Monitor_test_owner,
"System.Threading.Monitor::Monitor_test_synchronised", ves_icall_System_Threading_Monitor_Monitor_test_synchronised,
"System.Reflection.Assembly::LoadFrom", ves_icall_System_Reflection_Assembly_LoadFrom,
- "System.Reflection.Assembly::GetType", ves_icall_System_Reflection_Assembly_GetType,
+ "System.Reflection.Assembly::InternalGetType", ves_icall_System_Reflection_Assembly_InternalGetType,
"System.Reflection.Assembly::GetTypes", ves_icall_System_Reflection_Assembly_GetTypes,
"System.Reflection.Assembly::FillName", ves_icall_System_Reflection_Assembly_FillName,
"System.Reflection.Assembly::get_code_base", ves_icall_System_Reflection_Assembly_get_code_base,
+ "System.Reflection.Assembly::get_location", ves_icall_System_Reflection_Assembly_get_location,
"System.Reflection.Assembly::GetExecutingAssembly", ves_icall_System_Reflection_Assembly_GetExecutingAssembly,
"System.Reflection.Assembly::GetEntryAssembly", ves_icall_System_Reflection_Assembly_GetEntryAssembly,
"System.Reflection.Assembly::GetCallingAssembly", ves_icall_System_Reflection_Assembly_GetCallingAssembly,
"System.Reflection.Assembly::GetManifestResourceNames", ves_icall_System_Reflection_Assembly_GetManifestResourceNames,
"System.Reflection.Assembly::GetManifestResourceInternal", ves_icall_System_Reflection_Assembly_GetManifestResourceInternal,
"System.Reflection.Assembly::GetFilesInternal", ves_icall_System_Reflection_Assembly_GetFilesInternal,
+ "System.Reflection.Assembly::GetReferencedAssemblies", ves_icall_System_Reflection_Assembly_GetReferencedAssemblies,
/*
* System.MonoType.
"System.MonoType::type_from_obj", mono_type_type_from_obj,
"System.MonoType::GetElementType", ves_icall_MonoType_GetElementType,
"System.MonoType::get_type_info", ves_icall_get_type_info,
+ "System.MonoType::get_BaseType", ves_icall_get_type_parent,
+ "System.MonoType::get_Module", ves_icall_MonoType_get_Module,
+ "System.MonoType::IsPointerImpl", ves_icall_type_ispointer,
+ "System.MonoType::IsByRefImpl", ves_icall_type_isbyref,
"System.MonoType::GetField", ves_icall_Type_GetField,
"System.MonoType::GetFields", ves_icall_Type_GetFields,
"System.MonoType::GetMethods", ves_icall_Type_GetMethods,
"System.MonoType::GetConstructors", ves_icall_Type_GetConstructors,
"System.MonoType::GetProperties", ves_icall_Type_GetProperties,
"System.MonoType::GetEvents", ves_icall_Type_GetEvents,
+ "System.MonoType::InternalGetEvent", ves_icall_MonoType_GetEvent,
"System.MonoType::GetInterfaces", ves_icall_Type_GetInterfaces,
"System.MonoType::GetNestedTypes", ves_icall_Type_GetNestedTypes,
"System.Net.Sockets.Socket::GetSocketOption_obj_internal", ves_icall_System_Net_Sockets_Socket_GetSocketOption_obj_internal,
"System.Net.Sockets.Socket::GetSocketOption_arr_internal", ves_icall_System_Net_Sockets_Socket_GetSocketOption_arr_internal,
"System.Net.Sockets.Socket::SetSocketOption_internal", ves_icall_System_Net_Sockets_Socket_SetSocketOption_internal,
- "System.Net.Dns::GetHostByName_internal", ves_icall_System_Net_Dns_GetHostByName_internal,
- "System.Net.Dns::GetHostByAddr_internal", ves_icall_System_Net_Dns_GetHostByAddr_internal,
+ "System.Net.Dns::GetHostByName_internal(string,string&,string[]&,string[]&)", ves_icall_System_Net_Dns_GetHostByName_internal,
+ "System.Net.Dns::GetHostByAddr_internal(string,string&,string[]&,string[]&)", ves_icall_System_Net_Dns_GetHostByAddr_internal,
+ "System.Net.Dns::GetHostName_internal(string&)", ves_icall_System_Net_Dns_GetHostName_internal,
/*
* System.Char
"System.Char::ToLower", ves_icall_System_Char_ToLower,
"System.Char::ToUpper", ves_icall_System_Char_ToUpper,
- "System.Text.Encoding::IConvNewEncoder", ves_icall_iconv_new_encoder,
- "System.Text.Encoding::IConvNewDecoder", ves_icall_iconv_new_decoder,
- "System.Text.Encoding::IConvReset", ves_icall_iconv_reset,
- "System.Text.Encoding::IConvGetByteCount", ves_icall_iconv_get_byte_count,
- "System.Text.Encoding::IConvGetBytes", ves_icall_iconv_get_bytes,
- "System.Text.Encoding::IConvGetCharCount", ves_icall_iconv_get_char_count,
- "System.Text.Encoding::IConvGetChars", ves_icall_iconv_get_chars,
+ /*
+ * System.Text.Encoding
+ */
+ "System.Text.Encoding::InternalCodePage", ves_icall_System_Text_Encoding_InternalCodePage,
"System.DateTime::GetNow", ves_icall_System_DateTime_GetNow,
"System.CurrentTimeZone::GetTimeZoneData", ves_icall_System_CurrentTimeZone_GetTimeZoneData,
* System.Security.Cryptography calls
*/
- "System.Security.Cryptography.RNGCryptoServiceProvider::GetBytes", ves_icall_System_Security_Cryptography_RNGCryptoServiceProvider_GetBytes,
- "System.Security.Cryptography.RNGCryptoServiceProvider::GetNonZeroBytes", ves_icall_System_Security_Cryptography_RNGCryptoServiceProvider_GetNonZeroBytes,
+ "System.Security.Cryptography.RNGCryptoServiceProvider::InternalGetBytes", ves_icall_System_Security_Cryptography_RNGCryptoServiceProvider_InternalGetBytes,
+ "System.Security.Cryptography.RNGCryptoServiceProvider::InternalGetNonZeroBytes", ves_icall_System_Security_Cryptography_RNGCryptoServiceProvider_InternalGetNonZeroBytes,
/*
* System.Buffer
/*
* System.IO.MonoIO
*/
- "System.IO.MonoIO::GetLastError", ves_icall_System_IO_MonoIO_GetLastError,
- "System.IO.MonoIO::CreateDirectory", ves_icall_System_IO_MonoIO_CreateDirectory,
- "System.IO.MonoIO::RemoveDirectory", ves_icall_System_IO_MonoIO_RemoveDirectory,
- "System.IO.MonoIO::FindFirstFile", ves_icall_System_IO_MonoIO_FindFirstFile,
- "System.IO.MonoIO::FindNextFile", ves_icall_System_IO_MonoIO_FindNextFile,
- "System.IO.MonoIO::FindClose", ves_icall_System_IO_MonoIO_FindClose,
- "System.IO.MonoIO::GetCurrentDirectory", ves_icall_System_IO_MonoIO_GetCurrentDirectory,
- "System.IO.MonoIO::SetCurrentDirectory", ves_icall_System_IO_MonoIO_SetCurrentDirectory,
- "System.IO.MonoIO::MoveFile", ves_icall_System_IO_MonoIO_MoveFile,
- "System.IO.MonoIO::CopyFile", ves_icall_System_IO_MonoIO_CopyFile,
- "System.IO.MonoIO::DeleteFile", ves_icall_System_IO_MonoIO_DeleteFile,
- "System.IO.MonoIO::GetFileAttributes", ves_icall_System_IO_MonoIO_GetFileAttributes,
- "System.IO.MonoIO::SetFileAttributes", ves_icall_System_IO_MonoIO_SetFileAttributes,
- "System.IO.MonoIO::GetFileStat", ves_icall_System_IO_MonoIO_GetFileStat,
- "System.IO.MonoIO::Open", ves_icall_System_IO_MonoIO_Open,
- "System.IO.MonoIO::Close", ves_icall_System_IO_MonoIO_Close,
- "System.IO.MonoIO::Read", ves_icall_System_IO_MonoIO_Read,
- "System.IO.MonoIO::Write", ves_icall_System_IO_MonoIO_Write,
- "System.IO.MonoIO::Seek", ves_icall_System_IO_MonoIO_Seek,
- "System.IO.MonoIO::GetLength", ves_icall_System_IO_MonoIO_GetLength,
- "System.IO.MonoIO::SetLength", ves_icall_System_IO_MonoIO_SetLength,
- "System.IO.MonoIO::SetFileTime", ves_icall_System_IO_MonoIO_SetFileTime,
- "System.IO.MonoIO::Flush", ves_icall_System_IO_MonoIO_Flush,
+ "System.IO.MonoIO::CreateDirectory(string,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_CreateDirectory,
+ "System.IO.MonoIO::RemoveDirectory(string,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_RemoveDirectory,
+ "System.IO.MonoIO::FindFirstFile(string,System.IO.MonoIOStat&,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_FindFirstFile,
+ "System.IO.MonoIO::FindNextFile(intptr,System.IO.MonoIOStat&,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_FindNextFile,
+ "System.IO.MonoIO::FindClose(intptr,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_FindClose,
+ "System.IO.MonoIO::GetCurrentDirectory(System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_GetCurrentDirectory,
+ "System.IO.MonoIO::SetCurrentDirectory(string,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_SetCurrentDirectory,
+ "System.IO.MonoIO::MoveFile(string,string,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_MoveFile,
+ "System.IO.MonoIO::CopyFile(string,string,bool,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_CopyFile,
+ "System.IO.MonoIO::DeleteFile(string,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_DeleteFile,
+ "System.IO.MonoIO::GetFileAttributes(string,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_GetFileAttributes,
+ "System.IO.MonoIO::SetFileAttributes(string,System.IO.FileAttributes,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_SetFileAttributes,
+ "System.IO.MonoIO::GetFileType(intptr,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_GetFileType,
+ "System.IO.MonoIO::GetFileStat(string,System.IO.MonoIOStat&,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_GetFileStat,
+ "System.IO.MonoIO::Open(string,System.IO.FileMode,System.IO.FileAccess,System.IO.FileShare,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_Open,
+ "System.IO.MonoIO::Close(intptr,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_Close,
+ "System.IO.MonoIO::Read(intptr,byte[],int,int,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_Read,
+ "System.IO.MonoIO::Write(intptr,byte[],int,int,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_Write,
+ "System.IO.MonoIO::Seek(intptr,long,System.IO.SeekOrigin,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_Seek,
+ "System.IO.MonoIO::GetLength(intptr,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_GetLength,
+ "System.IO.MonoIO::SetLength(intptr,long,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_SetLength,
+ "System.IO.MonoIO::SetFileTime(intptr,long,long,long,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_SetFileTime,
+ "System.IO.MonoIO::Flush(intptr,System.IO.MonoIOError&)", ves_icall_System_IO_MonoIO_Flush,
"System.IO.MonoIO::get_ConsoleOutput", ves_icall_System_IO_MonoIO_get_ConsoleOutput,
"System.IO.MonoIO::get_ConsoleInput", ves_icall_System_IO_MonoIO_get_ConsoleInput,
"System.IO.MonoIO::get_ConsoleError", ves_icall_System_IO_MonoIO_get_ConsoleError,
/*
* System.Math
*/
+ "System.Math::Floor", ves_icall_System_Math_Floor,
+ "System.Math::Round", ves_icall_System_Math_Round,
+ "System.Math::Round2", ves_icall_System_Math_Round2,
"System.Math::Sin", ves_icall_System_Math_Sin,
- "System.Math::Cos", ves_icall_System_Math_Cos,
- "System.Math::Tan", ves_icall_System_Math_Tan,
- "System.Math::Sinh", ves_icall_System_Math_Sinh,
- "System.Math::Cosh", ves_icall_System_Math_Cosh,
- "System.Math::Tanh", ves_icall_System_Math_Tanh,
- "System.Math::Acos", ves_icall_System_Math_Acos,
- "System.Math::Asin", ves_icall_System_Math_Asin,
- "System.Math::Atan", ves_icall_System_Math_Atan,
- "System.Math::Atan2", ves_icall_System_Math_Atan2,
- "System.Math::Exp", ves_icall_System_Math_Exp,
- "System.Math::Log", ves_icall_System_Math_Log,
- "System.Math::Log10", ves_icall_System_Math_Log10,
- "System.Math::PowImpl", ves_icall_System_Math_Pow,
- "System.Math::Sqrt", ves_icall_System_Math_Sqrt,
+ "System.Math::Cos", ves_icall_System_Math_Cos,
+ "System.Math::Tan", ves_icall_System_Math_Tan,
+ "System.Math::Sinh", ves_icall_System_Math_Sinh,
+ "System.Math::Cosh", ves_icall_System_Math_Cosh,
+ "System.Math::Tanh", ves_icall_System_Math_Tanh,
+ "System.Math::Acos", ves_icall_System_Math_Acos,
+ "System.Math::Asin", ves_icall_System_Math_Asin,
+ "System.Math::Atan", ves_icall_System_Math_Atan,
+ "System.Math::Atan2", ves_icall_System_Math_Atan2,
+ "System.Math::Exp", ves_icall_System_Math_Exp,
+ "System.Math::Log", ves_icall_System_Math_Log,
+ "System.Math::Log10", ves_icall_System_Math_Log10,
+ "System.Math::Pow", ves_icall_System_Math_Pow,
+ "System.Math::Sqrt", ves_icall_System_Math_Sqrt,
/*
* System.Environment
"System.Environment::GetCommandLineArgs", mono_runtime_get_main_args,
"System.Environment::get_TickCount", ves_icall_System_Environment_get_TickCount,
"System.Environment::Exit", ves_icall_System_Environment_Exit,
+ "System.Environment::get_Platform", ves_icall_System_Environment_get_Platform,
+ "System.Environment::get_ExitCode", mono_environment_exitcode_get,
+ "System.Environment::set_ExitCode", mono_environment_exitcode_set,
/*
* System.Runtime.Remoting
"System.Runtime.Remoting.RemotingServices::IsTransparentProxy",
ves_icall_IsTransparentProxy,
+ /*
+ * System.Runtime.Remoting.Activation
+ */
+ "System.Runtime.Remoting.Activation.ActivationServices::AllocateUninitializedClassInstance",
+ ves_icall_System_Runtime_Activation_ActivationServices_AllocateUninitializedClassInstance,
+ "System.Runtime.Remoting.Activation.ActivationServices::EnableProxyActivation",
+ ves_icall_System_Runtime_Activation_ActivationServices_EnableProxyActivation,
+
/*
* System.Runtime.Remoting.Messaging
*/
/*
* System.Runtime.Remoting.Proxies
*/
- "System.Runtime.Remoting.Proxies.RealProxy::GetTransparentProxy",
+ "System.Runtime.Remoting.Proxies.RealProxy::InternalGetTransparentProxy",
ves_icall_Remoting_RealProxy_GetTransparentProxy,
/*
/*
* System.Diagnostics.Process
*/
- "System.Diagnostics.Process::GetCurrentProcess_internal()", ves_icall_System_Diagnostics_Process_GetCurrentProcess_internal,
+ "System.Diagnostics.Process::GetProcess_internal(int)", ves_icall_System_Diagnostics_Process_GetProcess_internal,
+ "System.Diagnostics.Process::GetProcesses_internal()", ves_icall_System_Diagnostics_Process_GetProcesses_internal,
"System.Diagnostics.Process::GetPid_internal()", ves_icall_System_Diagnostics_Process_GetPid_internal,
"System.Diagnostics.Process::Process_free_internal(intptr)", ves_icall_System_Diagnostics_Process_Process_free_internal,
"System.Diagnostics.Process::GetModules_internal()", ves_icall_System_Diagnostics_Process_GetModules_internal,
"System.Diagnostics.Process::ExitTime_internal(intptr)", ves_icall_System_Diagnostics_Process_ExitTime_internal,
"System.Diagnostics.Process::StartTime_internal(intptr)", ves_icall_System_Diagnostics_Process_StartTime_internal,
"System.Diagnostics.Process::ExitCode_internal(intptr)", ves_icall_System_Diagnostics_Process_ExitCode_internal,
+ "System.Diagnostics.Process::ProcessName_internal(intptr)", ves_icall_System_Diagnostics_Process_ProcessName_internal,
+ "System.Diagnostics.Process::GetWorkingSet_internal(intptr,int&,int&)", ves_icall_System_Diagnostics_Process_GetWorkingSet_internal,
+ "System.Diagnostics.Process::SetWorkingSet_internal(intptr,int,int,bool)", ves_icall_System_Diagnostics_Process_SetWorkingSet_internal,
"System.Diagnostics.FileVersionInfo::GetVersionInfo_internal(string)", ves_icall_System_Diagnostics_FileVersionInfo_GetVersionInfo_internal,
/*
*/
"System.Runtime.Serialization.FormatterServices::GetUninitializedObjectInternal",
ves_icall_System_Runtime_Serialization_FormatterServices_GetUninitializedObject_Internal,
+
+ /*
+ * System.IO.Path
+ */
+ "System.IO.Path::get_temp_path", ves_icall_System_IO_get_temp_path,
+
+ /*
+ * Private icalls for the Mono Debugger
+ */
+ "System.Reflection.Assembly::MonoDebugger_GetMethod",
+ ves_icall_MonoDebugger_GetMethod,
+
+ "System.Reflection.Assembly::MonoDebugger_GetMethodToken",
+ ves_icall_MonoDebugger_GetMethodToken,
+
+ "System.Reflection.Assembly::MonoDebugger_GetLocalTypeFromSignature",
+ ves_icall_MonoDebugger_GetLocalTypeFromSignature,
+
+ "System.Reflection.Assembly::MonoDebugger_GetType",
+ ves_icall_MonoDebugger_GetType,
+
+ /*
+ * System.Configuration
+ */
+ "System.Configuration.DefaultConfig::get_machine_config_path",
+ ves_icall_System_Configuration_DefaultConfig_get_machine_config_path,
+
+ /*
+ * System.Diagnostics.DefaultTraceListener
+ */
+ "System.Diagnostics.DefaultTraceListener::WriteWindowsDebugString",
+ ves_icall_System_Diagnostics_DefaultTraceListener_WriteWindowsDebugString,
+ /*
+ * System.Activator
+ */
+ "System.Activator::CreateInstanceInternal",
+ ves_icall_System_Activator_CreateInstanceInternal,
+
/*
* add other internal calls here
*/