xref: /openbsd/sys/dev/ic/comvar.h (revision db3296cf)
1 /*	$OpenBSD: comvar.h,v 1.33 2003/07/15 03:15:58 jason Exp $	*/
2 /*	$NetBSD: comvar.h,v 1.5 1996/05/05 19:50:47 christos Exp $	*/
3 
4 /*
5  * Copyright (c) 1997 - 1998, Jason Downs.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS
17  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19  * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT,
20  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
22  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
23  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26  * SUCH DAMAGE.
27  */
28 /*
29  * Copyright (c) 1996 Christopher G. Demetriou.  All rights reserved.
30  *
31  * Redistribution and use in source and binary forms, with or without
32  * modification, are permitted provided that the following conditions
33  * are met:
34  * 1. Redistributions of source code must retain the above copyright
35  *    notice, this list of conditions and the following disclaimer.
36  * 2. Redistributions in binary form must reproduce the above copyright
37  *    notice, this list of conditions and the following disclaimer in the
38  *    documentation and/or other materials provided with the distribution.
39  * 3. All advertising materials mentioning features or use of this software
40  *    must display the following acknowledgement:
41  *      This product includes software developed by Christopher G. Demetriou
42  *	for the NetBSD Project.
43  * 4. The name of the author may not be used to endorse or promote products
44  *    derived from this software without specific prior written permission
45  *
46  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
47  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
48  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
49  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
50  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
51  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
52  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
53  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
54  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
55  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
56  */
57 
58 #include <sys/timeout.h>
59 
60 struct commulti_attach_args {
61 	int		ca_slave;		/* slave number */
62 
63 	bus_space_tag_t ca_iot;
64 	bus_space_handle_t ca_ioh;
65 	int		ca_iobase;
66 	int		ca_noien;
67 };
68 
69 #define	COM_IBUFSIZE	(2 * 512)
70 #define	COM_IHIGHWATER	((3 * COM_IBUFSIZE) / 4)
71 
72 struct com_softc {
73 	struct device sc_dev;
74 	void *sc_ih;
75 	bus_space_tag_t sc_iot;
76 	struct tty *sc_tty;
77 	struct timeout sc_dtr_tmo;
78 	struct timeout sc_diag_tmo;
79 #ifdef __HAVE_GENERIC_SOFT_INTERRUPTS
80 	void *sc_si;
81 #else
82 	struct timeout sc_poll_tmo;
83 #endif
84 
85 	int sc_overflows;
86 	int sc_floods;
87 	int sc_errors;
88 
89 	int sc_halt;
90 
91 	int sc_iobase;
92 	int sc_frequency;
93 
94 	bus_space_handle_t sc_ioh;
95 
96 	u_char sc_uarttype;
97 #define COM_UART_UNKNOWN	0x00		/* unknown */
98 #define COM_UART_8250		0x01		/* no fifo */
99 #define COM_UART_16450		0x02		/* no fifo */
100 #define COM_UART_16550		0x03		/* no working fifo */
101 #define COM_UART_16550A		0x04		/* 16 byte fifo */
102 #define COM_UART_ST16650	0x05		/* no working fifo */
103 #define COM_UART_ST16650V2	0x06		/* 32 byte fifo */
104 #define COM_UART_TI16750	0x07		/* 64 byte fifo */
105 #define	COM_UART_XR16850	0x10		/* 128 byte fifo */
106 
107 	u_char sc_hwflags;
108 #define	COM_HW_NOIEN	0x01
109 #define	COM_HW_FIFO	0x02
110 #define	COM_HW_CONSOLE	0x40
111 #define	COM_HW_KGDB	0x80
112 	u_char sc_swflags;
113 #define	COM_SW_SOFTCAR	0x01
114 #define	COM_SW_CLOCAL	0x02
115 #define	COM_SW_CRTSCTS	0x04
116 #define	COM_SW_MDMBUF	0x08
117 #define	COM_SW_PPS	0x10
118 	int	sc_fifolen;
119 	u_char sc_msr, sc_mcr, sc_lcr, sc_ier;
120 	u_char sc_dtr;
121 
122 	u_char	sc_cua;
123 
124 	u_char	sc_initialize;		/* force initialization */
125 
126 	u_char *sc_ibuf, *sc_ibufp, *sc_ibufhigh, *sc_ibufend;
127 	u_char sc_ibufs[2][COM_IBUFSIZE];
128 
129 	/* power management hooks */
130 	int (*enable)(struct com_softc *);
131 	void (*disable)(struct com_softc *);
132 	int enabled;
133 };
134 
135 int	comprobe1(bus_space_tag_t, bus_space_handle_t);
136 void	cominit(bus_space_tag_t, bus_space_handle_t, int);
137 int	comstop(struct tty *, int);
138 int	comintr(void *);
139 int	com_detach(struct device *, int);
140 int	com_activate(struct device *, enum devact);
141 
142 void	comdiag(void *);
143 int	comspeed(long, long);
144 u_char	com_cflag2lcr(tcflag_t);
145 int	comparam(struct tty *, struct termios *);
146 void	comstart(struct tty *);
147 void	compoll(void *);
148 
149 struct consdev;
150 int	comcnattach(bus_space_tag_t, int, int, int, tcflag_t);
151 void	comcnprobe(struct consdev *);
152 void	comcninit(struct consdev *);
153 int	comcngetc(dev_t);
154 void	comcnputc(dev_t, int);
155 void	comcnpollc(dev_t, int);
156 int	com_common_getc(bus_space_tag_t, bus_space_handle_t);
157 void	com_common_putc(bus_space_tag_t, bus_space_handle_t, int);
158 void	com_raisedtr(void *);
159 
160 #ifdef KGDB
161 int	com_kgdb_attach(bus_space_tag_t, int, int, int, tcflag_t);
162 int	kgdbintr(void *);
163 #endif
164 
165 void com_attach_subr(struct com_softc *);
166 
167 extern int comdefaultrate;
168 extern int comconsaddr;
169 extern int comconsinit;
170 extern int comconsattached;
171 extern bus_space_tag_t comconsiot;
172 extern bus_space_handle_t comconsioh;
173 extern tcflag_t comconscflag;
174