+2007-08-07 Atsushi Enomoto <atsushi@ximian.com>
+
+ * icall-def.h, security.c, security.h :
+ added icall wrapper to ProtectedMemory.[Unprotect|Protect]Data().
+
2007-08-07 Martin Baulig <martin@ximian.com>
* mono-debug-debugger.h
ICALL(WINPRIN_1, "IsMemberOfGroupId", ves_icall_System_Security_Principal_WindowsPrincipal_IsMemberOfGroupId)
ICALL(WINPRIN_2, "IsMemberOfGroupName", ves_icall_System_Security_Principal_WindowsPrincipal_IsMemberOfGroupName)
+ICALL_TYPE(SECSTRING, "System.Security.SecureString", SECSTRING_1)
+ICALL(SECSTRING_1, "DecryptInternal", ves_icall_System_Security_SecureString_DecryptInternal)
+ICALL(SECSTRING_2, "EncryptInternal", ves_icall_System_Security_SecureString_EncryptInternal)
+
ICALL_TYPE(SECMAN, "System.Security.SecurityManager", SECMAN_1)
ICALL(SECMAN_1, "GetLinkDemandSecurity", ves_icall_System_Security_SecurityManager_GetLinkDemandSecurity)
ICALL(SECMAN_2, "get_CheckExecutionRights", ves_icall_System_Security_SecurityManager_get_CheckExecutionRights)
}
return FALSE;
}
+
+
+/* System.Security.SecureString related internal calls */
+
+static MonoImage *system_security_assembly = NULL;
+
+void
+ves_icall_System_Security_SecureString_DecryptInternal (MonoArray *data, MonoObject *scope)
+{
+ invoke_protected_memory_method (data, scope, FALSE);
+}
+void
+ves_icall_System_Security_SecureString_EncryptInternal (MonoArray* data, MonoObject *scope)
+{
+ invoke_protected_memory_method (data, scope, TRUE);
+}
+
+void invoke_protected_memory_method (MonoArray *data, MonoObject *scope, gboolean encrypt)
+{
+ MonoClass *klass;
+ MonoMethod *method;
+ void *params [2];
+
+ MONO_ARCH_SAVE_REGS;
+
+ if (system_security_assembly == NULL) {
+ system_security_assembly = mono_image_loaded ("System.Security");
+ if (!system_security_assembly) {
+ MonoAssembly *sa = mono_assembly_open ("System.Security.dll", NULL);
+ if (!sa)
+ g_assert_not_reached ();
+ system_security_assembly = mono_assembly_get_image (sa);
+ }
+ }
+
+ klass = mono_class_from_name (system_security_assembly,
+ "System.Security.Cryptography", "ProtectedMemory");
+ method = mono_class_get_method_from_name (klass, encrypt ? "Protect" : "Unprotect", 2);
+ params [0] = data;
+ params [1] = scope; /* MemoryProtectionScope.SameProcess */
+ mono_runtime_invoke (method, NULL, params, NULL);
+}
/* System.Security.Policy.Evidence */
MonoBoolean ves_icall_System_Security_Policy_Evidence_IsAuthenticodePresent (MonoReflectionAssembly *refass) MONO_INTERNAL;
+/* System.Security.SecureString */
+extern void ves_icall_System_Security_SecureString_DecryptInternal (MonoArray *data, MonoObject *scope) MONO_INTERNAL;
+extern void ves_icall_System_Security_SecureString_EncryptInternal (MonoArray *data, MonoObject *scope) MONO_INTERNAL;
+void invoke_protected_memory_method (MonoArray *data, MonoObject *scope, gboolean encrypt);
+
G_END_DECLS
#endif /* _MONO_METADATA_SECURITY_H_ */