2005-04-17 02:20:36 +04:00
/*
* rocket_int . h - - - internal header file for rocket . c
*
* Written by Theodore Ts ' o , Copyright 1997.
* Copyright 1997 Comtrol Corporation .
*
*/
/*
* Definition of the types in rcktpt_type
*/
# define ROCKET_TYPE_NORMAL 0
# define ROCKET_TYPE_MODEM 1
# define ROCKET_TYPE_MODEMII 2
# define ROCKET_TYPE_MODEMIII 3
# define ROCKET_TYPE_PC104 4
2007-05-08 11:32:00 +04:00
# include <linux/mutex.h>
2005-04-17 02:20:36 +04:00
# include <asm/io.h>
# include <asm/byteorder.h>
typedef unsigned char Byte_t ;
typedef unsigned int ByteIO_t ;
typedef unsigned int Word_t ;
typedef unsigned int WordIO_t ;
typedef unsigned int DWordIO_t ;
/*
* Note ! Normally the Linux I / O macros already take care of
* byte - swapping the I / O instructions . However , all accesses using
* sOutDW aren ' t really 32 - bit accesses , but should be handled in byte
* order . Hence the use of the cpu_to_le32 ( ) macro to byte - swap
* things to no - op the byte swapping done by the big - endian outl ( )
* instruction .
*/
static inline void sOutB ( unsigned short port , unsigned char value )
{
# ifdef ROCKET_DEBUG_IO
2008-02-07 11:16:33 +03:00
printk ( KERN_DEBUG " sOutB(%x, %x)... \n " , port , value ) ;
2005-04-17 02:20:36 +04:00
# endif
outb_p ( value , port ) ;
}
static inline void sOutW ( unsigned short port , unsigned short value )
{
# ifdef ROCKET_DEBUG_IO
2008-02-07 11:16:33 +03:00
printk ( KERN_DEBUG " sOutW(%x, %x)... \n " , port , value ) ;
2005-04-17 02:20:36 +04:00
# endif
outw_p ( value , port ) ;
}
2008-03-19 19:27:48 +03:00
static inline void out32 ( unsigned short port , Byte_t * p )
2005-04-17 02:20:36 +04:00
{
2008-04-29 12:03:32 +04:00
u32 value = get_unaligned_le32 ( p ) ;
2005-04-17 02:20:36 +04:00
# ifdef ROCKET_DEBUG_IO
2008-03-19 19:27:48 +03:00
printk ( KERN_DEBUG " out32(%x, %lx)... \n " , port , value ) ;
2005-04-17 02:20:36 +04:00
# endif
2008-03-19 19:27:48 +03:00
outl_p ( value , port ) ;
2005-04-17 02:20:36 +04:00
}
static inline unsigned char sInB ( unsigned short port )
{
return inb_p ( port ) ;
}
static inline unsigned short sInW ( unsigned short port )
{
return inw_p ( port ) ;
}
/* This is used to move arrays of bytes so byte swapping isn't appropriate. */
# define sOutStrW(port, addr, count) if (count) outsw(port, addr, count)
# define sInStrW(port, addr, count) if (count) insw(port, addr, count)
# define CTL_SIZE 8
# define AIOP_CTL_SIZE 4
# define CHAN_AIOP_SIZE 8
# define MAX_PORTS_PER_AIOP 8
# define MAX_AIOPS_PER_BOARD 4
# define MAX_PORTS_PER_BOARD 32
/* Bus type ID */
# define isISA 0
# define isPCI 1
# define isMC 2
/* Controller ID numbers */
# define CTLID_NULL -1 /* no controller exists */
# define CTLID_0001 0x0001 /* controller release 1 */
/* AIOP ID numbers, identifies AIOP type implementing channel */
# define AIOPID_NULL -1 /* no AIOP or channel exists */
# define AIOPID_0001 0x0001 /* AIOP release 1 */
/************************************************************************
Global Register Offsets - Direct Access - Fixed values
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define _CMD_REG 0x38 /* Command Register 8 Write */
# define _INT_CHAN 0x39 /* Interrupt Channel Register 8 Read */
# define _INT_MASK 0x3A /* Interrupt Mask Register 8 Read / Write */
# define _UNUSED 0x3B /* Unused 8 */
# define _INDX_ADDR 0x3C /* Index Register Address 16 Write */
# define _INDX_DATA 0x3E /* Index Register Data 8/16 Read / Write */
/************************************************************************
Channel Register Offsets for 1 st channel in AIOP - Direct Access
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define _TD0 0x00 /* Transmit Data 16 Write */
# define _RD0 0x00 /* Receive Data 16 Read */
# define _CHN_STAT0 0x20 /* Channel Status 8/16 Read / Write */
# define _FIFO_CNT0 0x10 /* Transmit/Receive FIFO Count 16 Read */
# define _INT_ID0 0x30 /* Interrupt Identification 8 Read */
/************************************************************************
Tx Control Register Offsets - Indexed - External - Fixed
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define _TX_ENBLS 0x980 /* Tx Processor Enables Register 8 Read / Write */
# define _TXCMP1 0x988 /* Transmit Compare Value #1 8 Read / Write */
# define _TXCMP2 0x989 /* Transmit Compare Value #2 8 Read / Write */
# define _TXREP1B1 0x98A /* Tx Replace Value #1 - Byte 1 8 Read / Write */
# define _TXREP1B2 0x98B /* Tx Replace Value #1 - Byte 2 8 Read / Write */
# define _TXREP2 0x98C /* Transmit Replace Value #2 8 Read / Write */
/************************************************************************
Memory Controller Register Offsets - Indexed - External - Fixed
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define _RX_FIFO 0x000 /* Rx FIFO */
# define _TX_FIFO 0x800 /* Tx FIFO */
# define _RXF_OUTP 0x990 /* Rx FIFO OUT pointer 16 Read / Write */
# define _RXF_INP 0x992 /* Rx FIFO IN pointer 16 Read / Write */
# define _TXF_OUTP 0x994 /* Tx FIFO OUT pointer 8 Read / Write */
# define _TXF_INP 0x995 /* Tx FIFO IN pointer 8 Read / Write */
# define _TXP_CNT 0x996 /* Tx Priority Count 8 Read / Write */
# define _TXP_PNTR 0x997 /* Tx Priority Pointer 8 Read / Write */
# define PRI_PEND 0x80 /* Priority data pending (bit7, Tx pri cnt) */
# define TXFIFO_SIZE 255 /* size of Tx FIFO */
# define RXFIFO_SIZE 1023 /* size of Rx FIFO */
/************************************************************************
Tx Priority Buffer - Indexed - External - Fixed
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define _TXP_BUF 0x9C0 /* Tx Priority Buffer 32 Bytes Read / Write */
# define TXP_SIZE 0x20 /* 32 bytes */
/************************************************************************
Channel Register Offsets - Indexed - Internal - Fixed
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define _TX_CTRL 0xFF0 /* Transmit Control 16 Write */
# define _RX_CTRL 0xFF2 /* Receive Control 8 Write */
# define _BAUD 0xFF4 /* Baud Rate 16 Write */
# define _CLK_PRE 0xFF6 /* Clock Prescaler 8 Write */
# define STMBREAK 0x08 /* BREAK */
# define STMFRAME 0x04 /* framing error */
# define STMRCVROVR 0x02 /* receiver over run error */
# define STMPARITY 0x01 /* parity error */
# define STMERROR (STMBREAK | STMFRAME | STMPARITY)
# define STMBREAKH 0x800 /* BREAK */
# define STMFRAMEH 0x400 /* framing error */
# define STMRCVROVRH 0x200 /* receiver over run error */
# define STMPARITYH 0x100 /* parity error */
# define STMERRORH (STMBREAKH | STMFRAMEH | STMPARITYH)
# define CTS_ACT 0x20 /* CTS input asserted */
# define DSR_ACT 0x10 /* DSR input asserted */
# define CD_ACT 0x08 /* CD input asserted */
# define TXFIFOMT 0x04 /* Tx FIFO is empty */
# define TXSHRMT 0x02 /* Tx shift register is empty */
# define RDA 0x01 /* Rx data available */
# define DRAINED (TXFIFOMT | TXSHRMT) /* indicates Tx is drained */
# define STATMODE 0x8000 /* status mode enable bit */
# define RXFOVERFL 0x2000 /* receive FIFO overflow */
# define RX2MATCH 0x1000 /* receive compare byte 2 match */
# define RX1MATCH 0x0800 /* receive compare byte 1 match */
# define RXBREAK 0x0400 /* received BREAK */
# define RXFRAME 0x0200 /* received framing error */
# define RXPARITY 0x0100 /* received parity error */
# define STATERROR (RXBREAK | RXFRAME | RXPARITY)
# define CTSFC_EN 0x80 /* CTS flow control enable bit */
# define RTSTOG_EN 0x40 /* RTS toggle enable bit */
# define TXINT_EN 0x10 /* transmit interrupt enable */
# define STOP2 0x08 /* enable 2 stop bits (0 = 1 stop) */
# define PARITY_EN 0x04 /* enable parity (0 = no parity) */
# define EVEN_PAR 0x02 /* even parity (0 = odd parity) */
# define DATA8BIT 0x01 /* 8 bit data (0 = 7 bit data) */
# define SETBREAK 0x10 /* send break condition (must clear) */
# define LOCALLOOP 0x08 /* local loopback set for test */
# define SET_DTR 0x04 /* assert DTR */
# define SET_RTS 0x02 /* assert RTS */
# define TX_ENABLE 0x01 /* enable transmitter */
# define RTSFC_EN 0x40 /* RTS flow control enable */
# define RXPROC_EN 0x20 /* receive processor enable */
# define TRIG_NO 0x00 /* Rx FIFO trigger level 0 (no trigger) */
# define TRIG_1 0x08 /* trigger level 1 char */
# define TRIG_1_2 0x10 /* trigger level 1/2 */
# define TRIG_7_8 0x18 /* trigger level 7/8 */
# define TRIG_MASK 0x18 /* trigger level mask */
# define SRCINT_EN 0x04 /* special Rx condition interrupt enable */
# define RXINT_EN 0x02 /* Rx interrupt enable */
# define MCINT_EN 0x01 /* modem change interrupt enable */
# define RXF_TRIG 0x20 /* Rx FIFO trigger level interrupt */
# define TXFIFO_MT 0x10 /* Tx FIFO empty interrupt */
# define SRC_INT 0x08 /* special receive condition interrupt */
# define DELTA_CD 0x04 /* CD change interrupt */
# define DELTA_CTS 0x02 /* CTS change interrupt */
# define DELTA_DSR 0x01 /* DSR change interrupt */
# define REP1W2_EN 0x10 /* replace byte 1 with 2 bytes enable */
# define IGN2_EN 0x08 /* ignore byte 2 enable */
# define IGN1_EN 0x04 /* ignore byte 1 enable */
# define COMP2_EN 0x02 /* compare byte 2 enable */
# define COMP1_EN 0x01 /* compare byte 1 enable */
# define RESET_ALL 0x80 /* reset AIOP (all channels) */
# define TXOVERIDE 0x40 /* Transmit software off override */
# define RESETUART 0x20 /* reset channel's UART */
# define RESTXFCNT 0x10 /* reset channel's Tx FIFO count register */
# define RESRXFCNT 0x08 /* reset channel's Rx FIFO count register */
# define INTSTAT0 0x01 /* AIOP 0 interrupt status */
# define INTSTAT1 0x02 /* AIOP 1 interrupt status */
# define INTSTAT2 0x04 /* AIOP 2 interrupt status */
# define INTSTAT3 0x08 /* AIOP 3 interrupt status */
# define INTR_EN 0x08 /* allow interrupts to host */
# define INT_STROB 0x04 /* strobe and clear interrupt line (EOI) */
/**************************************************************************
MUDBAC remapped for PCI
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define _CFG_INT_PCI 0x40
# define _PCI_INT_FUNC 0x3A
# define PCI_STROB 0x2000 /* bit 13 of int aiop register */
# define INTR_EN_PCI 0x0010 /* allow interrupts to host */
/*
* Definitions for Universal PCI board registers
*/
# define _PCI_9030_INT_CTRL 0x4c /* Offsets from BAR1 */
# define _PCI_9030_GPIO_CTRL 0x54
# define PCI_INT_CTRL_AIOP 0x0001
# define PCI_GPIO_CTRL_8PORT 0x4000
# define _PCI_9030_RING_IND 0xc0 /* Offsets from BAR1 */
# define CHAN3_EN 0x08 /* enable AIOP 3 */
# define CHAN2_EN 0x04 /* enable AIOP 2 */
# define CHAN1_EN 0x02 /* enable AIOP 1 */
# define CHAN0_EN 0x01 /* enable AIOP 0 */
# define FREQ_DIS 0x00
# define FREQ_274HZ 0x60
# define FREQ_137HZ 0x50
# define FREQ_69HZ 0x40
# define FREQ_34HZ 0x30
# define FREQ_17HZ 0x20
# define FREQ_9HZ 0x10
# define PERIODIC_ONLY 0x80 /* only PERIODIC interrupt */
# define CHANINT_EN 0x0100 /* flags to enable/disable channel ints */
# define RDATASIZE 72
# define RREGDATASIZE 52
/*
* AIOP interrupt bits for ISA / PCI boards and UPCI boards .
*/
# define AIOP_INTR_BIT_0 0x0001
# define AIOP_INTR_BIT_1 0x0002
# define AIOP_INTR_BIT_2 0x0004
# define AIOP_INTR_BIT_3 0x0008
# define AIOP_INTR_BITS ( \
AIOP_INTR_BIT_0 \
| AIOP_INTR_BIT_1 \
| AIOP_INTR_BIT_2 \
| AIOP_INTR_BIT_3 )
# define UPCI_AIOP_INTR_BIT_0 0x0004
# define UPCI_AIOP_INTR_BIT_1 0x0020
# define UPCI_AIOP_INTR_BIT_2 0x0100
# define UPCI_AIOP_INTR_BIT_3 0x0800
# define UPCI_AIOP_INTR_BITS ( \
UPCI_AIOP_INTR_BIT_0 \
| UPCI_AIOP_INTR_BIT_1 \
| UPCI_AIOP_INTR_BIT_2 \
| UPCI_AIOP_INTR_BIT_3 )
/* Controller level information structure */
typedef struct {
int CtlID ;
int CtlNum ;
int BusType ;
int boardType ;
int isUPCI ;
WordIO_t PCIIO ;
WordIO_t PCIIO2 ;
ByteIO_t MBaseIO ;
ByteIO_t MReg1IO ;
ByteIO_t MReg2IO ;
ByteIO_t MReg3IO ;
Byte_t MReg2 ;
Byte_t MReg3 ;
int NumAiop ;
int AltChanRingIndicator ;
ByteIO_t UPCIRingInd ;
WordIO_t AiopIO [ AIOP_CTL_SIZE ] ;
ByteIO_t AiopIntChanIO [ AIOP_CTL_SIZE ] ;
int AiopID [ AIOP_CTL_SIZE ] ;
int AiopNumChan [ AIOP_CTL_SIZE ] ;
Word_t * AiopIntrBits ;
} CONTROLLER_T ;
typedef CONTROLLER_T CONTROLLER_t ;
/* Channel level information structure */
typedef struct {
CONTROLLER_T * CtlP ;
int AiopNum ;
int ChanID ;
int ChanNum ;
int rtsToggle ;
ByteIO_t Cmd ;
ByteIO_t IntChan ;
ByteIO_t IntMask ;
DWordIO_t IndexAddr ;
WordIO_t IndexData ;
WordIO_t TxRxData ;
WordIO_t ChanStat ;
WordIO_t TxRxCount ;
ByteIO_t IntID ;
Word_t TxFIFO ;
Word_t TxFIFOPtrs ;
Word_t RxFIFO ;
Word_t RxFIFOPtrs ;
Word_t TxPrioCnt ;
Word_t TxPrioPtr ;
Word_t TxPrioBuf ;
Byte_t R [ RREGDATASIZE ] ;
Byte_t BaudDiv [ 4 ] ;
Byte_t TxControl [ 4 ] ;
Byte_t RxControl [ 4 ] ;
Byte_t TxEnables [ 4 ] ;
Byte_t TxCompare [ 4 ] ;
Byte_t TxReplace1 [ 4 ] ;
Byte_t TxReplace2 [ 4 ] ;
} CHANNEL_T ;
typedef CHANNEL_T CHANNEL_t ;
typedef CHANNEL_T * CHANPTR_T ;
# define InterfaceModeRS232 0x00
# define InterfaceModeRS422 0x08
# define InterfaceModeRS485 0x10
# define InterfaceModeRS232T 0x18
/***************************************************************************
Function : sClrBreak
Purpose : Stop sending a transmit BREAK signal
Call : sClrBreak ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sClrBreak(ChP) \
do { \
( ChP ) - > TxControl [ 3 ] & = ~ SETBREAK ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sClrDTR
Purpose : Clr the DTR output
Call : sClrDTR ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sClrDTR(ChP) \
do { \
( ChP ) - > TxControl [ 3 ] & = ~ SET_DTR ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sClrRTS
Purpose : Clr the RTS output
Call : sClrRTS ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sClrRTS(ChP) \
do { \
if ( ( ChP ) - > rtsToggle ) break ; \
( ChP ) - > TxControl [ 3 ] & = ~ SET_RTS ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sClrTxXOFF
Purpose : Clear any existing transmit software flow control off condition
Call : sClrTxXOFF ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sClrTxXOFF(ChP) \
do { \
sOutB ( ( ChP ) - > Cmd , TXOVERIDE | ( Byte_t ) ( ChP ) - > ChanNum ) ; \
sOutB ( ( ChP ) - > Cmd , ( Byte_t ) ( ChP ) - > ChanNum ) ; \
} while ( 0 )
/***************************************************************************
Function : sCtlNumToCtlPtr
Purpose : Convert a controller number to controller structure pointer
Call : sCtlNumToCtlPtr ( CtlNum )
int CtlNum ; Controller number
Return : CONTROLLER_T * : Ptr to controller structure
*/
# define sCtlNumToCtlPtr(CTLNUM) &sController[CTLNUM]
/***************************************************************************
Function : sControllerEOI
Purpose : Strobe the MUDBAC ' s End Of Interrupt bit .
Call : sControllerEOI ( CtlP )
CONTROLLER_T * CtlP ; Ptr to controller structure
*/
# define sControllerEOI(CTLP) sOutB((CTLP)->MReg2IO,(CTLP)->MReg2 | INT_STROB)
/***************************************************************************
Function : sPCIControllerEOI
Purpose : Strobe the PCI End Of Interrupt bit .
For the UPCI boards , toggle the AIOP interrupt enable bit
( this was taken from the Windows driver ) .
Call : sPCIControllerEOI ( CtlP )
CONTROLLER_T * CtlP ; Ptr to controller structure
*/
# define sPCIControllerEOI(CTLP) \
do { \
if ( ( CTLP ) - > isUPCI ) { \
Word_t w = sInW ( ( CTLP ) - > PCIIO ) ; \
sOutW ( ( CTLP ) - > PCIIO , ( w ^ PCI_INT_CTRL_AIOP ) ) ; \
sOutW ( ( CTLP ) - > PCIIO , w ) ; \
} \
else { \
sOutW ( ( CTLP ) - > PCIIO , PCI_STROB ) ; \
} \
} while ( 0 )
/***************************************************************************
Function : sDisAiop
Purpose : Disable I / O access to an AIOP
Call : sDisAiop ( CltP )
CONTROLLER_T * CtlP ; Ptr to controller structure
int AiopNum ; Number of AIOP on controller
*/
# define sDisAiop(CTLP,AIOPNUM) \
do { \
( CTLP ) - > MReg3 & = sBitMapClrTbl [ AIOPNUM ] ; \
sOutB ( ( CTLP ) - > MReg3IO , ( CTLP ) - > MReg3 ) ; \
} while ( 0 )
/***************************************************************************
Function : sDisCTSFlowCtl
Purpose : Disable output flow control using CTS
Call : sDisCTSFlowCtl ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sDisCTSFlowCtl(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] & = ~ CTSFC_EN ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sDisIXANY
Purpose : Disable IXANY Software Flow Control
Call : sDisIXANY ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sDisIXANY(ChP) \
do { \
( ChP ) - > R [ 0x0e ] = 0x86 ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , & ( ChP ) - > R [ 0x0c ] ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : DisParity
Purpose : Disable parity
Call : sDisParity ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : Function sSetParity ( ) can be used in place of functions sEnParity ( ) ,
sDisParity ( ) , sSetOddParity ( ) , and sSetEvenParity ( ) .
*/
# define sDisParity(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] & = ~ PARITY_EN ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sDisRTSToggle
Purpose : Disable RTS toggle
Call : sDisRTSToggle ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sDisRTSToggle(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] & = ~ RTSTOG_EN ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
( ChP ) - > rtsToggle = 0 ; \
} while ( 0 )
/***************************************************************************
Function : sDisRxFIFO
Purpose : Disable Rx FIFO
Call : sDisRxFIFO ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sDisRxFIFO(ChP) \
do { \
( ChP ) - > R [ 0x32 ] = 0x0a ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , & ( ChP ) - > R [ 0x30 ] ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sDisRxStatusMode
Purpose : Disable the Rx status mode
Call : sDisRxStatusMode ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : This takes the channel out of the receive status mode . All
subsequent reads of receive data using sReadRxWord ( ) will return
two data bytes .
*/
# define sDisRxStatusMode(ChP) sOutW((ChP)->ChanStat,0)
/***************************************************************************
Function : sDisTransmit
Purpose : Disable transmit
Call : sDisTransmit ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
This disables movement of Tx data from the Tx FIFO into the 1 byte
Tx buffer . Therefore there could be up to a 2 byte latency
between the time sDisTransmit ( ) is called and the transmit buffer
and transmit shift register going completely empty .
*/
# define sDisTransmit(ChP) \
do { \
( ChP ) - > TxControl [ 3 ] & = ~ TX_ENABLE ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sDisTxSoftFlowCtl
Purpose : Disable Tx Software Flow Control
Call : sDisTxSoftFlowCtl ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sDisTxSoftFlowCtl(ChP) \
do { \
( ChP ) - > R [ 0x06 ] = 0x8a ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , & ( ChP ) - > R [ 0x04 ] ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sEnAiop
Purpose : Enable I / O access to an AIOP
Call : sEnAiop ( CltP )
CONTROLLER_T * CtlP ; Ptr to controller structure
int AiopNum ; Number of AIOP on controller
*/
# define sEnAiop(CTLP,AIOPNUM) \
do { \
( CTLP ) - > MReg3 | = sBitMapSetTbl [ AIOPNUM ] ; \
sOutB ( ( CTLP ) - > MReg3IO , ( CTLP ) - > MReg3 ) ; \
} while ( 0 )
/***************************************************************************
Function : sEnCTSFlowCtl
Purpose : Enable output flow control using CTS
Call : sEnCTSFlowCtl ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sEnCTSFlowCtl(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] | = CTSFC_EN ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sEnIXANY
Purpose : Enable IXANY Software Flow Control
Call : sEnIXANY ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sEnIXANY(ChP) \
do { \
( ChP ) - > R [ 0x0e ] = 0x21 ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , & ( ChP ) - > R [ 0x0c ] ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : EnParity
Purpose : Enable parity
Call : sEnParity ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : Function sSetParity ( ) can be used in place of functions sEnParity ( ) ,
sDisParity ( ) , sSetOddParity ( ) , and sSetEvenParity ( ) .
Warnings : Before enabling parity odd or even parity should be chosen using
functions sSetOddParity ( ) or sSetEvenParity ( ) .
*/
# define sEnParity(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] | = PARITY_EN ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sEnRTSToggle
Purpose : Enable RTS toggle
Call : sEnRTSToggle ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : This function will disable RTS flow control and clear the RTS
line to allow operation of RTS toggle .
*/
# define sEnRTSToggle(ChP) \
do { \
( ChP ) - > RxControl [ 2 ] & = ~ RTSFC_EN ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > RxControl ) ; \
2005-04-17 02:20:36 +04:00
( ChP ) - > TxControl [ 2 ] | = RTSTOG_EN ; \
( ChP ) - > TxControl [ 3 ] & = ~ SET_RTS ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
( ChP ) - > rtsToggle = 1 ; \
} while ( 0 )
/***************************************************************************
Function : sEnRxFIFO
Purpose : Enable Rx FIFO
Call : sEnRxFIFO ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sEnRxFIFO(ChP) \
do { \
( ChP ) - > R [ 0x32 ] = 0x08 ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , & ( ChP ) - > R [ 0x30 ] ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sEnRxProcessor
Purpose : Enable the receive processor
Call : sEnRxProcessor ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : This function is used to start the receive processor . When
the channel is in the reset state the receive processor is not
running . This is done to prevent the receive processor from
executing invalid microcode instructions prior to the
downloading of the microcode .
Warnings : This function must be called after valid microcode has been
downloaded to the AIOP , and it must not be called before the
microcode has been downloaded .
*/
# define sEnRxProcessor(ChP) \
do { \
( ChP ) - > RxControl [ 2 ] | = RXPROC_EN ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > RxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sEnRxStatusMode
Purpose : Enable the Rx status mode
Call : sEnRxStatusMode ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : This places the channel in the receive status mode . All subsequent
reads of receive data using sReadRxWord ( ) will return a data byte
in the low word and a status byte in the high word .
*/
# define sEnRxStatusMode(ChP) sOutW((ChP)->ChanStat,STATMODE)
/***************************************************************************
Function : sEnTransmit
Purpose : Enable transmit
Call : sEnTransmit ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sEnTransmit(ChP) \
do { \
( ChP ) - > TxControl [ 3 ] | = TX_ENABLE ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sEnTxSoftFlowCtl
Purpose : Enable Tx Software Flow Control
Call : sEnTxSoftFlowCtl ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sEnTxSoftFlowCtl(ChP) \
do { \
( ChP ) - > R [ 0x06 ] = 0xc5 ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , & ( ChP ) - > R [ 0x04 ] ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sGetAiopIntStatus
Purpose : Get the AIOP interrupt status
Call : sGetAiopIntStatus ( CtlP , AiopNum )
CONTROLLER_T * CtlP ; Ptr to controller structure
int AiopNum ; AIOP number
Return : Byte_t : The AIOP interrupt status . Bits 0 through 7
represent channels 0 through 7 respectively . If a
bit is set that channel is interrupting .
*/
# define sGetAiopIntStatus(CTLP,AIOPNUM) sInB((CTLP)->AiopIntChanIO[AIOPNUM])
/***************************************************************************
Function : sGetAiopNumChan
Purpose : Get the number of channels supported by an AIOP
Call : sGetAiopNumChan ( CtlP , AiopNum )
CONTROLLER_T * CtlP ; Ptr to controller structure
int AiopNum ; AIOP number
Return : int : The number of channels supported by the AIOP
*/
# define sGetAiopNumChan(CTLP,AIOPNUM) (CTLP)->AiopNumChan[AIOPNUM]
/***************************************************************************
Function : sGetChanIntID
Purpose : Get a channel ' s interrupt identification byte
Call : sGetChanIntID ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Return : Byte_t : The channel interrupt ID . Can be any
combination of the following flags :
RXF_TRIG : Rx FIFO trigger level interrupt
TXFIFO_MT : Tx FIFO empty interrupt
SRC_INT : Special receive condition interrupt
DELTA_CD : CD change interrupt
DELTA_CTS : CTS change interrupt
DELTA_DSR : DSR change interrupt
*/
# define sGetChanIntID(ChP) (sInB((ChP)->IntID) & (RXF_TRIG | TXFIFO_MT | SRC_INT | DELTA_CD | DELTA_CTS | DELTA_DSR))
/***************************************************************************
Function : sGetChanNum
Purpose : Get the number of a channel within an AIOP
Call : sGetChanNum ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Return : int : Channel number within AIOP , or NULLCHAN if channel does
not exist .
*/
# define sGetChanNum(ChP) (ChP)->ChanNum
/***************************************************************************
Function : sGetChanStatus
Purpose : Get the channel status
Call : sGetChanStatus ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Return : Word_t : The channel status . Can be any combination of
the following flags :
LOW BYTE FLAGS
CTS_ACT : CTS input asserted
DSR_ACT : DSR input asserted
CD_ACT : CD input asserted
TXFIFOMT : Tx FIFO is empty
TXSHRMT : Tx shift register is empty
RDA : Rx data available
HIGH BYTE FLAGS
STATMODE : status mode enable bit
RXFOVERFL : receive FIFO overflow
RX2MATCH : receive compare byte 2 match
RX1MATCH : receive compare byte 1 match
RXBREAK : received BREAK
RXFRAME : received framing error
RXPARITY : received parity error
Warnings : This function will clear the high byte flags in the Channel
Status Register .
*/
# define sGetChanStatus(ChP) sInW((ChP)->ChanStat)
/***************************************************************************
Function : sGetChanStatusLo
Purpose : Get the low byte only of the channel status
Call : sGetChanStatusLo ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Return : Byte_t : The channel status low byte . Can be any combination
of the following flags :
CTS_ACT : CTS input asserted
DSR_ACT : DSR input asserted
CD_ACT : CD input asserted
TXFIFOMT : Tx FIFO is empty
TXSHRMT : Tx shift register is empty
RDA : Rx data available
*/
# define sGetChanStatusLo(ChP) sInB((ByteIO_t)(ChP)->ChanStat)
/**********************************************************************
* Get RI status of channel
* Defined as a function in rocket . c - aes
*/
#if 0
# define sGetChanRI(ChP) ((ChP)->CtlP->AltChanRingIndicator ? \
( sInB ( ( ByteIO_t ) ( ( ChP ) - > ChanStat + 8 ) ) & DSR_ACT ) : \
( ( ( ChP ) - > CtlP - > boardType = = ROCKET_TYPE_PC104 ) ? \
( ! ( sInB ( ( ChP ) - > CtlP - > AiopIO [ 3 ] ) & sBitMapSetTbl [ ( ChP ) - > ChanNum ] ) ) : \
0 ) )
# endif
/***************************************************************************
Function : sGetControllerIntStatus
Purpose : Get the controller interrupt status
Call : sGetControllerIntStatus ( CtlP )
CONTROLLER_T * CtlP ; Ptr to controller structure
Return : Byte_t : The controller interrupt status in the lower 4
bits . Bits 0 through 3 represent AIOP ' s 0
through 3 respectively . If a bit is set that
AIOP is interrupting . Bits 4 through 7 will
always be cleared .
*/
# define sGetControllerIntStatus(CTLP) (sInB((CTLP)->MReg1IO) & 0x0f)
/***************************************************************************
Function : sPCIGetControllerIntStatus
Purpose : Get the controller interrupt status
Call : sPCIGetControllerIntStatus ( CtlP )
CONTROLLER_T * CtlP ; Ptr to controller structure
Return : unsigned char : The controller interrupt status in the lower 4
bits and bit 4. Bits 0 through 3 represent AIOP ' s 0
through 3 respectively . Bit 4 is set if the int
was generated from periodic . If a bit is set the
AIOP is interrupting .
*/
# define sPCIGetControllerIntStatus(CTLP) \
( ( CTLP ) - > isUPCI ? \
( sInW ( ( CTLP ) - > PCIIO2 ) & UPCI_AIOP_INTR_BITS ) : \
( ( sInW ( ( CTLP ) - > PCIIO ) > > 8 ) & AIOP_INTR_BITS ) )
/***************************************************************************
Function : sGetRxCnt
Purpose : Get the number of data bytes in the Rx FIFO
Call : sGetRxCnt ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Return : int : The number of data bytes in the Rx FIFO .
Comments : Byte read of count register is required to obtain Rx count .
*/
# define sGetRxCnt(ChP) sInW((ChP)->TxRxCount)
/***************************************************************************
Function : sGetTxCnt
Purpose : Get the number of data bytes in the Tx FIFO
Call : sGetTxCnt ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Return : Byte_t : The number of data bytes in the Tx FIFO .
Comments : Byte read of count register is required to obtain Tx count .
*/
# define sGetTxCnt(ChP) sInB((ByteIO_t)(ChP)->TxRxCount)
/*****************************************************************************
Function : sGetTxRxDataIO
Purpose : Get the I / O address of a channel ' s TxRx Data register
Call : sGetTxRxDataIO ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Return : WordIO_t : I / O address of a channel ' s TxRx Data register
*/
# define sGetTxRxDataIO(ChP) (ChP)->TxRxData
/***************************************************************************
Function : sInitChanDefaults
Purpose : Initialize a channel structure to it ' s default state .
Call : sInitChanDefaults ( ChP )
CHANNEL_T * ChP ; Ptr to the channel structure
Comments : This function must be called once for every channel structure
that exists before any other SSCI calls can be made .
*/
# define sInitChanDefaults(ChP) \
do { \
( ChP ) - > CtlP = NULLCTLPTR ; \
( ChP ) - > AiopNum = NULLAIOP ; \
( ChP ) - > ChanID = AIOPID_NULL ; \
( ChP ) - > ChanNum = NULLCHAN ; \
} while ( 0 )
/***************************************************************************
Function : sResetAiopByNum
Purpose : Reset the AIOP by number
Call : sResetAiopByNum ( CTLP , AIOPNUM )
CONTROLLER_T CTLP ; Ptr to controller structure
AIOPNUM ; AIOP index
*/
# define sResetAiopByNum(CTLP,AIOPNUM) \
do { \
sOutB ( ( CTLP ) - > AiopIO [ ( AIOPNUM ) ] + _CMD_REG , RESET_ALL ) ; \
sOutB ( ( CTLP ) - > AiopIO [ ( AIOPNUM ) ] + _CMD_REG , 0x0 ) ; \
} while ( 0 )
/***************************************************************************
Function : sSendBreak
Purpose : Send a transmit BREAK signal
Call : sSendBreak ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sSendBreak(ChP) \
do { \
( ChP ) - > TxControl [ 3 ] | = SETBREAK ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetBaud
Purpose : Set baud rate
Call : sSetBaud ( ChP , Divisor )
CHANNEL_T * ChP ; Ptr to channel structure
Word_t Divisor ; 16 bit baud rate divisor for channel
*/
# define sSetBaud(ChP,DIVISOR) \
do { \
( ChP ) - > BaudDiv [ 2 ] = ( Byte_t ) ( DIVISOR ) ; \
( ChP ) - > BaudDiv [ 3 ] = ( Byte_t ) ( ( DIVISOR ) > > 8 ) ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > BaudDiv ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetData7
Purpose : Set data bits to 7
Call : sSetData7 ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sSetData7(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] & = ~ DATA8BIT ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetData8
Purpose : Set data bits to 8
Call : sSetData8 ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sSetData8(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] | = DATA8BIT ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetDTR
Purpose : Set the DTR output
Call : sSetDTR ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sSetDTR(ChP) \
do { \
( ChP ) - > TxControl [ 3 ] | = SET_DTR ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetEvenParity
Purpose : Set even parity
Call : sSetEvenParity ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : Function sSetParity ( ) can be used in place of functions sEnParity ( ) ,
sDisParity ( ) , sSetOddParity ( ) , and sSetEvenParity ( ) .
Warnings : This function has no effect unless parity is enabled with function
sEnParity ( ) .
*/
# define sSetEvenParity(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] | = EVEN_PAR ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetOddParity
Purpose : Set odd parity
Call : sSetOddParity ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : Function sSetParity ( ) can be used in place of functions sEnParity ( ) ,
sDisParity ( ) , sSetOddParity ( ) , and sSetEvenParity ( ) .
Warnings : This function has no effect unless parity is enabled with function
sEnParity ( ) .
*/
# define sSetOddParity(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] & = ~ EVEN_PAR ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetRTS
Purpose : Set the RTS output
Call : sSetRTS ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sSetRTS(ChP) \
do { \
if ( ( ChP ) - > rtsToggle ) break ; \
( ChP ) - > TxControl [ 3 ] | = SET_RTS ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetRxTrigger
Purpose : Set the Rx FIFO trigger level
Call : sSetRxProcessor ( ChP , Level )
CHANNEL_T * ChP ; Ptr to channel structure
Byte_t Level ; Number of characters in Rx FIFO at which the
interrupt will be generated . Can be any of the following flags :
TRIG_NO : no trigger
TRIG_1 : 1 character in FIFO
TRIG_1_2 : FIFO 1 / 2 full
TRIG_7_8 : FIFO 7 / 8 full
Comments : An interrupt will be generated when the trigger level is reached
only if function sEnInterrupt ( ) has been called with flag
RXINT_EN set . The RXF_TRIG flag in the Interrupt Idenfification
register will be set whenever the trigger level is reached
regardless of the setting of RXINT_EN .
*/
# define sSetRxTrigger(ChP,LEVEL) \
do { \
( ChP ) - > RxControl [ 2 ] & = ~ TRIG_MASK ; \
( ChP ) - > RxControl [ 2 ] | = LEVEL ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > RxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetStop1
Purpose : Set stop bits to 1
Call : sSetStop1 ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sSetStop1(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] & = ~ STOP2 ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetStop2
Purpose : Set stop bits to 2
Call : sSetStop2 ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
*/
# define sSetStop2(ChP) \
do { \
( ChP ) - > TxControl [ 2 ] | = STOP2 ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , ( ChP ) - > TxControl ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetTxXOFFChar
Purpose : Set the Tx XOFF flow control character
Call : sSetTxXOFFChar ( ChP , Ch )
CHANNEL_T * ChP ; Ptr to channel structure
Byte_t Ch ; The value to set the Tx XOFF character to
*/
# define sSetTxXOFFChar(ChP,CH) \
do { \
( ChP ) - > R [ 0x07 ] = ( CH ) ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , & ( ChP ) - > R [ 0x04 ] ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sSetTxXONChar
Purpose : Set the Tx XON flow control character
Call : sSetTxXONChar ( ChP , Ch )
CHANNEL_T * ChP ; Ptr to channel structure
Byte_t Ch ; The value to set the Tx XON character to
*/
# define sSetTxXONChar(ChP,CH) \
do { \
( ChP ) - > R [ 0x0b ] = ( CH ) ; \
2008-03-19 19:27:48 +03:00
out32 ( ( ChP ) - > IndexAddr , & ( ChP ) - > R [ 0x08 ] ) ; \
2005-04-17 02:20:36 +04:00
} while ( 0 )
/***************************************************************************
Function : sStartRxProcessor
Purpose : Start a channel ' s receive processor
Call : sStartRxProcessor ( ChP )
CHANNEL_T * ChP ; Ptr to channel structure
Comments : This function is used to start a Rx processor after it was
stopped with sStopRxProcessor ( ) or sStopSWInFlowCtl ( ) . It
will restart both the Rx processor and software input flow control .
*/
2008-03-19 19:27:48 +03:00
# define sStartRxProcessor(ChP) out32((ChP)->IndexAddr,&(ChP)->R[0])
2005-04-17 02:20:36 +04:00
/***************************************************************************
Function : sWriteTxByte
Purpose : Write a transmit data byte to a channel .
ByteIO_t io : Channel transmit register I / O address . This can
be obtained with sGetTxRxDataIO ( ) .
Byte_t Data ; The transmit data byte .
Warnings : This function writes the data byte without checking to see if
sMaxTxSize is exceeded in the Tx FIFO .
*/
# define sWriteTxByte(IO,DATA) sOutB(IO,DATA)
/*
* Begin Linux specific definitions for the Rocketport driver
*
* This code is Copyright Theodore Ts ' o , 1995 - 1997
*/
struct r_port {
int magic ;
2008-07-17 00:56:18 +04:00
struct tty_port port ;
2005-04-17 02:20:36 +04:00
int line ;
2008-07-17 00:56:18 +04:00
int flags ; /* Don't yet match the ASY_ flags!! */
2005-04-17 02:20:36 +04:00
unsigned int board : 3 ;
unsigned int aiop : 2 ;
unsigned int chan : 3 ;
CONTROLLER_t * ctlp ;
CHANNEL_t channel ;
int intmask ;
int xmit_fifo_room ; /* room in xmit fifo */
unsigned char * xmit_buf ;
int xmit_head ;
int xmit_tail ;
int xmit_cnt ;
int cd_status ;
int ignore_status_mask ;
int read_status_mask ;
int cps ;
2008-07-17 00:56:18 +04:00
struct completion close_wait ; /* Not yet matching the core */
2005-04-17 02:20:36 +04:00
spinlock_t slock ;
2007-05-08 11:32:00 +04:00
struct mutex write_mtx ;
2005-04-17 02:20:36 +04:00
} ;
# define RPORT_MAGIC 0x525001
# define NUM_BOARDS 8
# define MAX_RP_PORTS (32*NUM_BOARDS)
/*
* The size of the xmit buffer is 1 page , or 4096 bytes
*/
# define XMIT_BUF_SIZE 4096
/* number of characters left in xmit buffer before we ask for more */
# define WAKEUP_CHARS 256
/* Internal flags used only by the rocketport driver */
# define ROCKET_INITIALIZED 0x80000000 /* Port is active */
# define ROCKET_CLOSING 0x40000000 /* Serial port is closing */
# define ROCKET_NORMAL_ACTIVE 0x20000000 /* Normal port is active */
/*
* Assigned major numbers for the Comtrol Rocketport
*/
# define TTY_ROCKET_MAJOR 46
# define CUA_ROCKET_MAJOR 47
# ifdef PCI_VENDOR_ID_RP
# undef PCI_VENDOR_ID_RP
# undef PCI_DEVICE_ID_RP8OCTA
# undef PCI_DEVICE_ID_RP8INTF
# undef PCI_DEVICE_ID_RP16INTF
# undef PCI_DEVICE_ID_RP32INTF
# undef PCI_DEVICE_ID_URP8OCTA
# undef PCI_DEVICE_ID_URP8INTF
# undef PCI_DEVICE_ID_URP16INTF
# undef PCI_DEVICE_ID_CRP16INTF
# undef PCI_DEVICE_ID_URP32INTF
# endif
/* Comtrol PCI Vendor ID */
# define PCI_VENDOR_ID_RP 0x11fe
/* Comtrol Device ID's */
# define PCI_DEVICE_ID_RP32INTF 0x0001 /* Rocketport 32 port w/external I/F */
# define PCI_DEVICE_ID_RP8INTF 0x0002 /* Rocketport 8 port w/external I/F */
# define PCI_DEVICE_ID_RP16INTF 0x0003 /* Rocketport 16 port w/external I/F */
# define PCI_DEVICE_ID_RP4QUAD 0x0004 /* Rocketport 4 port w/quad cable */
# define PCI_DEVICE_ID_RP8OCTA 0x0005 /* Rocketport 8 port w/octa cable */
# define PCI_DEVICE_ID_RP8J 0x0006 /* Rocketport 8 port w/RJ11 connectors */
# define PCI_DEVICE_ID_RP4J 0x0007 /* Rocketport 4 port w/RJ11 connectors */
# define PCI_DEVICE_ID_RP8SNI 0x0008 /* Rocketport 8 port w/ DB78 SNI (Siemens) connector */
# define PCI_DEVICE_ID_RP16SNI 0x0009 /* Rocketport 16 port w/ DB78 SNI (Siemens) connector */
# define PCI_DEVICE_ID_RPP4 0x000A /* Rocketport Plus 4 port */
# define PCI_DEVICE_ID_RPP8 0x000B /* Rocketport Plus 8 port */
# define PCI_DEVICE_ID_RP6M 0x000C /* RocketModem 6 port */
# define PCI_DEVICE_ID_RP4M 0x000D /* RocketModem 4 port */
# define PCI_DEVICE_ID_RP2_232 0x000E /* Rocketport Plus 2 port RS232 */
# define PCI_DEVICE_ID_RP2_422 0x000F /* Rocketport Plus 2 port RS422 */
/* Universal PCI boards */
# define PCI_DEVICE_ID_URP32INTF 0x0801 /* Rocketport UPCI 32 port w/external I/F */
# define PCI_DEVICE_ID_URP8INTF 0x0802 /* Rocketport UPCI 8 port w/external I/F */
# define PCI_DEVICE_ID_URP16INTF 0x0803 /* Rocketport UPCI 16 port w/external I/F */
# define PCI_DEVICE_ID_URP8OCTA 0x0805 /* Rocketport UPCI 8 port w/octa cable */
# define PCI_DEVICE_ID_UPCI_RM3_8PORT 0x080C /* Rocketmodem III 8 port */
# define PCI_DEVICE_ID_UPCI_RM3_4PORT 0x080D /* Rocketmodem III 4 port */
/* Compact PCI device */
# define PCI_DEVICE_ID_CRP16INTF 0x0903 /* Rocketport Compact PCI 16 port w/external I/F */