1 /*
2 	usa90msg.h
3 
4 	Copyright (c) 1998-2003 InnoSys Incorporated.  All Rights Reserved
5 	This file is available under a BSD-style copyright
6 
7 	Keyspan USB Async Message Formats for the USA19HS
8 
9 	Redistribution and use in source and binary forms, with or without
10 	modification, are permitted provided that the following conditions are
11 	met:
12 
13 	1. Redistributions of source code must retain this licence text
14    	without modification, this list of conditions, and the following
15    	disclaimer.  The following copyright notice must appear immediately at
16    	the beginning of all source files:
17 
18         	Copyright (c) 1998-2003 InnoSys Incorporated.  All Rights Reserved
19 
20         	This file is available under a BSD-style copyright
21 
22 	2. The name of InnoSys Incorprated may not be used to endorse or promote
23    	products derived from this software without specific prior written
24    	permission.
25 
26 	THIS SOFTWARE IS PROVIDED BY INNOSYS CORP. ``AS IS'' AND ANY EXPRESS OR
27 	IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
28 	OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN
29 	NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
30 	INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
31 	(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
32 	SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
33 	CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34 	LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
35 	OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
36 	SUCH DAMAGE.
37 
38 	Revisions:
39 
40 	2003feb14		add setTxMode/txMode  and cancelRxXoff to portControl
41 	2003mar21		change name of PARITY_0/1 to add MARK/SPACE
42 */
43 
44 #ifndef	__USA90MSG__
45 #define	__USA90MSG__
46 
47 struct keyspan_usa90_portControlMessage
48 {
49 	/*
50 		there are three types of "commands" sent in the control message:
51 
52 		1.	configuration changes which must be requested by setting
53 			the corresponding "set" flag (and should only be requested
54 			when necessary, to reduce overhead on the device):
55 	*/
56 
57 	u8	setClocking,	// host requests baud rate be set
58 		baudLo,			// host does baud divisor calculation
59 		baudHi,			// host does baud divisor calculation
60 
61 		setLcr,			// host requests lcr be set
62 		lcr,			// use PARITY, STOPBITS, DATABITS below
63 
64 		setRxMode,		// set receive mode
65 		rxMode,			// RXMODE_DMA or RXMODE_BYHAND
66 
67 		setTxMode,		// set transmit mode
68 		txMode,			// TXMODE_DMA or TXMODE_BYHAND
69 
70 		setTxFlowControl,	// host requests tx flow control be set
71 		txFlowControl	,	// use TX_FLOW... bits below
72 		setRxFlowControl,	// host requests rx flow control be set
73 		rxFlowControl,	// use RX_FLOW... bits below
74 		sendXoff,		// host requests XOFF transmitted immediately
75 		sendXon,		// host requests XON char transmitted
76 		xonChar,		// specified in current character format
77 		xoffChar,		// specified in current character format
78 
79 		sendChar,		// host requests char transmitted immediately
80 		txChar,			// character to send
81 
82 		setRts,			// host requests RTS output be set
83 		rts,			// 1=on, 0=off
84 		setDtr, 		// host requests DTR output be set
85 		dtr;			// 1=on, 0=off
86 
87 
88 	/*
89 		2.	configuration data which is simply used as is
90 			and must be specified correctly in every host message.
91 	*/
92 
93 	u8	rxForwardingLength,  // forward when this number of chars available
94 		rxForwardingTimeout, // (1-31 in ms)
95 		txAckSetting;	   // 0=don't ack, 1=normal, 2-255 TBD...
96 	/*
97 		3.	Firmware states which cause actions if they change
98 		and must be specified correctly in every host message.
99 	*/
100 
101 	u8	portEnabled,	// 0=disabled, 1=enabled
102 		txFlush,		// 0=normal, 1=toss outbound data
103 		txBreak,		// 0=break off, 1=break on
104 		loopbackMode;	// 0=no loopback, 1=loopback enabled
105 
106 	/*
107 		4.	commands which are flags only; these are processed in order
108 			(so that, e.g., if rxFlush and rxForward flags are set, the
109 			port will have no data to forward); any non-zero value
110 			is respected
111 	*/
112 
113 	u8	rxFlush,		// toss inbound data
114 		rxForward,		// forward all inbound data, NOW (as if fwdLen==1)
115 		cancelRxXoff,	// cancel any receive XOFF state (_txXoff)
116 		returnStatus;	// return current status NOW
117 };
118 
119 // defines for bits in lcr
120 #define		USA_DATABITS_5		0x00
121 #define		USA_DATABITS_6		0x01
122 #define		USA_DATABITS_7		0x02
123 #define		USA_DATABITS_8		0x03
124 #define		STOPBITS_5678_1		0x00	// 1 stop bit for all byte sizes
125 #define		STOPBITS_5_1p5		0x04	// 1.5 stop bits for 5-bit byte
126 #define		STOPBITS_678_2		0x04	// 2 stop bits for 6-8 bit byte
127 #define		USA_PARITY_NONE		0x00
128 #define		USA_PARITY_ODD		0x08
129 #define		USA_PARITY_EVEN		0x18
130 #define		PARITY_MARK_1  		0x28   	// force parity MARK
131 #define		PARITY_SPACE_0 		0x38	// force parity SPACE
132 
133 #define		TXFLOW_CTS			0x04
134 #define		TXFLOW_DSR			0x08
135 #define		TXFLOW_XOFF			0x01
136 #define		TXFLOW_XOFF_ANY		0x02
137 #define		TXFLOW_XOFF_BITS	(TXFLOW_XOFF | TXFLOW_XOFF_ANY)
138 
139 #define		RXFLOW_XOFF			0x10
140 #define		RXFLOW_RTS			0x20
141 #define		RXFLOW_DTR			0x40
142 #define		RXFLOW_DSR_SENSITIVITY	0x80
143 
144 #define		RXMODE_BYHAND		0x00
145 #define		RXMODE_DMA			0x02
146 
147 #define		TXMODE_BYHAND		0x00
148 #define		TXMODE_DMA			0x02
149 
150 
151 // all things called "StatusMessage" are sent on the status endpoint
152 
153 struct keyspan_usa90_portStatusMessage
154 {
155 	u8	msr,			// reports the actual MSR register
156 		cts,			// reports CTS pin
157 		dcd,			// reports DCD pin
158 		dsr,			// reports DSR pin
159 		ri,				// reports RI pin
160 		_txXoff,		// port is in XOFF state (we received XOFF)
161 		rxBreak,		// reports break state
162 		rxOverrun,		// count of overrun errors (since last reported)
163 		rxParity,		// count of parity errors (since last reported)
164 		rxFrame,		// count of frame errors (since last reported)
165 		portState,		// PORTSTATE_xxx bits (useful for debugging)
166 		messageAck,		// message acknowledgement
167 		charAck,		// character acknowledgement
168 		controlResponse;	// (value = returnStatus) a control message has been processed
169 };
170 
171 // bits in RX data message when STAT byte is included
172 
173 #define	RXERROR_OVERRUN		0x02
174 #define	RXERROR_PARITY		0x04
175 #define	RXERROR_FRAMING		0x08
176 #define	RXERROR_BREAK		0x10
177 
178 #define	PORTSTATE_ENABLED	0x80
179 #define	PORTSTATE_TXFLUSH	0x01
180 #define	PORTSTATE_TXBREAK	0x02
181 #define	PORTSTATE_LOOPBACK 	0x04
182 
183 // MSR bits
184 
185 #define MSR_dCTS	  		0x01		// CTS has changed since last report
186 #define MSR_dDSR	  		0x02
187 #define MSR_dRI				0x04
188 #define MSR_dDCD	  		0x08
189 
190 #define MSR_CTS				0x10	  	// current state of CTS
191 #define MSR_DSR				0x20
192 #define MSR_RI				0x40
193 #define MSR_DCD				0x80
194 
195 // ie: the maximum length of an endpoint buffer
196 #define		MAX_DATA_LEN			64
197 
198 #endif
199