X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/43866e378188c25dd1e2208016ab3cbeb086ae6c..a991bd8d3e7fe02dbca0644054bab73c5b75324a:/osfmk/kern/syscall_sw.h diff --git a/osfmk/kern/syscall_sw.h b/osfmk/kern/syscall_sw.h index 1272c1863..2816a65fc 100644 --- a/osfmk/kern/syscall_sw.h +++ b/osfmk/kern/syscall_sw.h @@ -1,16 +1,19 @@ /* - * Copyright (c) 2000 Apple Computer, Inc. All rights reserved. + * Copyright (c) 2000-2004 Apple Computer, Inc. All rights reserved. * - * @APPLE_LICENSE_HEADER_START@ - * - * Copyright (c) 1999-2003 Apple Computer, Inc. All Rights Reserved. + * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ * * This file contains Original Code and/or Modifications of Original Code * as defined in and that are subject to the Apple Public Source License * Version 2.0 (the 'License'). You may not use this file except in - * compliance with the License. Please obtain a copy of the License at - * http://www.opensource.apple.com/apsl/ and read it before using this - * file. + * compliance with the License. The rights granted to you under the License + * may not be used to create, or enable the creation or redistribution of, + * unlawful or unlicensed copies of an Apple operating system, or to + * circumvent, violate, or enable the circumvention or violation of, any + * terms of an Apple operating system software license agreement. + * + * Please obtain a copy of the License at + * http://www.opensource.apple.com/apsl/ and read it before using this file. * * The Original Code and all software distributed under the License are * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER @@ -20,7 +23,7 @@ * Please see the License for the specific language governing rights and * limitations under the License. * - * @APPLE_LICENSE_HEADER_END@ + * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ */ /* * @OSF_COPYRIGHT@ @@ -63,28 +66,51 @@ * its kernel stack. Some architectures may need * to save more state in the pcb for these traps. */ +#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 { - int mach_trap_arg_count; - int (*mach_trap_function)(void); - boolean_t mach_trap_stack; + int mach_trap_arg_count; /* Number of trap arguments (Arch independant) */ + 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 */ +} mach_trap_t; + +#define MACH_TRAP_TABLE_COUNT 128 + + +extern const mach_trap_t mach_trap_table[]; +extern int mach_trap_count; + +#if CONFIG_REQUIRES_U32_MUNGING || (__arm__ && (__BIGGEST_ALIGNMENT__ > 4)) + #if !MACH_ASSERT - int mach_trap_unused; -#else - char* mach_trap_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 */ -} mach_trap_t; -extern mach_trap_t mach_trap_table[]; -extern int mach_trap_count; -extern kern_return_t kern_invalid(void); + +#else /* !CONFIG_REQUIRES_U32_MUNGING || (__arm__ && (__BIGGEST_ALIGNMENT__ > 4)) */ #if !MACH_ASSERT -#define MACH_TRAP(name, arg_count) \ - { (arg_count), (int (*)(void)) (name), FALSE, 0 } -#else -#define MACH_TRAP(name, arg_count) \ - { (arg_count), (int (*)(void)) (name), FALSE, #name } +#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_ */