123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- /*
- 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
|