2005-04-21 16:53:53 +02:00
|
|
|
/* The object file of "table.c" contains most kernel data. Variables that
|
|
|
|
* are declared in the *.h files appear with EXTERN in front of them, as in
|
|
|
|
*
|
|
|
|
* EXTERN int x;
|
|
|
|
*
|
|
|
|
* Normally EXTERN is defined as extern, so when they are included in another
|
|
|
|
* file, no storage is allocated. If EXTERN were not present, but just say,
|
|
|
|
*
|
|
|
|
* int x;
|
|
|
|
*
|
|
|
|
* then including this file in several source files would cause 'x' to be
|
|
|
|
* declared several times. While some linkers accept this, others do not,
|
|
|
|
* so they are declared extern when included normally. However, it must be
|
|
|
|
* declared for real somewhere. That is done here, by redefining EXTERN as
|
|
|
|
* the null string, so that inclusion of all *.h files in table.c actually
|
|
|
|
* generates storage for them.
|
|
|
|
*
|
|
|
|
* Various variables could not be declared EXTERN, but are declared PUBLIC
|
|
|
|
* or PRIVATE. The reason for this is that extern variables cannot have a
|
|
|
|
* default initialization. If such variables are shared, they must also be
|
|
|
|
* declared in one of the *.h files without the initialization. Examples
|
2005-07-29 17:26:23 +02:00
|
|
|
* include 'boot_image' (this file) and 'idt' and 'gdt' (protect.c).
|
2005-04-21 16:53:53 +02:00
|
|
|
*
|
|
|
|
* Changes:
|
2005-08-04 21:23:03 +02:00
|
|
|
* Aug 02, 2005 set privileges and minimal boot image (Jorrit N. Herder)
|
2005-04-21 16:53:53 +02:00
|
|
|
* Oct 17, 2004 updated above and tasktab comments (Jorrit N. Herder)
|
2005-07-21 20:36:40 +02:00
|
|
|
* May 01, 2004 changed struct for system image (Jorrit N. Herder)
|
2005-04-21 16:53:53 +02:00
|
|
|
*/
|
|
|
|
#define _TABLE
|
|
|
|
|
|
|
|
#include "kernel.h"
|
|
|
|
#include "proc.h"
|
2005-05-31 11:50:51 +02:00
|
|
|
#include "ipc.h"
|
2005-04-21 16:53:53 +02:00
|
|
|
#include <minix/com.h>
|
|
|
|
|
2005-08-02 17:28:09 +02:00
|
|
|
/* Define stack sizes for the kernel tasks included in the system image. */
|
2005-04-21 16:53:53 +02:00
|
|
|
#define NO_STACK 0
|
2006-07-25 11:38:24 +02:00
|
|
|
#define SMALL_STACK (256 * sizeof(char *))
|
2005-08-04 11:26:36 +02:00
|
|
|
#define IDL_S SMALL_STACK /* 3 intr, 3 temps, 4 db for Intel */
|
|
|
|
#define HRD_S NO_STACK /* dummy task, uses kernel stack */
|
|
|
|
#define TSK_S SMALL_STACK /* system and clock task */
|
2005-04-21 16:53:53 +02:00
|
|
|
|
|
|
|
/* Stack space for all the task stacks. Declared as (char *) to align it. */
|
2005-08-04 11:26:36 +02:00
|
|
|
#define TOT_STACK_SPACE (IDL_S + HRD_S + (2 * TSK_S))
|
2005-04-21 16:53:53 +02:00
|
|
|
PUBLIC char *t_stack[TOT_STACK_SPACE / sizeof(char *)];
|
|
|
|
|
2005-08-02 17:28:09 +02:00
|
|
|
/* Define flags for the various process types. */
|
2005-08-23 13:31:32 +02:00
|
|
|
#define IDL_F (SYS_PROC | PREEMPTIBLE | BILLABLE) /* idle task */
|
|
|
|
#define TSK_F (SYS_PROC) /* kernel tasks */
|
|
|
|
#define SRV_F (SYS_PROC | PREEMPTIBLE) /* system services */
|
2009-05-12 13:35:01 +02:00
|
|
|
#define USR_F (BILLABLE | PREEMPTIBLE | PROC_FULLVM) /* user processes */
|
2008-12-11 15:21:47 +01:00
|
|
|
#define SVM_F (SRV_F | PROC_FULLVM) /* servers with VM */
|
2005-08-02 17:28:09 +02:00
|
|
|
|
|
|
|
/* Define system call traps for the various process types. These call masks
|
|
|
|
* determine what system call traps a process is allowed to make.
|
|
|
|
*/
|
2005-08-04 11:26:36 +02:00
|
|
|
#define TSK_T (1 << RECEIVE) /* clock and system */
|
|
|
|
#define SRV_T (~0) /* system services */
|
2007-04-23 15:46:26 +02:00
|
|
|
#define USR_T ((1 << SENDREC)) /* user processes */
|
2005-08-02 17:28:09 +02:00
|
|
|
|
2005-08-03 18:06:35 +02:00
|
|
|
/* Send masks determine to whom processes can send messages or notifications.
|
|
|
|
* The values here are used for the processes in the boot image. We rely on
|
2009-07-02 18:25:31 +02:00
|
|
|
* the boot image table itself to match the order of the process numbers, so
|
|
|
|
* that the send mask that is defined here can be interpreted properly.
|
|
|
|
* Privilege structure 0 is shared by user processes.
|
2005-08-03 18:06:35 +02:00
|
|
|
*/
|
2006-06-20 11:56:06 +02:00
|
|
|
#define s(n) (1 << (s_nr_to_id(n)))
|
2005-09-30 14:54:59 +02:00
|
|
|
#define SRV_M (~0)
|
|
|
|
#define SYS_M (~0)
|
2009-07-02 18:25:31 +02:00
|
|
|
#define USR_M (s(PM_PROC_NR) | s(FS_PROC_NR) | s(RS_PROC_NR) | s(VM_PROC_NR))
|
|
|
|
#define DRV_M (USR_M | s(SYSTEM) | s(DS_PROC_NR) | s(LOG_PROC_NR) | s(TTY_PROC_NR))
|
2005-08-03 18:06:35 +02:00
|
|
|
|
2005-08-04 21:23:03 +02:00
|
|
|
/* Define kernel calls that processes are allowed to make. This is not looking
|
2005-08-05 11:41:15 +02:00
|
|
|
* very nice, but we need to define the access rights on a per call basis.
|
2005-10-02 21:02:05 +02:00
|
|
|
* Note that the reincarnation server has all bits on, because it should
|
2005-08-04 21:23:03 +02:00
|
|
|
* be allowed to distribute rights to services that it starts.
|
2006-06-20 11:56:06 +02:00
|
|
|
*
|
|
|
|
* Calls are unordered lists, converted by the kernel to bitmasks
|
|
|
|
* once at runtime.
|
2005-08-04 21:23:03 +02:00
|
|
|
*/
|
2006-06-20 11:56:06 +02:00
|
|
|
#define FS_C SYS_KILL, SYS_VIRCOPY, SYS_SAFECOPYFROM, SYS_SAFECOPYTO, \
|
|
|
|
SYS_VIRVCOPY, SYS_UMAP, SYS_GETINFO, SYS_EXIT, SYS_TIMES, SYS_SETALARM, \
|
2009-01-26 18:43:59 +01:00
|
|
|
SYS_PRIVCTL, SYS_TRACE , SYS_SETGRANT, SYS_PROFBUF, SYS_SYSCTL
|
2006-06-20 11:56:06 +02:00
|
|
|
#define DRV_C FS_C, SYS_SEGCTL, SYS_IRQCTL, SYS_INT86, SYS_DEVIO, \
|
2009-01-26 18:43:59 +01:00
|
|
|
SYS_SDEVIO, SYS_VDEVIO, SYS_SETGRANT, SYS_PROFBUF, SYS_SYSCTL
|
2006-06-20 11:56:06 +02:00
|
|
|
|
|
|
|
PRIVATE int
|
|
|
|
fs_c[] = { FS_C },
|
|
|
|
pm_c[] = { SYS_ALL_CALLS },
|
|
|
|
rs_c[] = { SYS_ALL_CALLS },
|
|
|
|
ds_c[] = { SYS_ALL_CALLS },
|
2008-11-19 13:26:10 +01:00
|
|
|
vm_c[] = { SYS_ALL_CALLS },
|
2006-06-20 11:56:06 +02:00
|
|
|
drv_c[] = { DRV_C },
|
2008-11-19 13:26:10 +01:00
|
|
|
tty_c[] = { DRV_C, SYS_PHYSCOPY, SYS_ABORT, SYS_IOPENABLE,
|
2007-03-22 17:15:33 +01:00
|
|
|
SYS_READBIOS },
|
2008-11-19 13:26:10 +01:00
|
|
|
mem_c[] = { DRV_C, SYS_PHYSCOPY, SYS_PHYSVCOPY, SYS_IOPENABLE };
|
2005-04-21 16:53:53 +02:00
|
|
|
|
|
|
|
/* The system image table lists all programs that are part of the boot image.
|
|
|
|
* The order of the entries here MUST agree with the order of the programs
|
2009-07-02 18:25:31 +02:00
|
|
|
* in the boot image and all kernel tasks must come first. Furthermore, the
|
|
|
|
* order of the entries MUST agree with their process numbers. See above.
|
2006-03-10 17:10:05 +01:00
|
|
|
*
|
|
|
|
* Each entry provides the process number, flags, quantum size, scheduling
|
2005-08-02 17:28:09 +02:00
|
|
|
* queue, allowed traps, ipc mask, and a name for the process table. The
|
|
|
|
* initial program counter and stack size is also provided for kernel tasks.
|
2006-03-10 17:10:05 +01:00
|
|
|
*
|
|
|
|
* Note: the quantum size must be positive in all cases!
|
2005-04-21 16:53:53 +02:00
|
|
|
*/
|
2006-06-20 11:56:06 +02:00
|
|
|
#define c(calls) calls, (sizeof(calls) / sizeof((calls)[0]))
|
|
|
|
#define no_c { 0 }, 0
|
|
|
|
|
2005-07-29 17:26:23 +02:00
|
|
|
PUBLIC struct boot_image image[] = {
|
2006-06-20 11:56:06 +02:00
|
|
|
/* process nr, pc,flags, qs, queue, stack, traps, ipcto, call, name */
|
|
|
|
{IDLE, idle_task,IDL_F, 8, IDLE_Q, IDL_S, 0, 0, no_c,"idle" },
|
|
|
|
{CLOCK,clock_task,TSK_F, 8, TASK_Q, TSK_S, TSK_T, 0, no_c,"clock" },
|
|
|
|
{SYSTEM, sys_task,TSK_F, 8, TASK_Q, TSK_S, TSK_T, 0, no_c,"system"},
|
|
|
|
{HARDWARE, 0,TSK_F, 8, TASK_Q, HRD_S, 0, 0, no_c,"kernel"},
|
2009-05-12 13:35:01 +02:00
|
|
|
{PM_PROC_NR, 0,SVM_F, 32, 4, 0, SRV_T, SRV_M, c(pm_c),"pm" },
|
|
|
|
{FS_PROC_NR, 0,SVM_F, 32, 5, 0, SRV_T, SRV_M, c(fs_c),"vfs" },
|
|
|
|
{RS_PROC_NR, 0,SVM_F, 4, 4, 0, SRV_T, SYS_M, c(rs_c),"rs" },
|
2008-12-11 15:21:47 +01:00
|
|
|
{MEM_PROC_NR, 0,SVM_F, 4, 3, 0, SRV_T, SYS_M,c(mem_c),"memory"},
|
2009-05-12 13:35:01 +02:00
|
|
|
{LOG_PROC_NR, 0,SVM_F, 4, 2, 0, SRV_T, SYS_M,c(drv_c),"log" },
|
2009-07-02 18:25:31 +02:00
|
|
|
{TTY_PROC_NR, 0,SVM_F, 4, 1, 0, SRV_T, SYS_M,c(tty_c),"tty" },
|
|
|
|
{DS_PROC_NR, 0,SVM_F, 4, 4, 0, SRV_T, SYS_M, c(ds_c),"ds" },
|
2008-12-11 15:21:47 +01:00
|
|
|
{MFS_PROC_NR, 0,SVM_F, 32, 5, 0, SRV_T, SRV_M, c(fs_c),"mfs" },
|
|
|
|
{VM_PROC_NR, 0,SRV_F, 32, 2, 0, SRV_T, SRV_M, c(vm_c),"vm" },
|
2006-06-20 11:56:06 +02:00
|
|
|
{INIT_PROC_NR, 0,USR_F, 8, USER_Q, 0, USR_T, USR_M, no_c,"init" },
|
2005-04-21 16:53:53 +02:00
|
|
|
};
|
|
|
|
|
2005-08-04 21:23:03 +02:00
|
|
|
/* Verify the size of the system image table at compile time. Also verify that
|
|
|
|
* the first chunk of the ipc mask has enough bits to accommodate the processes
|
|
|
|
* in the image.
|
|
|
|
* If a problem is detected, the size of the 'dummy' array will be negative,
|
|
|
|
* causing a compile time error. Note that no space is actually allocated
|
|
|
|
* because 'dummy' is declared extern.
|
|
|
|
*/
|
2005-08-29 18:47:18 +02:00
|
|
|
extern int dummy[(NR_BOOT_PROCS==sizeof(image)/
|
|
|
|
sizeof(struct boot_image))?1:-1];
|
2005-08-04 21:23:03 +02:00
|
|
|
extern int dummy[(BITCHUNK_BITS > NR_BOOT_PROCS - 1) ? 1 : -1];
|
|
|
|
|
2008-02-22 13:25:44 +01:00
|
|
|
PUBLIC endpoint_t ipc_stats_target= NONE;
|