⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cirrus.h

📁 linux2.6.16版本
💻 H
字号:
/**************************************************************************** *******                                                              ******* *******		CIRRUS.H				      ******* *******                                                              ******* **************************************************************************** Author  : Jeremy Rolls Date    : 3 Aug 1990 * *  (C) 1990 - 2000 Specialix International Ltd., Byfleet, Surrey, UK. * *      This program is free software; you can redistribute it and/or modify *      it under the terms of the GNU General Public License as published by *      the Free Software Foundation; either version 2 of the License, or *      (at your option) any later version. * *      This program is distributed in the hope that it will be useful, *      but WITHOUT ANY WARRANTY; without even the implied warranty of *      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *      GNU General Public License for more details. * *      You should have received a copy of the GNU General Public License *      along with this program; if not, write to the Free Software *      Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Version : 0.01                            Mods ----------------------------------------------------------------------------  Date     By                Description ---------------------------------------------------------------------------- ***************************************************************************/#ifndef _cirrus_h#ifndef lint/* static char* _cirrus_h_sccs = "@(#)cirrus.h	1.16"; */#endif#define _cirrus_h 1/* Bit fields for particular registers *//* GCR */#define GCR_SERIAL	0x00	/* Configure as serial channel */#define GCR_PARALLEL	0x80	/* Configure as parallel channel *//* RDSR - when status read from FIFO */#define	RDSR_BREAK		0x08	/* Break received */#define RDSR_TIMEOUT    	0x80	/* No new data timeout */#define RDSR_SC1  	  	0x10	/* Special char 1 (tx XON) matched */#define RDSR_SC2  	  	0x20	/* Special char 2 (tx XOFF) matched */#define RDSR_SC12_MASK	  	0x30	/* Mask for special chars 1 and 2 *//* PPR */#define PPR_DEFAULT	0x31	/* Default value - for a 25Mhz clock gives				   a timeout period of 1ms *//* LIVR */#define	LIVR_EXCEPTION	0x07	/* Receive exception interrupt *//* CCR */#define	CCR_RESET	0x80	/* Reset channel */#define	CCR_CHANGE	0x4e	/* COR's have changed - NB always change all				   COR's */#define	CCR_WFLUSH	0x82	/* Flush transmit FIFO and TSR / THR */#define	CCR_SENDSC1	0x21	/* Send special character one */#define CCR_SENDSC2	0x22	/* Send special character two */#define CCR_SENDSC3	0x23	/* Send special character three */#define CCR_SENDSC4	0x24	/* Send special character four */#define CCR_TENABLE	0x18	/* Enable transmitter */#define	CCR_TDISABLE	0x14	/* Disable transmitter */#define CCR_RENABLE	0x12	/* Enable receiver */#define CCR_RDISABLE	0x11	/* Disable receiver */#define	CCR_READY	0x00	/* CCR is ready for another command *//* CCSR */#define CCSR_TXENABLE	0x08	/* Transmitter enable */#define CCSR_RXENABLE	0x80	/* Receiver enable */#define CCSR_TXFLOWOFF	0x04	/* Transmit flow off */#define CCSR_TXFLOWON	0x02	/* Transmit flow on *//* SVRR */#define	SVRR_RECEIVE	0x01	/* Receive interrupt pending */#define	SVRR_TRANSMIT	0x02	/* Transmit interrupt pending */#define	SVRR_MODEM	0x04	/* Modem interrupt pending *//* CAR */#define CAR_PORTS	0x03	/* Bit fields for ports *//* IER */#define	IER_MODEM	0x80	/* Change in modem status */#define	IER_RECEIVE	0x10	/* Good data / data exception */#define IER_TRANSMITR	0x04	/* Transmit ready (FIFO empty) */#define	IER_TRANSMITE	0x02	/* Transmit empty */#define IER_TIMEOUT	0x01	/* Timeout on no data */#define	IER_DEFAULT	0x94	/* Default values */#define IER_PARALLEL    0x84	/* Default for Parallel */#define	IER_EMPTY	0x92	/* Transmitter empty rather than ready *//* COR1 - Driver only */#define	COR1_INPCK	0x10	/* Check parity of received characters *//* COR1 - driver and RTA */#define	COR1_ODD	0x80	/* Odd parity */#define COR1_EVEN	0x00	/* Even parity */#define	COR1_NOP	0x00	/* No parity */#define	COR1_FORCE	0x20	/* Force parity */#define	COR1_NORMAL	0x40	/* With parity */#define	COR1_1STOP	0x00	/* 1 stop bit */#define	COR1_15STOP	0x04	/* 1.5 stop bits */#define	COR1_2STOP	0x08	/* 2 stop bits */#define	COR1_5BITS	0x00	/* 5 data bits */#define	COR1_6BITS	0x01	/* 6 data bits */#define	COR1_7BITS	0x02	/* 7 data bits */#define	COR1_8BITS	0x03	/* 8 data bits */#define COR1_HOST       0xef	/* Safe host bits *//* RTA only */#define COR1_CINPCK     0x00	/* Check parity of received characters */#define COR1_CNINPCK    0x10	/* Don't check parity *//* COR2 bits for both RTA and driver use */#define	COR2_IXANY	0x80	/* IXANY - any character is XON */#define	COR2_IXON	0x40	/* IXON - enable tx soft flowcontrol */#define	COR2_RTSFLOW	0x02	/* Enable tx hardware flow control *//* Additional driver bits */#define	COR2_HUPCL	0x20	/* Hang up on close */#define	COR2_CTSFLOW	0x04	/* Enable rx hardware flow control */#define	COR2_IXOFF	0x01	/* Enable rx software flow control */#define COR2_DTRFLOW	0x08	/* Enable tx hardware flow control *//* RTA use only */#define COR2_ETC	0x20	/* Embedded transmit options */#define	COR2_LOCAL	0x10	/* Local loopback mode */#define	COR2_REMOTE	0x08	/* Remote loopback mode */#define	COR2_HOST	0xc2	/* Safe host bits *//* COR3 - RTA use only */#define	COR3_SCDRNG	0x80	/* Enable special char detect for range */#define	COR3_SCD34	0x40	/* Special character detect for SCHR's 3 + 4 */#define	COR3_FCT	0x20	/* Flow control transparency */#define	COR3_SCD12	0x10	/* Special character detect for SCHR's 1 + 2 */#define	COR3_FIFO12	0x0c	/* 12 chars for receive FIFO threshold */#define COR3_FIFO10     0x0a	/* 10 chars for receive FIFO threshold */#define COR3_FIFO8      0x08	/* 8 chars for receive FIFO threshold */#define COR3_FIFO6      0x06	/* 6 chars for receive FIFO threshold */#define COR3_THRESHOLD  COR3_FIFO8	/* MUST BE LESS THAN MCOR_THRESHOLD */#define	COR3_DEFAULT	(COR3_FCT | COR3_THRESHOLD)				/* Default bits for COR3 *//* COR4 driver and RTA use */#define	COR4_IGNCR	0x80	/* Throw away CR's on input */#define	COR4_ICRNL	0x40	/* Map CR -> NL on input */#define	COR4_INLCR	0x20	/* Map NL -> CR on input */#define	COR4_IGNBRK	0x10	/* Ignore Break */#define	COR4_NBRKINT	0x08	/* No interrupt on break (-BRKINT) */#define COR4_RAISEMOD	0x01	/* Raise modem output lines on non-zero baud *//* COR4 driver only */#define COR4_IGNPAR	0x04	/* IGNPAR (ignore characters with errors) */#define COR4_PARMRK	0x02	/* PARMRK */#define COR4_HOST	0xf8	/* Safe host bits *//* COR4 RTA only */#define COR4_CIGNPAR	0x02	/* Thrown away bad characters */#define COR4_CPARMRK	0x04	/* PARMRK characters */#define COR4_CNPARMRK	0x03	/* Don't PARMRK *//* COR5 driver and RTA use */#define	COR5_ISTRIP	0x80	/* Strip input chars to 7 bits */#define	COR5_LNE	0x40	/* Enable LNEXT processing */#define	COR5_CMOE	0x20	/* Match good and errored characters */#define	COR5_ONLCR	0x02	/* NL -> CR NL on output */#define	COR5_OCRNL	0x01	/* CR -> NL on output *//*** Spare bits - these are not used in the CIRRUS registers, so we use** them to set various other features.*//*** tstop and tbusy indication*/#define	COR5_TSTATE_ON	0x08	/* Turn on monitoring of tbusy and tstop */#define	COR5_TSTATE_OFF	0x04	/* Turn off monitoring of tbusy and tstop *//*** TAB3*/#define	COR5_TAB3	0x10	/* TAB3 mode */#define	COR5_HOST	0xc3	/* Safe host bits *//* CCSR */#define	CCSR_TXFLOFF	0x04	/* Tx is xoffed *//* MSVR1 *//* NB. DTR / CD swapped from Cirrus spec as the pins are also reversed on the   RTA. This is because otherwise DCD would get lost on the 1 parallel / 3   serial option.*/#define	MSVR1_CD	0x80	/* CD (DSR on Cirrus) */#define	MSVR1_RTS	0x40	/* RTS (CTS on Cirrus) */#define	MSVR1_RI	0x20	/* RI */#define	MSVR1_DTR	0x10	/* DTR (CD on Cirrus) */#define	MSVR1_CTS	0x01	/* CTS output pin (RTS on Cirrus) *//* Next two used to indicate state of tbusy and tstop to driver */#define	MSVR1_TSTOP	0x08	/* Set if port flow controlled */#define	MSVR1_TEMPTY	0x04	/* Set if port tx buffer empty */#define	MSVR1_HOST	0xf3	/* The bits the host wants *//* MSVR2 */#define	MSVR2_DSR	0x02	/* DSR output pin (DTR on Cirrus) *//* MCOR */#define	MCOR_CD	        0x80	/* CD (DSR on Cirrus) */#define	MCOR_RTS	0x40	/* RTS (CTS on Cirrus) */#define	MCOR_RI	        0x20	/* RI */#define	MCOR_DTR	0x10	/* DTR (CD on Cirrus) */#define MCOR_DEFAULT    (MCOR_CD | MCOR_RTS | MCOR_RI | MCOR_DTR)#define MCOR_FULLMODEM  MCOR_DEFAULT#define MCOR_RJ45       (MCOR_CD | MCOR_RTS | MCOR_DTR)#define MCOR_RESTRICTED (MCOR_CD | MCOR_RTS)/* More MCOR - H/W Handshake (flowcontrol) stuff */#define	MCOR_THRESH8	0x08	/* eight characters then we stop */#define	MCOR_THRESH9	0x09	/* nine characters then we stop */#define	MCOR_THRESH10	0x0A	/* ten characters then we stop */#define	MCOR_THRESH11	0x0B	/* eleven characters then we stop */#define	MCOR_THRESHBITS 0x0F	/* mask for ANDing out the above */#define	MCOR_THRESHOLD	MCOR_THRESH9	/* MUST BE GREATER THAN COR3_THRESHOLD *//* RTPR */#define RTPR_DEFAULT	0x02	/* Default *//* Defines for the subscripts of a CONFIG packet */#define	CONFIG_COR1	1	/* Option register 1 */#define	CONFIG_COR2	2	/* Option register 2 */#define	CONFIG_COR4	3	/* Option register 4 */#define	CONFIG_COR5	4	/* Option register 5 */#define	CONFIG_TXXON	5	/* Tx XON character */#define	CONFIG_TXXOFF	6	/* Tx XOFF character */#define	CONFIG_RXXON	7	/* Rx XON character */#define	CONFIG_RXXOFF	8	/* Rx XOFF character */#define CONFIG_LNEXT	9	/* LNEXT character */#define	CONFIG_TXBAUD	10	/* Tx baud rate */#define	CONFIG_RXBAUD	11	/* Rx baud rate *//* Port status stuff */#define	IDLE_CLOSED	0	/* Closed */#define IDLE_OPEN	1	/* Idle open */#define IDLE_BREAK	2	/* Idle on break *//* Subscript of MODEM STATUS packet */#define	MODEM_VALUE	3	/* Current values of handshake pins *//* Subscript of SBREAK packet */#define BREAK_LENGTH	1	/* Length of a break in slices of 0.01 seconds				   0 = stay on break until an EBREAK command				   is sent */#define	PRE_EMPTIVE	0x80	/* Pre-emptive bit in command field *//* Packet types going from Host to remote - with the exception of OPEN, MOPEN,   CONFIG, SBREAK and MEMDUMP the remaining bytes of the data array will not   be used */#define	OPEN		0x00	/* Open a port */#define CONFIG		0x01	/* Configure a port */#define	MOPEN		0x02	/* Modem open (block for DCD) */#define	CLOSE		0x03	/* Close a port */#define	WFLUSH		(0x04 | PRE_EMPTIVE)	/* Write flush */#define	RFLUSH		(0x05 | PRE_EMPTIVE)	/* Read flush */#define	RESUME		(0x06 | PRE_EMPTIVE)	/* Resume if xoffed */#define	SBREAK		0x07	/* Start break */#define	EBREAK		0x08	/* End break */#define	SUSPEND		(0x09 | PRE_EMPTIVE)	/* Susp op (behave as tho xoffed) */#define FCLOSE          (0x0a | PRE_EMPTIVE)	/* Force close */#define XPRINT          0x0b	/* Xprint packet */#define MBIS		(0x0c | PRE_EMPTIVE)	/* Set modem lines */#define MBIC		(0x0d | PRE_EMPTIVE)	/* Clear modem lines */#define MSET		(0x0e | PRE_EMPTIVE)	/* Set modem lines */#define PCLOSE		0x0f	/* Pseudo close - Leaves rx/tx enabled */#define MGET		(0x10 | PRE_EMPTIVE)	/* Force update of modem status */#define MEMDUMP		(0x11 | PRE_EMPTIVE)	/* Send back mem from addr supplied */#define	READ_REGISTER	(0x12 | PRE_EMPTIVE)	/* Read CD1400 register (debug) *//* "Command" packets going from remote to host COMPLETE and MODEM_STATUS   use data[4] / data[3] to indicate current state and modem status respectively*/#define	COMPLETE	(0x20 | PRE_EMPTIVE)				/* Command complete */#define BREAK_RECEIVED	(0x21 | PRE_EMPTIVE)				/* Break received */#define MODEM_STATUS	(0x22 | PRE_EMPTIVE)				/* Change in modem status *//* "Command" packet that could go either way - handshake wake-up */#define HANDSHAKE	(0x23 | PRE_EMPTIVE)				/* Wake-up to HOST / RTA */#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -