source: trunk/minix/kernel/table.c@ 12

Last change on this file since 12 was 9, checked in by Mattia Monga, 14 years ago

Minix 3.1.2a

File size: 6.1 KB
Line 
1/* The object file of "table.c" contains most kernel data. Variables that
2 * are declared in the *.h files appear with EXTERN in front of them, as in
3 *
4 * EXTERN int x;
5 *
6 * Normally EXTERN is defined as extern, so when they are included in another
7 * file, no storage is allocated. If EXTERN were not present, but just say,
8 *
9 * int x;
10 *
11 * then including this file in several source files would cause 'x' to be
12 * declared several times. While some linkers accept this, others do not,
13 * so they are declared extern when included normally. However, it must be
14 * declared for real somewhere. That is done here, by redefining EXTERN as
15 * the null string, so that inclusion of all *.h files in table.c actually
16 * generates storage for them.
17 *
18 * Various variables could not be declared EXTERN, but are declared PUBLIC
19 * or PRIVATE. The reason for this is that extern variables cannot have a
20 * default initialization. If such variables are shared, they must also be
21 * declared in one of the *.h files without the initialization. Examples
22 * include 'boot_image' (this file) and 'idt' and 'gdt' (protect.c).
23 *
24 * Changes:
25 * Aug 02, 2005 set privileges and minimal boot image (Jorrit N. Herder)
26 * Oct 17, 2004 updated above and tasktab comments (Jorrit N. Herder)
27 * May 01, 2004 changed struct for system image (Jorrit N. Herder)
28 */
29#define _TABLE
30
31#include "kernel.h"
32#include "proc.h"
33#include "ipc.h"
34#include <minix/com.h>
35#include <ibm/int86.h>
36
37/* Define stack sizes for the kernel tasks included in the system image. */
38#define NO_STACK 0
39#define SMALL_STACK (128 * sizeof(char *))
40#define IDL_S SMALL_STACK /* 3 intr, 3 temps, 4 db for Intel */
41#define HRD_S NO_STACK /* dummy task, uses kernel stack */
42#define TSK_S SMALL_STACK /* system and clock task */
43
44/* Stack space for all the task stacks. Declared as (char *) to align it. */
45#define TOT_STACK_SPACE (IDL_S + HRD_S + (2 * TSK_S))
46PUBLIC char *t_stack[TOT_STACK_SPACE / sizeof(char *)];
47
48/* Define flags for the various process types. */
49#define IDL_F (SYS_PROC | PREEMPTIBLE | BILLABLE) /* idle task */
50#define TSK_F (SYS_PROC) /* kernel tasks */
51#define SRV_F (SYS_PROC | PREEMPTIBLE) /* system services */
52#define USR_F (BILLABLE | PREEMPTIBLE) /* user processes */
53
54/* Define system call traps for the various process types. These call masks
55 * determine what system call traps a process is allowed to make.
56 */
57#define TSK_T (1 << RECEIVE) /* clock and system */
58#define SRV_T (~0) /* system services */
59#define USR_T ((1 << SENDREC) | (1 << ECHO)) /* user processes */
60
61/* Send masks determine to whom processes can send messages or notifications.
62 * The values here are used for the processes in the boot image. We rely on
63 * the initialization code in main() to match the s_nr_to_id() mapping for the
64 * processes in the boot image, so that the send mask that is defined here
65 * can be directly copied onto map[0] of the actual send mask. Privilege
66 * structure 0 is shared by user processes.
67 */
68#define s(n) (1 << s_nr_to_id(n))
69#define SRV_M (~0)
70#define SYS_M (~0)
71#define USR_M (s(PM_PROC_NR) | s(FS_PROC_NR) | s(RS_PROC_NR) | s(SYSTEM))
72#define DRV_M (USR_M | s(SYSTEM) | s(CLOCK) | s(DS_PROC_NR) | s(LOG_PROC_NR) | s(TTY_PROC_NR))
73
74/* Define kernel calls that processes are allowed to make. This is not looking
75 * very nice, but we need to define the access rights on a per call basis.
76 * Note that the reincarnation server has all bits on, because it should
77 * be allowed to distribute rights to services that it starts.
78 */
79#define c(n) (1 << ((n)-KERNEL_CALL))
80#define RS_C ~0
81#define DS_C ~0
82#define PM_C ~(c(SYS_DEVIO) | c(SYS_SDEVIO) | c(SYS_VDEVIO) | c(SYS_IRQCTL) | c(SYS_INT86))
83#define FS_C (c(SYS_KILL) | c(SYS_VIRCOPY) | c(SYS_VIRVCOPY) | c(SYS_UMAP) | c(SYS_GETINFO) | c(SYS_EXIT) | c(SYS_TIMES) | c(SYS_SETALARM))
84#define DRV_C (FS_C | c(SYS_SEGCTL) | c(SYS_IRQCTL) | c(SYS_INT86) | c(SYS_DEVIO) | c(SYS_SDEVIO) | c(SYS_VDEVIO))
85#define TTY_C (DRV_C | c(SYS_ABORT) | c(SYS_VM_MAP) | c(SYS_IOPENABLE))
86#define MEM_C (DRV_C | c(SYS_PHYSCOPY) | c(SYS_PHYSVCOPY) | c(SYS_VM_MAP) | \
87 c(SYS_IOPENABLE))
88
89/* The system image table lists all programs that are part of the boot image.
90 * The order of the entries here MUST agree with the order of the programs
91 * in the boot image and all kernel tasks must come first.
92 *
93 * Each entry provides the process number, flags, quantum size, scheduling
94 * queue, allowed traps, ipc mask, and a name for the process table. The
95 * initial program counter and stack size is also provided for kernel tasks.
96 *
97 * Note: the quantum size must be positive in all cases!
98 */
99PUBLIC struct boot_image image[] = {
100/* process nr, pc, flags, qs, queue, stack, traps, ipcto, call, name */
101 { IDLE, idle_task, IDL_F, 8, IDLE_Q, IDL_S, 0, 0, 0, "idle" },
102 { CLOCK,clock_task, TSK_F, 8, TASK_Q, TSK_S, TSK_T, 0, 0, "clock" },
103 { SYSTEM, sys_task, TSK_F, 8, TASK_Q, TSK_S, TSK_T, 0, 0, "system"},
104 { HARDWARE, 0, TSK_F, 8, TASK_Q, HRD_S, 0, 0, 0, "kernel"},
105 { PM_PROC_NR, 0, SRV_F, 32, 3, 0, SRV_T, SRV_M, PM_C, "pm" },
106 { FS_PROC_NR, 0, SRV_F, 32, 4, 0, SRV_T, SRV_M, FS_C, "fs" },
107 { RS_PROC_NR, 0, SRV_F, 4, 3, 0, SRV_T, SYS_M, RS_C, "rs" },
108 { DS_PROC_NR, 0, SRV_F, 4, 3, 0, SRV_T, SYS_M, DS_C, "ds" },
109 { TTY_PROC_NR, 0, SRV_F, 4, 1, 0, SRV_T, SYS_M, TTY_C, "tty" },
110 { MEM_PROC_NR, 0, SRV_F, 4, 2, 0, SRV_T, SYS_M, MEM_C, "mem" },
111 { LOG_PROC_NR, 0, SRV_F, 4, 2, 0, SRV_T, SYS_M, DRV_C, "log" },
112 { INIT_PROC_NR, 0, USR_F, 8, USER_Q, 0, USR_T, USR_M, 0, "init" },
113};
114
115/* Verify the size of the system image table at compile time. Also verify that
116 * the first chunk of the ipc mask has enough bits to accommodate the processes
117 * in the image.
118 * If a problem is detected, the size of the 'dummy' array will be negative,
119 * causing a compile time error. Note that no space is actually allocated
120 * because 'dummy' is declared extern.
121 */
122extern int dummy[(NR_BOOT_PROCS==sizeof(image)/
123 sizeof(struct boot_image))?1:-1];
124extern int dummy[(BITCHUNK_BITS > NR_BOOT_PROCS - 1) ? 1 : -1];
125
Note: See TracBrowser for help on using the repository browser.