xv6-riscv-kernel/proc.h

78 lines
2 KiB
C
Raw Normal View History

2006-06-12 17:22:12 +02:00
/*
* p->mem:
* text
* original data and bss
* fixed-size stack
* expandable heap
*/
/*
* segments in proc->gdt
*/
#define SEG_KCODE 1 // kernel code
#define SEG_KDATA 2 // kernel data+stack
#define SEG_UCODE 3
#define SEG_UDATA 4
#define SEG_TSS 5 // this process's task state
#define NSEGS 6
2006-07-11 03:07:40 +02:00
struct jmpbuf {
// saved registers for kernel context switches
// don't need to save all the fs etc. registers because
// they are constant across kernel contexts
// save all the regular registers so we don't care which are caller save
// don't save eax because that's the return register
// layout known to swtch.S
int jb_ebx;
int jb_ecx;
int jb_edx;
int jb_esi;
int jb_edi;
int jb_esp;
int jb_ebp;
int jb_eip;
};
enum proc_state { UNUSED, EMBRYO, WAITING, RUNNABLE, RUNNING, ZOMBIE };
2006-06-12 17:22:12 +02:00
struct proc{
char *mem; // start of process's physical memory
unsigned sz; // total size of mem, including kernel stack
char *kstack; // kernel stack, separate from mem so it doesn't move
enum proc_state state;
enum proc_state newstate; // desired state after swtch()
2006-06-15 21:58:01 +02:00
int pid;
int ppid;
void *chan; // sleep
int killed;
int locks; // # of locks currently held
2006-06-27 16:35:53 +02:00
struct fd *fds[NOFILE];
2006-06-12 17:22:12 +02:00
struct Taskstate ts; // only to give cpu address of kernel stack
struct Segdesc gdt[NSEGS];
struct Pseudodesc gdt_pd;
unsigned esp; // kernel stack pointer
unsigned ebp; // kernel frame pointer
2006-07-11 03:07:40 +02:00
struct jmpbuf jmpbuf;
2006-06-12 17:22:12 +02:00
struct Trapframe *tf; // points into kstack, used to find user regs
};
extern struct proc proc[];
2006-07-11 03:07:40 +02:00
extern struct proc *curproc[NCPU]; // can be NULL if no proc running.
// XXX move curproc into cpu structure?
#define MPSTACK 512
struct cpu {
uint8_t apicid; // Local APIC ID
2006-07-11 03:07:40 +02:00
struct jmpbuf jmpbuf;
char mpstack[MPSTACK]; // per-cpu start-up stack, only used to get into main()
2006-07-11 03:07:40 +02:00
struct proc *lastproc; // last proc scheduled on this cpu (never NULL)
int clis; // cli() nesting depth
};
extern struct cpu cpus[NCPU];
extern int ncpu;