/* $OpenBSD: dartreg.h,v 1.6 2006/04/15 22:32:42 miod Exp $ */ #define MAXPORTS 2 /* max count of PORTS/DUART */ #define A_PORT 0 /* flag for port a */ #define B_PORT 1 /* flag for port b */ /* the access to the same command register must be delayed, because the chip has some hardware problems in this case */ #define DELAY_CR do { volatile int i; for (i = 0; i < 250; ++i); } while (0) /*********************** MC68681 DEFINITIONS ************************/ /* mode register 1: MR1x operations */ #define RXRTS 0x80 /* enable receiver RTS */ #define PAREN 0x00 /* with parity */ #define PARDIS 0x10 /* no parity */ #define EVENPAR 0x00 /* even parity */ #define ODDPAR 0x04 /* odd parity */ #define CL5 0x00 /* 5 bits per char */ #define CL6 0x01 /* 6 bits per char */ #define CL7 0x02 /* 7 bits per char */ #define CL8 0x03 /* 8 bits per char */ #define PARMODEMASK 0x18 /* parity mode mask */ #define PARTYPEMASK 0x04 /* parity type mask */ #define CLMASK 0x03 /* character length mask */ /* mode register 2: MR2x operations */ #define TXRTS 0x20 /* enable transmitter RTS */ #define TXCTS 0x10 /* enable transmitter CTS */ #define SB2 0x0f /* 2 stop bits */ #define SB1 0x07 /* 1 stop bit */ #define SB1L5 0x00 /* 1 stop bit at 5 bits per character */ #define SBMASK 0x0f /* stop bit mask */ /* clock-select register: CSRx operations */ #define NOBAUD -1 /* 50 and 200 baud are not possible */ /* they are not in Baud register set 2 */ #define BD75 0x00 /* 75 baud */ #define BD110 0x11 /* 110 baud */ #define BD134 0x22 /* 134.5 baud */ #define BD150 0x33 /* 150 baud */ #define BD300 0x44 /* 300 baud */ #define BD600 0x55 /* 600 baud */ #define BD1200 0x66 /* 1200 baud */ #define BD1800 0xaa /* 1800 baud */ #define BD2400 0x88 /* 2400 baud */ #define BD4800 0x99 /* 4800 baud */ #define BD9600 0xbb /* 9600 baud */ #define BD19200 0xcc /* 19200 baud */ #define DEFBAUD BD9600 /* default value if baudrate is not possible */ /* channel command register: CRx operations */ #define MRRESET 0x10 /* reset mr pointer to mr1 */ #define RXRESET 0x20 /* reset receiver */ #define TXRESET 0x30 /* reset transmitter */ #define ERRRESET 0x40 /* reset error status */ #define BRKINTRESET 0x50 /* reset channel's break interrupt */ #define BRKSTART 0x60 /* start break */ #define BRKSTOP 0x70 /* stop break */ #define TXDIS 0x08 /* disable transmitter */ #define TXEN 0x04 /* enable transmitter */ #define RXDIS 0x02 /* disable receiver */ #define RXEN 0x01 /* enable receiver */ /* status register: SRx status */ #define RBRK 0x80 /* received break */ #define FRERR 0x40 /* frame error */ #define PERR 0x20 /* parity error */ #define ROVRN 0x10 /* receiver overrun error */ #define TXEMT 0x08 /* transmitter empty */ #define TXRDY 0x04 /* transmitter ready */ #define FFULL 0x02 /* receiver FIFO full */ #define RXRDY 0x01 /* receiver ready */ /* output port configuration register: OPCR operations */ #define OPSET 0x00 /* set all op lines to op function */ #define OPSETTO 0x04 /* use OP3 for timer output */ /* output port register: OP operations */ #define OPDTRB 0x20 /* DTR line output b on the VME188, 181, 141 */ #define OPDTRA 0x04 /* DTR line output a */ #define OPRTSB 0x02 /* RTS line output b */ #define OPRTSA 0x01 /* RTS line output a */ /* auxiliary control register: ACR operations */ #define BDSET1 0x00 /* baudrate generator set 1 */ #define BDSET2 0x80 /* baudrate generator set 2 */ #define CCLK1 0x60 /* timer clock: external rate. TA */ #define CCLK16 0x30 /* counter clock: x1 clk divided by 16 */ #define SLCTIM 0x7800/* timer count to get 60 Hz time slice (16.6ms ticks) */ #define IPDCDIB 0x08 /* IP3 change == DCD input on port B */ #define IPDCDIA 0x04 /* IP2 change == DCD input on port A */ /* input port change register: IPCR operations */ #define IPCRDCDB 0x80 /* IP3 change == DCD change on port B */ #define IPCRDCDA 0x40 /* IP2 change == DCD change on port A */ /* Defines for mvme335 */ #define IPDCDB 0x20 /* DCD line input b */ #define IPDCDA 0x10 /* DCD line input a */ #define IPDSRB 0x08 /* DSR line input b */ #define IPDSRA 0x04 /* DSR line input a */ #define IPCTSB 0x02 /* CTS line input b */ #define IPCTSA 0x01 /* CTS line input a */ /* interrupt status and mask register: ISR status and IMR mask */ #define IIPCHG 0x80 /* input port change */ #define IBRKB 0x40 /* delta break b */ #define IRXRDYB 0x20 /* receiver ready b */ #define ITXRDYB 0x10 /* transmitter ready b */ #define ITIMER 0x08 /* Enable timer interrupts. */ #define IBRKA 0x04 /* delta break a */ #define IRXRDYA 0x02 /* receiver ready a */ #define ITXRDYA 0x01 /* transmitter ready a */ /* interrupts from port a or b */ #define AINTPORT ( IRXRDYA | ITXRDYA ) #define BINTPORT ( IRXRDYB | ITXRDYB ) /* HW write register index for ut_wr_regs[] */ #define MR1A 0 /* mode register 1 a */ #define CSRA 1 /* clock-select register a*/ #define CRA 2 /* command register a */ #define TBA 3 /* transmitter buffer a */ #define ACR 4 /* auxiliary control register*/ #define IMR 5 /* interrupt mask register */ #define CTUR 6 /* counter/timer upper reg */ #define CTLR 7 /* counter/timer lower reg */ #define MR1B 8 /* mode register 1 b */ #define CSRB 9 /* clock-select register b*/ #define CRB 10 /* command register b */ #define TBB 11 /* transmitter buffer b */ #define IVR 12 /* interrupt vector register */ #define OPCR 13 /* output port config reg */ #define OPRSET 14 /* output port: bit set cmd */ #define OPRRESET 15 /* output port: bit reset cmd */ #define MR2A 16 /* mode register 2 a */ #define MR2B 17 /* mode register 2 b */ #define MAXREG 18 /* max count of registers */ /* * MC68681 hardware registers. */ #define DART_MR1A 0x00 /* RW: mode register A */ #define DART_MR2A 0x00 /* RW: mode register A */ #define DART_SRA 0x01 /* R: status register A */ #define DART_CSRA 0x01 /* W: clock select register A */ #define DART_CRA 0x02 /* W: command register A */ #define DART_RBA 0x03 /* R: receiver buffer A */ #define DART_TBA 0x03 /* W: transmit buffer A */ #define DART_IPCR 0x04 /* R: input port change register */ #define DART_ACR 0x04 /* W: auxiliary control register */ #define DART_ISR 0x05 /* R: interrupt status register */ #define DART_IMR 0x05 /* W: interrupt mask register */ #define DART_CUR 0x06 /* R: count upper register */ #define DART_CTUR 0x06 /* W: counter/timer upper register */ #define DART_CLR 0x07 /* R: count lower register */ #define DART_CTLR 0x07 /* W: counter/timer lower register */ #define DART_MR1B 0x08 /* RW: mode register B */ #define DART_MR2B 0x08 /* RW: mode register B */ #define DART_SRB 0x09 /* R: status register B */ #define DART_CSRB 0x09 /* W: clock select register B */ #define DART_CRB 0x0a /* W: command register B */ #define DART_RBB 0x0b /* R: receiver buffer B */ #define DART_TBB 0x0b /* W: transmit buffer B */ #define DART_IVR 0x0c /* RW: interrupt vector register */ #define DART_IP 0x0d /* R: input port (unlatched) */ #define DART_OPCR 0x0d /* W: output port configuration register */ #define DART_CTSTART 0x0e /* R: start counter command */ #define DART_OPRS 0x0e /* W: output port bit set */ #define DART_CTSTOP 0x0f /* R: stop counter command */ #define DART_OPRR 0x0f /* W: output port bit reset */ #define DART_A_BASE 0x00 #define DART_B_BASE 0x08