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