]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/kern/syscall_sw.h
xnu-7195.81.3.tar.gz
[apple/xnu.git] / osfmk / kern / syscall_sw.h
index 879b9cd5c0cf828fc77d9c260dbbac1f96e76732..2816a65fc768d8c080dd3d19ebe54c8830dfaea3 100644 (file)
  *     its kernel stack.  Some architectures may need
  *     to save more state in the pcb for these traps.
  */
  *     its kernel stack.  Some architectures may need
  *     to save more state in the pcb for these traps.
  */
-typedef        void    mach_munge_t(const void *, void *);
+#if CONFIG_REQUIRES_U32_MUNGING
+typedef        void    mach_munge_t(void *);
+#elif __arm__ && (__BIGGEST_ALIGNMENT__ > 4)
+typedef        int     mach_munge_t(const void *, void *);
+#endif
 
 typedef struct {
 
 typedef struct {
-       int                     mach_trap_arg_count;
+       int                     mach_trap_arg_count; /* Number of trap arguments (Arch independant) */
        kern_return_t           (*mach_trap_function)(void *);
        kern_return_t           (*mach_trap_function)(void *);
+#if CONFIG_REQUIRES_U32_MUNGING || (__arm__ && (__BIGGEST_ALIGNMENT__ > 4))
+       mach_munge_t            *mach_trap_arg_munge32; /* system call argument munger routine for 32-bit */
+#endif
+       int                     mach_trap_u32_words; /* number of 32-bit words to copyin for U32 */
 #if    MACH_ASSERT
        const char*             mach_trap_name;
 #endif /* MACH_ASSERT */
 #if    MACH_ASSERT
        const char*             mach_trap_name;
 #endif /* MACH_ASSERT */
@@ -82,16 +90,27 @@ typedef struct {
 extern const mach_trap_t       mach_trap_table[];
 extern int                     mach_trap_count;
 
 extern const mach_trap_t       mach_trap_table[];
 extern int                     mach_trap_count;
 
-#if defined(__i386__) || defined(__x86_64__)
+#if CONFIG_REQUIRES_U32_MUNGING || (__arm__ && (__BIGGEST_ALIGNMENT__ > 4))
+
 #if    !MACH_ASSERT
 #if    !MACH_ASSERT
-#define        MACH_TRAP(name, arg_count, munge32, munge64)    \
-       { (arg_count), (kern_return_t (*)(void *)) (name)  }
-#else
-#define MACH_TRAP(name, arg_count, munge32, munge64)           \
-       { (arg_count), (kern_return_t (*)(void *)) (name), #name }
+#define        MACH_TRAP(name, arg_count, u32_arg_words, munge32)      \
+       { (arg_count), (kern_return_t (*)(void *)) (name), munge32, (u32_arg_words)  }
+#else /* !MACH_ASSERT */
+#define        MACH_TRAP(name, arg_count, u32_arg_words, munge32)      \
+       { (arg_count), (kern_return_t (*)(void *)) (name), munge32, (u32_arg_words), #name  }
 #endif /* !MACH_ASSERT */
 #endif /* !MACH_ASSERT */
-#else  /* !defined(__i386__) && !defined(__x86_64__) && !defined(__arm__) */
-#error Unsupported architecture
-#endif /* !defined(__i386__) && !defined(__x86_64__) && !defined(__arm__) */
+
+
+#else /* !CONFIG_REQUIRES_U32_MUNGING || (__arm__ && (__BIGGEST_ALIGNMENT__ > 4)) */
+
+#if    !MACH_ASSERT
+#define        MACH_TRAP(name, arg_count, u32_arg_words, munge32)      \
+       { (arg_count), (kern_return_t (*)(void *)) (name), (u32_arg_words)  }
+#else /* !MACH_ASSERT */
+#define        MACH_TRAP(name, arg_count, u32_arg_words, munge32)      \
+       { (arg_count), (kern_return_t (*)(void *)) (name), (u32_arg_words), #name  }
+#endif /* !MACH_ASSERT */
+
+#endif /* !CONFIG_REQUIRES_U32_MUNGING */
 
 #endif /* _KERN_SYSCALL_SW_H_ */
 
 #endif /* _KERN_SYSCALL_SW_H_ */