| plan 9 kernel history: overview | file list | diff list |
1997/0327/pc/io.h (diff list | history)
| 1995/0818/sys/src/9/pc/io.h:1,74 – 1997/0327/sys/src/9/pc/io.h:1,153 (short | long | prev | next) | ||
|
Initial SMP support — new vector names, replace PCIcfg with Pcidev, add PCMmap.
rsc Fri Mar 4 12:44:25 2005 | ||
| 1991/0703 |
| |
| 1991/0731 |
| |
| 1991/0703 |
| |
| 1991/0704 |
| |
| 1991/1112 |
| |
| 1991/0906 |
| |
| 1991/0912 |
| |
| 1991/0710 |
| |
| 1997/0327 | #define X86STEPPING(x) ((x) & 0x0F) #define X86MODEL(x) (((x)>>4) & 0x0F) #define X86FAMILY(x) (((x)>>8) & 0x0F) | |
| 1991/0905 | ||
| 1991/0904 |
| |
| 1991/0731 |
| |
| 1991/0810 |
| |
| 1991/0811 |
| |
| 1992/0929 |
| |
| 1991/0731 |
| |
| 1991/1127 |
| |
| 1992/0904 |
| |
| 1994/0908 |
| |
| 1992/0904 |
| |
| 1995/0818 |
| |
| 1997/0327 | enum { VectorBPT = 3, /* breakpoint */ VectorCNA = 7, /* coprocessor not available */ VectorCSO = 9, /* coprocessor segment overrun */ VectorPF = 14, /* page fault */ VectorCERR = 16, /* coprocessor error */ | |
| 1991/0910 |
| |
| 1997/0327 | VectorLAPIC = 32, /* local APIC interrupts */ VectorLINT0 = VectorLAPIC+0,/* LINT[01] must be offsets 0 and 1 */ VectorLINT1 = VectorLAPIC+1, VectorTIMER = VectorLAPIC+2, VectorERROR = VectorLAPIC+3, VectorPCINT = VectorLAPIC+4, VectorSPURIOUS = VectorLAPIC+15,/* must have bits [3-0] == 0x0F */ MaxVectorLAPIC = VectorLAPIC+15, VectorSYSCALL = 64, VectorPIC = 128, /* external [A]PIC interrupts */ VectorCLOCK = VectorPIC+0, VectorKBD = VectorPIC+1, VectorUART1 = VectorPIC+3, VectorUART0 = VectorPIC+4, VectorPCMCIA = VectorPIC+5, VectorFLOPPY = VectorPIC+6, VectorLPT = VectorPIC+7, VectorIRQ7 = VectorPIC+7, VectorAUX = VectorPIC+12, /* PS/2 port */ VectorIRQ13 = VectorPIC+13, /* coprocessor on x386 */ VectorATA0 = VectorPIC+14, MaxVectorPIC = VectorPIC+15, | |
| 1994/0908 | }; enum { | |
| 1997/0327 | BusCBUS = 0, /* Corollary CBUS */ BusCBUSII, /* Corollary CBUS II */ BusEISA, /* Extended ISA */ BusFUTURE, /* IEEE Futurebus */ BusINTERN, /* Internal bus */ BusISA, /* Industry Standard Architecture */ BusMBI, /* Multibus I */ BusMBII, /* Multibus II */ BusMCA, /* Micro Channel Architecture */ BusMPI, /* MPI */ BusMPSA, /* MPSA */ BusNUBUS, /* Apple Macintosh NuBus */ BusPCI, /* Peripheral Component Interconnect */ BusPCMCIA, /* PC Memory Card International Association */ BusTC, /* DEC TurboChannel */ BusVL, /* VESA Local bus */ BusVME, /* VMEbus */ BusXPRESS, /* Express System Bus */ }; #define MKBUS(t,b,d,f) (((t)<<24)|(((b)&0xFF)<<16)|(((d)&0x1F)<<11)|(((f)&0x07)<<8)) #define BUSFNO(tbdf) (((tbdf)>>8)&0x07) #define BUSDNO(tbdf) (((tbdf)>>11)&0x1F) #define BUSBNO(tbdf) (((tbdf)>>16)&0xFF) #define BUSTYPE(tbdf) ((tbdf)>>24) #define BUSBDF(tbdf) ((tbdf)&0x00FFFF00) #define BUSUNKNOWN (-1) enum { | |
| 1994/0908 | MaxEISA = 16, | |
| 1995/0126 | EISAconfig = 0xC80, | |
| 1991/0704 | }; | |
| 1995/0517 | /* | |
| 1997/0327 | * PCI support code. | |
| 1995/0517 | */ | |
| 1997/0327 | enum { /* type 0 and type 1 pre-defined header */ PciVID = 0x00, /* vendor ID */ PciDID = 0x02, /* device ID */ PciPCR = 0x04, /* command */ PciPSR = 0x06, /* status */ PciRID = 0x08, /* revision ID */ PciCCRp = 0x09, /* programming interface class code */ PciCCRu = 0x0A, /* sub-class code */ PciCCRb = 0x0B, /* base class code */ PciCLS = 0x0C, /* cache line size */ PciLTR = 0x0D, /* latency timer */ PciHDT = 0x0E, /* header type */ PciBST = 0x0F, /* BIST */ | |
| 1995/0517 |
| |
| 1995/0726 |
| |
| 1997/0327 | PciBAR0 = 0x10, /* base address */ PciBAR1 = 0x14, PciINTL = 0x3C, /* interrupt line */ PciINTP = 0x3D, /* interrupt pin */ | |
| 1995/0517 | }; | |
| 1997/0327 | enum { /* type 0 pre-defined header */ PciBAR2 = 0x18, PciBAR3 = 0x1C, PciBAR4 = 0x20, PciBAR5 = 0x24, PciCIS = 0x28, /* cardbus CIS pointer */ PciSVID = 0x2C, /* subsystem vendor ID */ PciSID = 0x2E, /* cardbus CIS pointer */ PciEBAR0 = 0x30, /* expansion ROM base address */ PciMGNT = 0x3E, /* burst period length */ PciMLT = 0x3F, /* maximum latency between bursts */ }; enum { /* type 1 pre-defined header */ PciPBN = 0x18, /* primary bus number */ PciSBN = 0x19, /* secondary bus number */ PciUBN = 0x1A, /* subordinate bus number */ PciSLTR = 0x1B, /* secondary latency timer */ PciIBR = 0x1C, /* I/O base */ PciILR = 0x1D, /* I/O limit */ PciSPSR = 0x1E, /* secondary status */ PciMBR = 0x20, /* memory base */ PciMLR = 0x22, /* memory limit */ PciPMBR = 0x24, /* prefetchable memory base */ PciPMLR = 0x26, /* prefetchable memory limit */ PciPUBR = 0x28, /* prefetchable base upper 32 bits */ PciPULR = 0x2C, /* prefetchable limit upper 32 bits */ PciIUBR = 0x30, /* I/O base upper 16 bits */ PciIULR = 0x32, /* I/O limit upper 16 bits */ PciEBAR1 = 0x28, /* expansion ROM base address */ PciBCR = 0x3E, /* bridge control register */ }; typedef struct Pcidev Pcidev; typedef struct Pcidev { int tbdf; /* type+bus+device+function */ | |
| 1995/0517 | ushort vid; /* vendor ID */ ushort did; /* device ID */ | |
| 1997/0327 | ulong bar[2]; /* base address */ uchar intl; /* interrupt line */ Pcidev* next; /* next device on this bno */ } Pcidev; /* * PCMCIA support code. */ /* * Map between ISA memory space and PCMCIA card memory space. */ struct PCMmap { ulong ca; /* card address */ ulong cea; /* card end address */ ulong isa; /* ISA address */ int len; /* length of the ISA area */ int attr; /* attribute memory */ int ref; }; | |