X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Futils%2Fmono-codeman.h;h=1507348b0b5c957ce149510a28465cf2b9b0d9a5;hb=7eefa895e97ebdb9f926c6926165cf168b550d84;hp=b6ef439be248b5117c5ef773ee4cac79532e03fe;hpb=b6b13e72e91d5b529a6306ce53bda685932c77db;p=mono.git diff --git a/mono/utils/mono-codeman.h b/mono/utils/mono-codeman.h index b6ef439be24..1507348b0b5 100644 --- a/mono/utils/mono-codeman.h +++ b/mono/utils/mono-codeman.h @@ -7,13 +7,33 @@ MonoCodeManager* mono_code_manager_new (void); MonoCodeManager* mono_code_manager_new_dynamic (void); void mono_code_manager_destroy (MonoCodeManager *cman); void mono_code_manager_invalidate (MonoCodeManager *cman); +void mono_code_manager_set_read_only (MonoCodeManager *cman); + +void* mono_code_manager_reserve_align (MonoCodeManager *cman, int size, int alignment); void* mono_code_manager_reserve (MonoCodeManager *cman, int size); void mono_code_manager_commit (MonoCodeManager *cman, void *data, int size, int newsize); +int mono_code_manager_size (MonoCodeManager *cman, int *used_size); /* find the extra block allocated to resolve branches close to code */ typedef int (*MonoCodeManagerFunc) (void *data, int csize, int size, void *user_data); void mono_code_manager_foreach (MonoCodeManager *cman, MonoCodeManagerFunc func, void *user_data); +#if defined( __native_client_codegen__ ) && defined( __native_client__ ) + +#define kNaClBundleSize 32 +#define kNaClBundleMask (kNaClBundleSize-1) + +extern __thread unsigned char **patch_source_base; +extern __thread unsigned char **patch_dest_base; +extern __thread int patch_current_depth; + +int nacl_is_code_address (void *target); +void* nacl_code_manager_get_code_dest (MonoCodeManager *cman, void *data); +void nacl_allow_target_modification (int val); +void* nacl_modify_patch_target (unsigned char *target); +void* nacl_inverse_modify_patch_target (unsigned char *target); +#endif /* __native_client__ */ + #endif /* __MONO_CODEMAN_H__ */