typedef struct Conf Conf; typedef struct Confmem Confmem; typedef struct FPsave FPsave; typedef struct ISAConf ISAConf; typedef struct Imap Imap; typedef struct Label Label; typedef struct Lock Lock; typedef struct Mach Mach; typedef struct Notsave Notsave; typedef struct PCArch PCArch; typedef struct PMMU PMMU; typedef struct Page Page; typedef struct Pcidev Pcidev; typedef struct Proc Proc; typedef struct Sys Sys; typedef vlong Tval; typedef struct Ureg Ureg; typedef struct Vctl Vctl; #pragma incomplete Ureg #pragma incomplete Imap #pragma incomplete Mach #define MAXSYSARG 5 /* for mount(fd, mpt, flag, arg, srv) */ /* * parameters for sysproc.c */ #define AOUT_MAGIC Q_MAGIC /* * machine dependent definitions used by ../port/dat.h */ struct Lock { ulong key; /* semaphore (non-zero = locked) */ ulong sr; ulong pc; Proc *p; Mach *m; ulong pid; ushort isilock; }; struct Label { ulong sp; ulong pc; }; /* * Proc.fpstate */ enum { /* Floating point states */ FPinit = 0, FPactive = 1, FPinactive = 2, /* Bit that's or-ed in during note handling (FP is illegal in note handlers) */ FPillegal = 0x100, }; /* * This structure must agree with fpsave and fprestore asm routines */ struct FPsave { double fpreg[32]; union { double fpscrd; struct { ulong pad; ulong fpscr; }; }; }; struct Confmem { ulong base; ulong npage; ulong kbase; ulong klimit; }; struct Conf { ulong nmach; /* processors */ ulong nproc; /* processes */ Confmem mem[2]; ulong npage0; /* total physical pages of memory */ ulong npage1; /* total physical pages of memory */ ulong npage; /* total physical pages of memory */ ulong base0; /* base of bank 0 */ ulong base1; /* base of bank 1 */ ulong upages; /* user page pool */ ulong nimage; /* number of page cache image headers */ ulong nswap; /* number of swap pages */ int nswppo; /* max # of pageouts per segment pass */ ulong copymode; /* 0 is copy on write, 1 is copy on reference */ int monitor; /* has display? */ ulong ialloc; /* bytes available for interrupt time allocation */ ulong pipeqsize; /* size in bytes of pipe queues */ }; /* * mmu goo in the Proc structure */ #define NCOLOR 1 struct PMMU { int mmupid; Ureg *mmureg; /* pointer to ureg structure */ }; /* * things saved in the Proc structure during a notify */ struct Notsave { ulong UNUSED; }; #include "../port/portdat.h" /* * machine dependent definitions not used by ../port/dat.h */ /* * Fake kmap */ typedef void KMap; #define VA(k) ((ulong)(k)) #define kmap(p) (KMap*)((p)->pa|KZERO) #define kunmap(k) struct IMM; typedef struct IMM IMM; struct Mach { /* OFFSETS OF THE FOLLOWING KNOWN BY l.s */ /*0x00*/ int machno; /* physical id of processor */ /*0x04*/ ulong splpc; /* pc that called splhi() */ /*0x08*/ Proc *proc; /* current process on this processor */ /* Debugging/statistics for software TLB in l.s (therefore, also known by l.s) */ /*0x0c*/ ulong tlbfault; /* type of last miss */ /*0x10*/ ulong imiss; /* number of instruction misses */ /*0x14*/ ulong dmiss; /* number of data misses */ /* ordering from here on irrelevant */ Imap* imap; #ifndef ucuconf IMM* immr; #endif ulong ticks; /* of the clock since boot time */ Label sched; /* scheduler wakeup */ Lock alarmlock; /* access to alarm list */ void *alarm; /* alarms bound to this clock */ int inclockintr; int cputype; ulong loopconst; Perf perf; /* performance counters */ Proc* readied; /* for runproc */ ulong schedticks; /* next forced context switch */ ulong clkin; /* basic clock frequency */ ulong vco_out; vlong cpuhz; uvlong cyclefreq; /* Frequency of user readable cycle counter */ ulong bushz; ulong dechz; ulong tbhz; ulong cpmhz; /* communications processor module frequency */ ulong brghz; /* baud rate generator frequency */ ulong pcclast; uvlong fastclock; int tlbpurge; /* # of tlb purges */ int pfault; /* # of page faults */ int cs; int syscall; int load; int intr; int flushmmu; /* make current proc flush it's mmu state */ int ilockdepth; ulong ptabbase; /* start of page table in kernel virtual space */ int slotgen; /* next pte (byte offset) when pteg is full */ int mmupid; /* next mmu pid to use */ int sweepcolor; int trigcolor; Rendez sweepr; ulong spuriousintr; int lastintr; /* MUST BE LAST */ int stack[1]; }; struct { Lock; short machs; short exiting; short ispanic; }active; /* * a parsed plan9.ini line */ #define NISAOPT 8 struct ISAConf { char *type; ulong port; int irq; ulong dma; ulong mem; ulong size; ulong freq; int nopt; char *opt[NISAOPT]; }; struct Vctl { Vctl* next; /* handlers on this vector */ char name[KNAMELEN]; /* of driver */ int isintr; /* interrupt or fault/trap */ int irq; void (*f)(Ureg*, void*); /* handler to call */ void* a; /* argument to call it with */ }; extern Mach mach0; extern register Mach *m; extern register Proc *up; extern FPsave initfp;