X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/ff6e181ae92fc6f1e89841290f461d1f2f9badd9..refs/heads/master:/osfmk/i386/machdep_call.c diff --git a/osfmk/i386/machdep_call.c b/osfmk/i386/machdep_call.c index 5666f180c..cde942292 100644 --- a/osfmk/i386/machdep_call.c +++ b/osfmk/i386/machdep_call.c @@ -1,15 +1,20 @@ /* - * Copyright (c) 2000 Apple Computer, Inc. All rights reserved. + * Copyright (c) 2000-2006 Apple Computer, Inc. All rights reserved. + * + * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ * - * @APPLE_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 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, @@ -17,8 +22,8 @@ * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. * Please see the License for the specific language governing rights and * limitations under the License. - * - * @APPLE_LICENSE_HEADER_END@ + * + * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ */ /* * Copyright (c) 1992 NeXT Computer, Inc. @@ -30,34 +35,36 @@ * 17 June 1992 ? at NeXT * Created. */ - + #include #include -extern kern_return_t kern_invalid(void); -#ifdef FIXME -extern kern_return_t PCcreate(), PCldt(), PCresume(); -extern kern_return_t PCcopyBIOSData(), PCmapBIOSRom(); -extern kern_return_t PCsizeBIOSExtData(), PCcopyBIOSExtData(); -#endif +extern kern_return_t kern_invalid(void); -machdep_call_t machdep_call_table[] = { - MACHDEP_CALL_ROUTINE(thread_get_cthread_self,0), - MACHDEP_CALL_ROUTINE(thread_set_cthread_self,1), - MACHDEP_CALL_ROUTINE(kern_invalid,0), - MACHDEP_CALL_ROUTINE(thread_fast_set_cthread_self,1), - MACHDEP_CALL_ROUTINE(thread_set_user_ldt,3), -#ifdef FIXME - MACHDEP_CALL_ROUTINE(PCcreate,3), - MACHDEP_CALL_ROUTINE(PCldt,3), - MACHDEP_CALL_ROUTINE(PCresume,0), - MACHDEP_CALL_ROUTINE(PCcopyBIOSData,1), - MACHDEP_CALL_ROUTINE(PCsizeBIOSExtData,0), - MACHDEP_CALL_ROUTINE(PCcopyBIOSExtData,1), - MACHDEP_CALL_ROUTINE(PCmapBIOSRom,3), +const machdep_call_t machdep_call_table[] = { + MACHDEP_CALL_ROUTINE(kern_invalid, 0), + MACHDEP_CALL_ROUTINE(kern_invalid, 0), + MACHDEP_CALL_ROUTINE(kern_invalid, 0), + MACHDEP_CALL_ROUTINE(thread_fast_set_cthread_self, 1), + MACHDEP_CALL_ROUTINE(thread_set_user_ldt, 3), + MACHDEP_BSD_CALL_ROUTINE(i386_set_ldt, 3), + MACHDEP_BSD_CALL_ROUTINE(i386_get_ldt, 3), +}; +const machdep_call_t machdep_call_table64[] = { +#if HYPERVISOR + MACHDEP_CALL_ROUTINE64(hv_task_trap, 2), + MACHDEP_CALL_ROUTINE64(hv_thread_trap, 2), +#else + MACHDEP_CALL_ROUTINE(kern_invalid, 0), + MACHDEP_CALL_ROUTINE(kern_invalid, 0), #endif + MACHDEP_CALL_ROUTINE(kern_invalid, 0), + MACHDEP_CALL_ROUTINE64(thread_fast_set_cthread_self64, 1), + MACHDEP_CALL_ROUTINE(kern_invalid, 0), + MACHDEP_BSD_CALL_ROUTINE64(i386_set_ldt64, 3), + MACHDEP_BSD_CALL_ROUTINE64(i386_get_ldt64, 3) }; -int machdep_call_count = - (sizeof (machdep_call_table) / sizeof (machdep_call_t)); +int machdep_call_count = + (sizeof(machdep_call_table) / sizeof(machdep_call_t));