]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/mach/shared_memory_server.h
xnu-4570.41.2.tar.gz
[apple/xnu.git] / osfmk / mach / shared_memory_server.h
index 7d2f103b28d3f55a33ce12d408e13694ad212d7a..bd792319c1d38eda798395d0b74deb6de784d368 100644 (file)
  *     protos and struct definitions for shared library
  *     server and interface
  */
  *     protos and struct definitions for shared library
  *     server and interface
  */
+
+/*
+ * XXX
+ * 
+ * NOTE: this file is deprecated and will be removed in the near future.
+ * Any project that includes this file should be changed to:
+ * 1. use <mach/shared_region.h> instead of this file,
+ * 2. handle the new shared regions, now available on more platforms
+ */
+
 #ifndef _MACH_SHARED_MEMORY_SERVER_H_
 #define _MACH_SHARED_MEMORY_SERVER_H_
 
 #ifndef _MACH_SHARED_MEMORY_SERVER_H_
 #define _MACH_SHARED_MEMORY_SERVER_H_
 
+#warning "<mach/shared_memory_server.h> is deprecated.  Please use <mach/shared_region.h> instead."
+
 #include <sys/cdefs.h>
 #include <mach/vm_prot.h>
 #include <mach/vm_types.h>
 #include <sys/cdefs.h>
 #include <mach/vm_prot.h>
 #include <mach/vm_types.h>
 #define VM_PROT_COW  0x8  /* must not interfere with normal prot assignments */
 #define VM_PROT_ZF  0x10  /* must not interfere with normal prot assignments */
 
 #define VM_PROT_COW  0x8  /* must not interfere with normal prot assignments */
 #define VM_PROT_ZF  0x10  /* must not interfere with normal prot assignments */
 
+#ifdef __arm__
+#define GLOBAL_SHARED_TEXT_SEGMENT     0x30000000U
+#define GLOBAL_SHARED_DATA_SEGMENT     0x38000000U
+#define GLOBAL_SHARED_SEGMENT_MASK     0xF8000000U
+
+#define        SHARED_TEXT_REGION_SIZE         0x08000000
+#define        SHARED_DATA_REGION_SIZE         0x08000000
+#else
+#define GLOBAL_SHARED_TEXT_SEGMENT     0x90000000U
+#define GLOBAL_SHARED_DATA_SEGMENT     0xA0000000U
+#define GLOBAL_SHARED_SEGMENT_MASK     0xF0000000U
+
+#define        SHARED_TEXT_REGION_SIZE         0x10000000
+#define        SHARED_DATA_REGION_SIZE         0x10000000
+#endif
 
 #if !defined(__LP64__)
 
 #define        SHARED_LIBRARY_SERVER_SUPPORTED
 
 #if !defined(__LP64__)
 
 #define        SHARED_LIBRARY_SERVER_SUPPORTED
-#define GLOBAL_SHARED_TEXT_SEGMENT     0x90000000
-#define GLOBAL_SHARED_DATA_SEGMENT     0xA0000000
-#define GLOBAL_SHARED_SEGMENT_MASK     0xF0000000
 
 
-#define        SHARED_TEXT_REGION_SIZE         0x10000000
-#define        SHARED_DATA_REGION_SIZE         0x10000000
 #define        SHARED_ALTERNATE_LOAD_BASE      0x09000000
 
 /* 
 #define        SHARED_ALTERNATE_LOAD_BASE      0x09000000
 
 /* 
  *  i.e. if the size is 0x10000000 the object can be mapped at 
  *  0x20000000, or 0x30000000, but not 0x1000000
  */
  *  i.e. if the size is 0x10000000 the object can be mapped at 
  *  0x20000000, or 0x30000000, but not 0x1000000
  */
+#ifdef __arm__
+#define        SHARED_TEXT_REGION_MASK         0x07FFFFFF
+#define        SHARED_DATA_REGION_MASK         0x07FFFFFF
+#else
 #define        SHARED_TEXT_REGION_MASK         0x0FFFFFFF
 #define        SHARED_DATA_REGION_MASK         0x0FFFFFFF
 #define        SHARED_TEXT_REGION_MASK         0x0FFFFFFF
 #define        SHARED_DATA_REGION_MASK         0x0FFFFFFF
-
-#define SHARED_LIB_ALIAS  0x10
+#endif
 
 
 /* flags field aliases for copyin_shared_file and load_shared_file */
 
 
 /* flags field aliases for copyin_shared_file and load_shared_file */
@@ -88,16 +113,6 @@ struct sf_mapping {
 };
 typedef struct sf_mapping sf_mapping_t;
 
 };
 typedef struct sf_mapping sf_mapping_t;
 
-#ifndef KERNEL
-/* load_shared_file and friends is deprecated */
-__BEGIN_DECLS
-int    load_shared_file(char *, caddr_t, u_long,
-               caddr_t *, int, sf_mapping_t *, int *);
-int    reset_shared_file(caddr_t *, int, sf_mapping_t *);
-int    new_system_shared_regions(void);
-__END_DECLS
-#endif /* !KERNEL */
-
 #endif  /* !defined(__LP64__) */
 
 /* 
 #endif  /* !defined(__LP64__) */
 
 /*