aboutsummaryrefslogtreecommitdiff
path: root/kern/sched.h
diff options
context:
space:
mode:
authorPasha <pasha@member.fsf.org>2024-02-20 18:49:50 +0000
committerPasha <pasha@member.fsf.org>2024-02-20 18:49:50 +0000
commit5e0b8d508ed51004bd836384293be00950ee62c9 (patch)
treee3f16b1aa8b7177032ce3ec429fbad2b1d92a876 /kern/sched.h
downloadgnumach-riscv-5e0b8d508ed51004bd836384293be00950ee62c9.tar.gz
gnumach-riscv-5e0b8d508ed51004bd836384293be00950ee62c9.tar.bz2
init gnumach copy
Diffstat (limited to 'kern/sched.h')
-rw-r--r--kern/sched.h186
1 files changed, 186 insertions, 0 deletions
diff --git a/kern/sched.h b/kern/sched.h
new file mode 100644
index 0000000..d7e74d3
--- /dev/null
+++ b/kern/sched.h
@@ -0,0 +1,186 @@
+/*
+ * Mach Operating System
+ * Copyright (c) 1991,1990,1989,1988,1987 Carnegie Mellon University
+ * All Rights Reserved.
+ *
+ * Permission to use, copy, modify and distribute this software and its
+ * documentation is hereby granted, provided that both the copyright
+ * notice and this permission notice appear in all copies of the
+ * software, derivative works or modified versions, and any portions
+ * thereof, and that both notices appear in supporting documentation.
+ *
+ * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
+ * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
+ * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
+ *
+ * Carnegie Mellon requests users of this software to return to
+ *
+ * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
+ * School of Computer Science
+ * Carnegie Mellon University
+ * Pittsburgh PA 15213-3890
+ *
+ * any improvements or extensions that they make and grant Carnegie Mellon
+ * the rights to redistribute these changes.
+ */
+/*
+ * File: sched.h
+ * Author: Avadis Tevanian, Jr.
+ * Date: 1985
+ *
+ * Header file for scheduler.
+ *
+ */
+
+#ifndef _KERN_SCHED_H_
+#define _KERN_SCHED_H_
+
+#include <kern/queue.h>
+#include <kern/lock.h>
+#include <kern/kern_types.h>
+#include <kern/macros.h>
+
+#if MACH_FIXPRI
+#include <mach/policy.h>
+#endif /* MACH_FIXPRI */
+
+#if STAT_TIME
+
+/*
+ * Statistical timing uses microseconds as timer units. 17 bit shift
+ * yields priorities. PRI_SHIFT_2 isn't needed.
+ */
+#define PRI_SHIFT 17
+
+#else /* STAT_TIME */
+
+/*
+ * Otherwise machine provides shift(s) based on time units it uses.
+ */
+#include <machine/sched_param.h>
+
+#endif /* STAT_TIME */
+#define NRQS 64 /* 64 run queues per cpu */
+
+struct run_queue {
+ queue_head_t runq[NRQS]; /* one for each priority */
+ decl_simple_lock_data(, lock) /* one lock for all queues,
+ shall be taken at splsched
+ only */
+ int low; /* low queue value */
+ int count; /* count of threads runable */
+};
+
+typedef struct run_queue *run_queue_t;
+#define RUN_QUEUE_NULL ((run_queue_t) 0)
+
+/* Shall be taken at splsched only */
+#ifdef MACH_LDEBUG
+#define runq_lock(rq) do { \
+ assert_splsched(); \
+ simple_lock_nocheck(&(rq)->lock); \
+} while (0)
+#define runq_unlock(rq) do { \
+ assert_splsched(); \
+ simple_unlock_nocheck(&(rq)->lock); \
+} while (0)
+#else
+#define runq_lock(rq) simple_lock_nocheck(&(rq)->lock)
+#define runq_unlock(rq) simple_unlock_nocheck(&(rq)->lock)
+#endif
+
+#if MACH_FIXPRI
+/*
+ * NOTE: For fixed priority threads, first_quantum indicates
+ * whether context switch at same priority is ok. For timeshareing
+ * it indicates whether preempt is ok.
+ */
+
+#define csw_needed(thread, processor) ((thread)->state & TH_SUSP || \
+ ((processor)->runq.count > 0) || \
+ ((thread)->policy == POLICY_TIMESHARE && \
+ (processor)->first_quantum == FALSE && \
+ (processor)->processor_set->runq.count > 0 && \
+ (processor)->processor_set->runq.low <= \
+ (thread)->sched_pri) || \
+ ((thread)->policy == POLICY_FIXEDPRI && \
+ (processor)->processor_set->runq.count > 0 && \
+ ((((processor)->first_quantum == FALSE) && \
+ ((processor)->processor_set->runq.low <= \
+ (thread)->sched_pri)) || \
+ ((processor)->processor_set->runq.low < \
+ (thread)->sched_pri))))
+
+#else /* MACH_FIXPRI */
+#define csw_needed(thread, processor) ((thread)->state & TH_SUSP || \
+ ((processor)->runq.count > 0) || \
+ ((processor)->first_quantum == FALSE && \
+ ((processor)->processor_set->runq.count > 0 && \
+ (processor)->processor_set->runq.low <= \
+ ((thread)->sched_pri))))
+#endif /* MACH_FIXPRI */
+
+/*
+ * Scheduler routines.
+ */
+
+extern struct run_queue *rem_runq(thread_t);
+extern struct thread *choose_thread(processor_t);
+extern queue_head_t action_queue; /* assign/shutdown queue */
+decl_simple_lock_data(extern,action_lock);
+
+extern int min_quantum; /* defines max context switch rate */
+#define MIN_QUANTUM (hz / 33) /* context switch 33 times/second */
+
+/*
+ * Default base priorities for threads.
+ */
+#define BASEPRI_SYSTEM 6
+#define BASEPRI_USER 25
+
+/*
+ * Macro to check for invalid priorities.
+ */
+
+#define invalid_pri(pri) (((pri) < 0) || ((pri) >= NRQS))
+
+/*
+ * Shift structures for holding update shifts. Actual computation
+ * is usage = (usage >> shift1) +/- (usage >> abs(shift2)) where the
+ * +/- is determined by the sign of shift 2.
+ */
+struct shift {
+ int shift1;
+ int shift2;
+};
+
+typedef struct shift *shift_t, shift_data_t;
+
+/*
+ * sched_tick increments once a second. Used to age priorities.
+ */
+
+extern unsigned sched_tick;
+
+#define SCHED_SCALE 128
+#define SCHED_SHIFT 7
+
+/*
+ * thread_timer_delta macro takes care of both thread timers.
+ */
+
+#define thread_timer_delta(thread) \
+MACRO_BEGIN \
+ unsigned delta; \
+ \
+ delta = 0; \
+ TIMER_DELTA((thread)->system_timer, \
+ (thread)->system_timer_save, delta); \
+ TIMER_DELTA((thread)->user_timer, \
+ (thread)->user_timer_save, delta); \
+ (thread)->cpu_delta += delta; \
+ (thread)->sched_delta += delta * \
+ (thread)->processor_set->sched_load; \
+MACRO_END
+
+#endif /* _KERN_SCHED_H_ */