## diffname alphapc/io.h 1999/0415
## diff -e /dev/null /n/emeliedump/1999/0415/sys/src/brazil/alphapc/io.h
0a
enum {
Uart0 = 0x3F8,
Uart1 = 0x2F8,
UartFREQ = 1843200,
};
enum {
/* VectorPIC = 32, /* external i8259 interrupts */
IrqCLOCK = 0,
IrqKBD = 1,
IrqUART1 = 3,
IrqUART0 = 4,
IrqPCMCIA = 5,
IrqFLOPPY = 6,
IrqLPT = 7,
IrqIRQ7 = 7,
IrqAUX = 12, /* PS/2 port */
IrqIRQ13 = 13, /* coprocessor on 386 */
IrqATA0 = 14,
MaxIrqPIC = 15,
/* deprecated: */
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, /* corocessor on x386 */
VectorATA0 = VectorPIC+14,
MaxVectorPIC = VectorPIC+15,
VectorPCI = 16, /* PCI bus (PLD) */
};
typedef struct Irq {
void (*f)(Ureg*, void*); /* handler to call */
void* a; /* argument to call it with */
Irq* next; /* link to next handler */
} Irq;
typedef struct Irqctl {
int (*isr)(int); /* get isr bit for this irq */
int (*eoi)(int); /* eoi */
int isintr;
Irq* irq; /* handlers on this IRQ */
} Irqctl;
enum {
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 BUSDF(tbdf) ((tbdf)&0x000FF00)
#define BUSBDF(tbdf) ((tbdf)&0x0FFFF00)
#define BUSUNKNOWN (-1)
enum {
MaxEISA = 16,
EISAconfig = 0xC80,
};
/*
* PCI support code.
*/
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 */
PciBAR0 = 0x10, /* base address */
PciBAR1 = 0x14,
PciINTL = 0x3C, /* interrupt line */
PciINTP = 0x3D, /* interrupt pin */
};
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, /* xpansion 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 */
ushort vid; /* vendor ID */
ushort did; /* device ID */
struct {
ulong bar; /* base address */
int size;
} mem[3];
uchar intl; /* interrupt line */
ushort ccru;
Pcidev* list;
Pcidev* bridge; /* down a bus */
Pcidev* link; /* next device on this bno */
};
/*
* 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;
};
/*
* SCSI bus
*/
enum {
MaxScsi = 8,
NTarget = 8, /* should be 16... */
};
struct Target {
int ctlrno;
int target;
uchar* inq;
uchar* scratch;
Rendez rendez;
int ok;
};
typedef int (*Scsiio)(Target*, int, uchar*, int, void*, int*);
typedef struct SCSIdev {
char* type;
Scsiio (*reset)(int, ISAConf*);
} SCSIdev;
.
## diffname alphapc/io.h 1999/0423
## diff -e /n/emeliedump/1999/0415/sys/src/brazil/alphapc/io.h /n/emeliedump/1999/0423/sys/src/brazil/alphapc/io.h
204a
#define PCIWINDOW 0x40000000
#define PCIWADDR(va) (PADDR(va)+PCIWINDOW)
.
## diffname alphapc/io.h 1999/0424
## diff -e /n/emeliedump/1999/0423/sys/src/brazil/alphapc/io.h /n/emeliedump/1999/0424/sys/src/brazil/alphapc/io.h
207a
#define ISAWINDOW 0x00800000
#define ISAWADDR(va) (PADDR(va)+ISAWINDOW)
.
## diffname alphapc/io.h 1999/0507
## diff -e /n/emeliedump/1999/0424/sys/src/brazil/alphapc/io.h /n/emeliedump/1999/0507/sys/src/brazil/alphapc/io.h
203c
Scsi* (*pnp)(void);
int (*reset)(Scsi*);
.
200a
Scsi* next;
} Scsi;
.
199c
typedef struct Scsi {
ISAConf;
int ctlrno;
Pcidev* pcidev;
int (*io)(Target*, int, uchar*, int, void*, int*);
void *ctlr;
int ntarget;
.
190c
Scsi* ctlr;
int targetno;
.
188c
typedef struct Scsi Scsi;
typedef struct Target Target;
typedef struct SCSIdev SCSIdev;
typedef struct Target {
.
185,186c
MaxTarget = 16,
.
160d
158c
uchar ccrp;
uchar ccru;
uchar ccrb;
.
155c
} mem[6];
.
## diffname alphapc/io.h 1999/0511
## diff -e /n/emeliedump/1999/0507/sys/src/brazil/alphapc/io.h /n/emeliedump/1999/0511/sys/src/brazil/alphapc/io.h
33c
VectorIRQ13 = VectorPIC+13, /* coprocessor on x386 */
.
## diffname alphapc/io.h 2000/0401
## diff -e /n/emeliedump/1999/0511/sys/src/brazil/alphapc/io.h /n/emeliedump/2000/0401/sys/src/9/alphapc/io.h
107a
PciROM = 0x30,
.
51,52c
void (*f)(Ureg*, void*); /* handler to call */
void* a; /* argument to call it with */
} Vctl;
.
49d
43,46c
char name[NAMELEN]; /* of driver */
int isintr; /* interrupt or fault/trap */
int irq;
int tbdf;
.
39,41c
typedef struct Vctl {
Vctl* next; /* handlers on this vector */
.
22,35c
VectorPIC = 64,
MaxVectorPIC = VectorPIC+MaxIrqPIC,
.
8d
## diffname alphapc/io.h 2000/0407
## diff -e /n/emeliedump/2000/0401/sys/src/9/alphapc/io.h /n/emeliedump/2000/0407/sys/src/9/alphapc/io.h
18a
IrqATA1 = 15,
.
## diffname alphapc/io.h 2000/0515
## diff -e /n/emeliedump/2000/0407/sys/src/9/alphapc/io.h /n/emeliedump/2000/0515/sys/src/9/alphapc/io.h
169,214d
154a
#define PCIWINDOW 0x40000000
#define PCIWADDR(va) (PADDR(va)+PCIWINDOW)
#define ISAWINDOW 0x00800000
#define ISAWADDR(va) (PADDR(va)+ISAWINDOW)
.
152a
Pcidev* bridge; /* down a bus */
struct {
ulong bar;
int size;
} ioa, mema;
ulong pcr;
.
151d
146,148d
139a
uchar rid;
uchar ccrp;
uchar ccru;
uchar ccrb;
.
136c
int tbdf; /* type+bus+device+function */
.
## diffname alphapc/io.h 2001/0727
## diff -e /n/emeliedump/2000/0515/sys/src/9/alphapc/io.h /n/emeliedump/2001/0727/sys/src/9/alphapc/io.h
30c
char name[KNAMELEN]; /* of driver */
.
2,7d
|