Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/torvalds/linux-2.6
[linux-2.6] / drivers / usb / serial / keyspan_usa90msg.h
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 Incorporated 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 USA_MSR_dCTS                    0x01            // CTS has changed since last report    
186 #define USA_MSR_dDSR                    0x02
187 #define USA_MSR_dRI                     0x04
188 #define USA_MSR_dDCD                    0x08
189
190 #define USA_MSR_CTS                     0x10            // current state of CTS
191 #define USA_MSR_DSR                     0x20
192 #define USA_USA_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