Annotation of XNU/osfmk/i386/cpu_data.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
        !             3:  *
        !             4:  * @APPLE_LICENSE_HEADER_START@
        !             5:  * 
        !             6:  * The contents of this file constitute Original Code as defined in and
        !             7:  * are subject to the Apple Public Source License Version 1.1 (the
        !             8:  * "License").  You may not use this file except in compliance with the
        !             9:  * License.  Please obtain a copy of the License at
        !            10:  * http://www.apple.com/publicsource and read it before using this file.
        !            11:  * 
        !            12:  * This Original Code and all software distributed under the License are
        !            13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
        !            14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
        !            15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
        !            16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
        !            17:  * License for the specific language governing rights and limitations
        !            18:  * under the License.
        !            19:  * 
        !            20:  * @APPLE_LICENSE_HEADER_END@
        !            21:  */
        !            22: /*
        !            23:  * @OSF_COPYRIGHT@
        !            24:  * 
        !            25:  */
        !            26: 
        !            27: #ifndef        I386_CPU_DATA
        !            28: #define I386_CPU_DATA
        !            29: 
        !            30: #include <cpus.h>
        !            31: #include <mach_assert.h>
        !            32: 
        !            33: #if    defined(__GNUC__)
        !            34: 
        !            35: #include <kern/assert.h>
        !            36: #include <kern/kern_types.h>
        !            37: 
        !            38: #if 0
        !            39: #ifndef        __OPTIMIZE__
        !            40: #define extern static
        !            41: #endif
        !            42: #endif
        !            43: 
        !            44: /*
        !            45:  * Everyone within the osfmk part of the kernel can use the fast
        !            46:  * inline versions of these routines.  Everyone outside, must call
        !            47:  * the real thing,
        !            48:  */
        !            49: extern thread_t        __inline__ current_thread_fast(void);
        !            50: extern thread_t __inline__ current_thread_fast(void)
        !            51: {
        !            52:        register thread_t       ct;
        !            53:        register int            idx = (int)&((cpu_data_t *)0)->active_thread;
        !            54: 
        !            55:        __asm__ volatile ("     movl %%gs:(%1),%0" : "=r" (ct) : "r" (idx));
        !            56: 
        !            57:        return (ct);
        !            58: }
        !            59: 
        !            60: #define current_thread()       current_thread_fast()
        !            61: 
        !            62: extern int     __inline__      get_preemption_level(void);
        !            63: extern void    __inline__      disable_preemption(void);
        !            64: extern void    __inline__      enable_preemption(void);
        !            65: extern void    __inline__      enable_preemption_no_check(void);
        !            66: extern void    __inline__      mp_disable_preemption(void);
        !            67: extern void    __inline__      mp_enable_preemption(void);
        !            68: extern void    __inline__      mp_enable_preemption_no_check(void);
        !            69: extern int     __inline__      get_simple_lock_count(void);
        !            70: extern int     __inline__      get_interrupt_level(void);
        !            71: 
        !            72: extern int __inline__          get_preemption_level(void)
        !            73: {
        !            74:        register int    idx = (int)&((cpu_data_t *)0)->preemption_level;
        !            75:        register int    pl;
        !            76: 
        !            77:        __asm__ volatile ("     movl %%gs:(%1),%0" : "=r" (pl) : "r" (idx));
        !            78: 
        !            79:        return (pl);
        !            80: }
        !            81: 
        !            82: extern void __inline__         disable_preemption(void)
        !            83: {
        !            84: #if    MACH_ASSERT
        !            85:        extern void _disable_preemption(void);
        !            86: 
        !            87:        _disable_preemption();
        !            88: #else  /* MACH_ASSERT */
        !            89:        register int    idx = (int)&((cpu_data_t *)0)->preemption_level;
        !            90: 
        !            91:        __asm__ volatile ("     incl %%gs:(%0)" : : "r" (idx));
        !            92: #endif /* MACH_ASSERT */
        !            93: }
        !            94: 
        !            95: extern void __inline__         enable_preemption(void)
        !            96: {
        !            97: #if    MACH_ASSERT
        !            98:        extern void _enable_preemption(void);
        !            99: 
        !           100:        assert(get_preemption_level() > 0);
        !           101:        _enable_preemption();
        !           102: #else  /* MACH_ASSERT */
        !           103:        extern void             kernel_preempt_check (void);
        !           104:        register int    idx = (int)&((cpu_data_t *)0)->preemption_level;
        !           105:        register void (*kpc)(void)=     kernel_preempt_check;
        !           106: 
        !           107:        __asm__ volatile ("decl %%gs:(%0); jne 1f; \
        !           108:                        call %1; 1:"
        !           109:                        : /* no outputs */
        !           110:                        : "r" (idx), "r" (kpc)
        !           111:                        : "%eax", "%ecx", "%edx", "cc", "memory");
        !           112: #endif /* MACH_ASSERT */
        !           113: }
        !           114: 
        !           115: extern void __inline__         enable_preemption_no_check(void)
        !           116: {
        !           117: #if    MACH_ASSERT
        !           118:        extern void _enable_preemption_no_check(void);
        !           119: 
        !           120:        assert(get_preemption_level() > 0);
        !           121:        _enable_preemption_no_check();
        !           122: #else  /* MACH_ASSERT */
        !           123:        register int    idx = (int)&((cpu_data_t *)0)->preemption_level;
        !           124: 
        !           125:        __asm__ volatile ("decl %%gs:(%0)"
        !           126:                        : /* no outputs */
        !           127:                        : "r" (idx)
        !           128:                        : "cc", "memory");
        !           129: #endif /* MACH_ASSERT */
        !           130: }
        !           131: 
        !           132: extern void __inline__         mp_disable_preemption(void)
        !           133: {
        !           134: #if    NCPUS > 1
        !           135:        disable_preemption();
        !           136: #endif /* NCPUS > 1 */
        !           137: }
        !           138: 
        !           139: extern void __inline__         mp_enable_preemption(void)
        !           140: {
        !           141: #if    NCPUS > 1
        !           142:        enable_preemption();
        !           143: #endif /* NCPUS > 1 */
        !           144: }
        !           145: 
        !           146: extern void __inline__         mp_enable_preemption_no_check(void)
        !           147: {
        !           148: #if    NCPUS > 1
        !           149:        enable_preemption_no_check();
        !           150: #endif /* NCPUS > 1 */
        !           151: }
        !           152: 
        !           153: extern int __inline__          get_simple_lock_count(void)
        !           154: {
        !           155:        register int    idx = (int)&((cpu_data_t *)0)->simple_lock_count;
        !           156:        register int    pl;
        !           157: 
        !           158:        __asm__ volatile ("     movl %%gs:(%1),%0" : "=r" (pl) : "r" (idx));
        !           159: 
        !           160:        return (pl);
        !           161: }
        !           162: 
        !           163: extern int __inline__          get_interrupt_level(void)
        !           164: {
        !           165:        register int    idx = (int)&((cpu_data_t *)0)->interrupt_level;
        !           166:        register int    pl;
        !           167: 
        !           168:        __asm__ volatile ("     movl %%gs:(%1),%0" : "=r" (pl) : "r" (idx));
        !           169: 
        !           170:        return (pl);
        !           171: }
        !           172: 
        !           173: #if 0
        !           174: #ifndef        __OPTIMIZE__
        !           175: #undef         extern 
        !           176: #endif
        !           177: #endif
        !           178: 
        !           179: #else  /* !defined(__GNUC__) */
        !           180: 
        !           181: #endif /* defined(__GNUC__) */
        !           182: 
        !           183: #endif /* I386_CPU_DATA */

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.