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

source code of linux/drivers/usb/serial/keyspan_usa90msg.h