Annotation of OSKit-Mach/kern/sched.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Mach Operating System
        !             3:  * Copyright (c) 1991,1990,1989,1988,1987 Carnegie Mellon University
        !             4:  * All Rights Reserved.
        !             5:  *
        !             6:  * Permission to use, copy, modify and distribute this software and its
        !             7:  * documentation is hereby granted, provided that both the copyright
        !             8:  * notice and this permission notice appear in all copies of the
        !             9:  * software, derivative works or modified versions, and any portions
        !            10:  * thereof, and that both notices appear in supporting documentation.
        !            11:  *
        !            12:  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
        !            13:  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
        !            14:  * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
        !            15:  *
        !            16:  * Carnegie Mellon requests users of this software to return to
        !            17:  *
        !            18:  *  Software Distribution Coordinator  or  [email protected]
        !            19:  *  School of Computer Science
        !            20:  *  Carnegie Mellon University
        !            21:  *  Pittsburgh PA 15213-3890
        !            22:  *
        !            23:  * any improvements or extensions that they make and grant Carnegie Mellon
        !            24:  * the rights to redistribute these changes.
        !            25:  */
        !            26: /*
        !            27:  *     File:   sched.h
        !            28:  *     Author: Avadis Tevanian, Jr.
        !            29:  *     Date:   1985
        !            30:  *
        !            31:  *     Header file for scheduler.
        !            32:  *
        !            33:  */
        !            34: 
        !            35: #ifndef        _KERN_SCHED_H_
        !            36: #define _KERN_SCHED_H_
        !            37: 
        !            38: #include <cpus.h>
        !            39: #include <mach_fixpri.h>
        !            40: #include <simple_clock.h>
        !            41: #include <stat_time.h>
        !            42: 
        !            43: #include <kern/queue.h>
        !            44: #include <kern/lock.h>
        !            45: #include <kern/macro_help.h>
        !            46: 
        !            47: #if    MACH_FIXPRI
        !            48: #include <mach/policy.h>
        !            49: #endif /* MACH_FIXPRI */
        !            50: 
        !            51: #if    STAT_TIME
        !            52: 
        !            53: /*
        !            54:  *     Statistical timing uses microseconds as timer units.  18 bit shift
        !            55:  *     yields priorities.  PRI_SHIFT_2 isn't needed.
        !            56:  */
        !            57: #define PRI_SHIFT      18
        !            58: 
        !            59: #else  /* STAT_TIME */
        !            60: 
        !            61: /*
        !            62:  *     Otherwise machine provides shift(s) based on time units it uses.
        !            63:  */
        !            64: #include <machine/sched_param.h>
        !            65: 
        !            66: #endif /* STAT_TIME */
        !            67: #define NRQS   32                      /* 32 run queues per cpu */
        !            68: 
        !            69: struct run_queue {
        !            70:        queue_head_t            runq[NRQS];     /* one for each priority */
        !            71:        decl_simple_lock_data(, lock)           /* one lock for all queues */
        !            72:        int                     low;            /* low queue value */
        !            73:        int                     count;          /* count of threads runable */
        !            74: };
        !            75: 
        !            76: typedef struct run_queue       *run_queue_t;
        !            77: #define RUN_QUEUE_NULL ((run_queue_t) 0)
        !            78: 
        !            79: #if    MACH_FIXPRI
        !            80: /*
        !            81:  *     NOTE: For fixed priority threads, first_quantum indicates
        !            82:  *     whether context switch at same priority is ok.  For timeshareing
        !            83:  *     it indicates whether preempt is ok.
        !            84:  */
        !            85: 
        !            86: #define csw_needed(thread, processor) ((thread)->state & TH_SUSP ||    \
        !            87:        ((processor)->runq.count > 0) ||                                \
        !            88:        ((thread)->policy == POLICY_TIMESHARE &&                        \
        !            89:                (processor)->first_quantum == FALSE &&                  \
        !            90:                (processor)->processor_set->runq.count > 0 &&           \
        !            91:                  (processor)->processor_set->runq.low <=               \
        !            92:                        (thread)->sched_pri) ||                         \
        !            93:        ((thread)->policy == POLICY_FIXEDPRI &&                         \
        !            94:                (processor)->processor_set->runq.count > 0 &&           \
        !            95:                 ((((processor)->first_quantum == FALSE) &&             \
        !            96:                  ((processor)->processor_set->runq.low <=              \
        !            97:                        (thread)->sched_pri)) ||                        \
        !            98:                 ((processor)->processor_set->runq.low <                \
        !            99:                        (thread)->sched_pri))))
        !           100: 
        !           101: #else  /* MACH_FIXPRI */
        !           102: #define csw_needed(thread, processor) ((thread)->state & TH_SUSP ||    \
        !           103:                ((processor)->runq.count > 0) ||                        \
        !           104:                ((processor)->first_quantum == FALSE &&                 \
        !           105:                 ((processor)->processor_set->runq.count > 0 &&         \
        !           106:                  (processor)->processor_set->runq.low <=               \
        !           107:                        ((thread)->sched_pri))))
        !           108: #endif /* MACH_FIXPRI */
        !           109: 
        !           110: /*
        !           111:  *     Scheduler routines.
        !           112:  */
        !           113: 
        !           114: extern struct run_queue        *rem_runq();
        !           115: extern struct thread   *choose_thread();
        !           116: extern queue_head_t    action_queue;   /* assign/shutdown queue */
        !           117: decl_simple_lock_data(extern,action_lock);
        !           118: 
        !           119: extern int             min_quantum;    /* defines max context switch rate */
        !           120: 
        !           121: /*
        !           122:  *     Default base priorities for threads.
        !           123:  */
        !           124: #define BASEPRI_SYSTEM 6
        !           125: #define BASEPRI_USER   12
        !           126: 
        !           127: /*
        !           128:  *     Macro to check for invalid priorities.
        !           129:  */
        !           130: 
        !           131: #define invalid_pri(pri) (((pri) < 0) || ((pri) >= NRQS))
        !           132: 
        !           133: /*
        !           134:  *     Shift structures for holding update shifts.  Actual computation
        !           135:  *     is  usage = (usage >> shift1) +/- (usage >> abs(shift2))  where the
        !           136:  *     +/- is determined by the sign of shift 2.
        !           137:  */
        !           138: struct shift {
        !           139:        int     shift1;
        !           140:        int     shift2;
        !           141: };
        !           142: 
        !           143: typedef        struct shift    *shift_t, shift_data_t;
        !           144: 
        !           145: /*
        !           146:  *     sched_tick increments once a second.  Used to age priorities.
        !           147:  */
        !           148: 
        !           149: extern unsigned        sched_tick;
        !           150: 
        !           151: #define SCHED_SCALE    128
        !           152: #define SCHED_SHIFT    7
        !           153: 
        !           154: /*
        !           155:  *     thread_timer_delta macro takes care of both thread timers.
        !           156:  */
        !           157: 
        !           158: #define thread_timer_delta(thread)                             \
        !           159: MACRO_BEGIN                                                    \
        !           160:        register unsigned       delta;                          \
        !           161:                                                                \
        !           162:        delta = 0;                                              \
        !           163:        TIMER_DELTA((thread)->system_timer,                     \
        !           164:                (thread)->system_timer_save, delta);            \
        !           165:        TIMER_DELTA((thread)->user_timer,                       \
        !           166:                (thread)->user_timer_save, delta);              \
        !           167:        (thread)->cpu_delta += delta;                           \
        !           168:        (thread)->sched_delta += delta *                        \
        !           169:                        (thread)->processor_set->sched_load;    \
        !           170: MACRO_END
        !           171: 
        !           172: #if    SIMPLE_CLOCK
        !           173: /*
        !           174:  *     sched_usec is an exponential average of number of microseconds
        !           175:  *     in a second for clock drift compensation.
        !           176:  */
        !           177: 
        !           178: extern int     sched_usec;
        !           179: #endif /* SIMPLE_CLOCK */
        !           180: 
        !           181: #endif /* _KERN_SCHED_H_ */

unix.superglobalmegacorp.com

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