blob: cf01b662aefc5b038da968d86ad5ac21413de253 (
plain)
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
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
|
/************************************************************************/
/* */
/* Title : SX Shared Memory Window Structure */
/* */
/* Author : N.P.Vassallo */
/* */
/* Creation : 16th March 1998 */
/* */
/* Version : 3.0.0 */
/* */
/* Copyright : (c) Specialix International Ltd. 1998 */
/* */
/* Description : Prototypes, structures and definitions */
/* describing the SX/SI/XIO cards shared */
/* memory window structure: */
/* SXCARD */
/* SXMODULE */
/* SXCHANNEL */
/* */
/************************************************************************/
/* History...
3.0.0 16/03/98 NPV Creation. (based on STRUCT.H)
*/
#ifndef _sxwindow_h /* If SXWINDOW.H not already defined */
#define _sxwindow_h 1
/*****************************************************************************
*************************** ***************************
*************************** Common Definitions ***************************
*************************** ***************************
*****************************************************************************/
typedef struct _SXCARD *PSXCARD; /* SXCARD structure pointer */
typedef struct _SXMODULE *PMOD; /* SXMODULE structure pointer */
typedef struct _SXCHANNEL *PCHAN; /* SXCHANNEL structure pointer */
/*****************************************************************************
********************************* *********************************
********************************* SXCARD *********************************
********************************* *********************************
*****************************************************************************/
typedef struct _SXCARD
{
BYTE cc_init_status; /* 0x00 Initialisation status */
BYTE cc_mem_size; /* 0x01 Size of memory on card */
WORD cc_int_count; /* 0x02 Interrupt count */
WORD cc_revision; /* 0x04 Download code revision */
BYTE cc_isr_count; /* 0x06 Count when ISR is run */
BYTE cc_main_count; /* 0x07 Count when main loop is run */
WORD cc_int_pending; /* 0x08 Interrupt pending */
WORD cc_poll_count; /* 0x0A Count when poll is run */
BYTE cc_int_set_count; /* 0x0C Count when host interrupt is set */
BYTE cc_rfu[0x80 - 0x0D]; /* 0x0D Pad structure to 128 bytes (0x80) */
} SXCARD;
/* SXCARD.cc_init_status definitions... */
#define ADAPTERS_FOUND (BYTE)0x01
#define NO_ADAPTERS_FOUND (BYTE)0xFF
/* SXCARD.cc_mem_size definitions... */
#define SX_MEMORY_SIZE (BYTE)0x40
/* SXCARD.cc_int_count definitions... */
#define INT_COUNT_DEFAULT 100 /* Hz */
/*****************************************************************************
******************************** ********************************
******************************** SXMODULE ********************************
******************************** ********************************
*****************************************************************************/
#define TOP_POINTER(a) ((a)|0x8000) /* Sets top bit of word */
#define UNTOP_POINTER(a) ((a)&~0x8000) /* Clears top bit of word */
typedef struct _SXMODULE
{
WORD mc_next; /* 0x00 Next module "pointer" (ORed with 0x8000) */
BYTE mc_type; /* 0x02 Type of TA in terms of number of channels */
BYTE mc_mod_no; /* 0x03 Module number on SI bus cable (0 closest to card) */
BYTE mc_dtr; /* 0x04 Private DTR copy (TA only) */
BYTE mc_rfu1; /* 0x05 Reserved */
WORD mc_uart; /* 0x06 UART base address for this module */
BYTE mc_chip; /* 0x08 Chip type / number of ports */
BYTE mc_current_uart; /* 0x09 Current uart selected for this module */
#ifdef DOWNLOAD
PCHAN mc_chan_pointer[8]; /* 0x0A Pointer to each channel structure */
#else
WORD mc_chan_pointer[8]; /* 0x0A Define as WORD if not compiling into download */
#endif
WORD mc_rfu2; /* 0x1A Reserved */
BYTE mc_opens1; /* 0x1C Number of open ports on first four ports on MTA/SXDC */
BYTE mc_opens2; /* 0x1D Number of open ports on second four ports on MTA/SXDC */
BYTE mc_mods; /* 0x1E Types of connector module attached to MTA/SXDC */
BYTE mc_rev1; /* 0x1F Revision of first CD1400 on MTA/SXDC */
BYTE mc_rev2; /* 0x20 Revision of second CD1400 on MTA/SXDC */
BYTE mc_mtaasic_rev; /* 0x21 Revision of MTA ASIC 1..4 -> A, B, C, D */
BYTE mc_rfu3[0x100 - 0x22]; /* 0x22 Pad structure to 256 bytes (0x100) */
} SXMODULE;
/* SXMODULE.mc_type definitions... */
#define FOUR_PORTS (BYTE)4
#define EIGHT_PORTS (BYTE)8
/* SXMODULE.mc_chip definitions... */
#define CHIP_MASK 0xF0
#define TA (BYTE)0
#define TA4 (TA | FOUR_PORTS)
#define TA8 (TA | EIGHT_PORTS)
#define TA4_ASIC (BYTE)0x0A
#define TA8_ASIC (BYTE)0x0B
#define MTA_CD1400 (BYTE)0x28
#define SXDC (BYTE)0x48
/* SXMODULE.mc_mods definitions... */
#define MOD_RS232DB25 0x00 /* RS232 DB25 (socket/plug) */
#define MOD_RS232RJ45 0x01 /* RS232 RJ45 (shielded/opto-isolated) */
#define MOD_RESERVED_2 0x02 /* Reserved (RS485) */
#define MOD_RS422DB25 0x03 /* RS422 DB25 Socket */
#define MOD_RESERVED_4 0x04 /* Reserved */
#define MOD_PARALLEL 0x05 /* Parallel */
#define MOD_RESERVED_6 0x06 /* Reserved (RS423) */
#define MOD_RESERVED_7 0x07 /* Reserved */
#define MOD_2_RS232DB25 0x08 /* Rev 2.0 RS232 DB25 (socket/plug) */
#define MOD_2_RS232RJ45 0x09 /* Rev 2.0 RS232 RJ45 */
#define MOD_RESERVED_A 0x0A /* Rev 2.0 Reserved */
#define MOD_2_RS422DB25 0x0B /* Rev 2.0 RS422 DB25 */
#define MOD_RESERVED_C 0x0C /* Rev 2.0 Reserved */
#define MOD_2_PARALLEL 0x0D /* Rev 2.0 Parallel */
#define MOD_RESERVED_E 0x0E /* Rev 2.0 Reserved */
#define MOD_BLANK 0x0F /* Blank Panel */
/*****************************************************************************
******************************** *******************************
******************************** SXCHANNEL *******************************
******************************** *******************************
*****************************************************************************/
#define TX_BUFF_OFFSET 0x60 /* Transmit buffer offset in channel structure */
#define BUFF_POINTER(a) (((a)+TX_BUFF_OFFSET)|0x8000)
#define UNBUFF_POINTER(a) (jet_channel*)(((a)&~0x8000)-TX_BUFF_OFFSET)
#define BUFFER_SIZE 256
#define HIGH_WATER ((BUFFER_SIZE / 4) * 3)
#define LOW_WATER (BUFFER_SIZE / 4)
typedef struct _SXCHANNEL
{
WORD next_item; /* 0x00 Offset from window base of next channels hi_txbuf (ORred with 0x8000) */
WORD addr_uart; /* 0x02 INTERNAL pointer to uart address. Includes FASTPATH bit */
WORD module; /* 0x04 Offset from window base of parent SXMODULE structure */
BYTE type; /* 0x06 Chip type / number of ports (copy of mc_chip) */
BYTE chan_number; /* 0x07 Channel number on the TA/MTA/SXDC */
WORD xc_status; /* 0x08 Flow control and I/O status */
BYTE hi_rxipos; /* 0x0A Receive buffer input index */
BYTE hi_rxopos; /* 0x0B Receive buffer output index */
BYTE hi_txopos; /* 0x0C Transmit buffer output index */
BYTE hi_txipos; /* 0x0D Transmit buffer input index */
BYTE hi_hstat; /* 0x0E Command register */
BYTE dtr_bit; /* 0x0F INTERNAL DTR control byte (TA only) */
BYTE txon; /* 0x10 INTERNAL copy of hi_txon */
BYTE txoff; /* 0x11 INTERNAL copy of hi_txoff */
BYTE rxon; /* 0x12 INTERNAL copy of hi_rxon */
BYTE rxoff; /* 0x13 INTERNAL copy of hi_rxoff */
BYTE hi_mr1; /* 0x14 Mode Register 1 (databits,parity,RTS rx flow)*/
BYTE hi_mr2; /* 0x15 Mode Register 2 (stopbits,local,CTS tx flow)*/
BYTE hi_csr; /* 0x16 Clock Select Register (baud rate) */
BYTE hi_op; /* 0x17 Modem Output Signal */
BYTE hi_ip; /* 0x18 Modem Input Signal */
BYTE hi_state; /* 0x19 Channel status */
BYTE hi_prtcl; /* 0x1A Channel protocol (flow control) */
BYTE hi_txon; /* 0x1B Transmit XON character */
BYTE hi_txoff; /* 0x1C Transmit XOFF character */
BYTE hi_rxon; /* 0x1D Receive XON character */
BYTE hi_rxoff; /* 0x1E Receive XOFF character */
BYTE close_prev; /* 0x1F INTERNAL channel previously closed flag */
BYTE hi_break; /* 0x20 Break and error control */
BYTE break_state; /* 0x21 INTERNAL copy of hi_break */
BYTE hi_mask; /* 0x22 Mask for received data */
BYTE mask; /* 0x23 INTERNAL copy of hi_mask */
BYTE mod_type; /* 0x24 MTA/SXDC hardware module type */
BYTE ccr_state; /* 0x25 INTERNAL MTA/SXDC state of CCR register */
BYTE ip_mask; /* 0x26 Input handshake mask */
BYTE hi_parallel; /* 0x27 Parallel port flag */
BYTE par_error; /* 0x28 Error code for parallel loopback test */
BYTE any_sent; /* 0x29 INTERNAL data sent flag */
BYTE asic_txfifo_size; /* 0x2A INTERNAL SXDC transmit FIFO size */
BYTE rfu1[2]; /* 0x2B Reserved */
BYTE csr; /* 0x2D INTERNAL copy of hi_csr */
#ifdef DOWNLOAD
PCHAN nextp; /* 0x2E Offset from window base of next channel structure */
#else
WORD nextp; /* 0x2E Define as WORD if not compiling into download */
#endif
BYTE prtcl; /* 0x30 INTERNAL copy of hi_prtcl */
BYTE mr1; /* 0x31 INTERNAL copy of hi_mr1 */
BYTE mr2; /* 0x32 INTERNAL copy of hi_mr2 */
BYTE hi_txbaud; /* 0x33 Extended transmit baud rate (SXDC only if((hi_csr&0x0F)==0x0F) */
BYTE hi_rxbaud; /* 0x34 Extended receive baud rate (SXDC only if((hi_csr&0xF0)==0xF0) */
BYTE txbreak_state; /* 0x35 INTERNAL MTA/SXDC transmit break state */
BYTE txbaud; /* 0x36 INTERNAL copy of hi_txbaud */
BYTE rxbaud; /* 0x37 INTERNAL copy of hi_rxbaud */
WORD err_framing; /* 0x38 Count of receive framing errors */
WORD err_parity; /* 0x3A Count of receive parity errors */
WORD err_overrun; /* 0x3C Count of receive overrun errors */
WORD err_overflow; /* 0x3E Count of receive buffer overflow errors */
BYTE rfu2[TX_BUFF_OFFSET - 0x40]; /* 0x40 Reserved until hi_txbuf */
BYTE hi_txbuf[BUFFER_SIZE]; /* 0x060 Transmit buffer */
BYTE hi_rxbuf[BUFFER_SIZE]; /* 0x160 Receive buffer */
BYTE rfu3[0x300 - 0x260]; /* 0x260 Reserved until 768 bytes (0x300) */
} SXCHANNEL;
/* SXCHANNEL.addr_uart definitions... */
#define FASTPATH 0x1000 /* Set to indicate fast rx/tx processing (TA only) */
/* SXCHANNEL.xc_status definitions... */
#define X_TANY 0x0001 /* XON is any character (TA only) */
#define X_TION 0x0001 /* Tx interrupts on (MTA only) */
#define X_TXEN 0x0002 /* Tx XON/XOFF enabled (TA only) */
#define X_RTSEN 0x0002 /* RTS FLOW enabled (MTA only) */
#define X_TXRC 0x0004 /* XOFF received (TA only) */
#define X_RTSLOW 0x0004 /* RTS dropped (MTA only) */
#define X_RXEN 0x0008 /* Rx XON/XOFF enabled */
#define X_ANYXO 0x0010 /* XOFF pending/sent or RTS dropped */
#define X_RXSE 0x0020 /* Rx XOFF sent */
#define X_NPEND 0x0040 /* Rx XON pending or XOFF pending */
#define X_FPEND 0x0080 /* Rx XOFF pending */
#define C_CRSE 0x0100 /* Carriage return sent (TA only) */
#define C_TEMR 0x0100 /* Tx empty requested (MTA only) */
#define C_TEMA 0x0200 /* Tx empty acked (MTA only) */
#define C_ANYP 0x0200 /* Any protocol bar tx XON/XOFF (TA only) */
#define C_EN 0x0400 /* Cooking enabled (on MTA means port is also || */
#define C_HIGH 0x0800 /* Buffer previously hit high water */
#define C_CTSEN 0x1000 /* CTS automatic flow-control enabled */
#define C_DCDEN 0x2000 /* DCD/DTR checking enabled */
#define C_BREAK 0x4000 /* Break detected */
#define C_RTSEN 0x8000 /* RTS automatic flow control enabled (MTA only) */
#define C_PARITY 0x8000 /* Parity checking enabled (TA only) */
/* SXCHANNEL.hi_hstat definitions... */
#define HS_IDLE_OPEN 0x00 /* Channel open state */
#define HS_LOPEN 0x02 /* Local open command (no modem monitoring) */
#define HS_MOPEN 0x04 /* Modem open command (wait for DCD signal) */
#define HS_IDLE_MPEND 0x06 /* Waiting for DCD signal state */
#define HS_CONFIG 0x08 /* Configuration command */
#define HS_CLOSE 0x0A /* Close command */
#define HS_START 0x0C /* Start transmit break command */
#define HS_STOP 0x0E /* Stop transmit break command */
#define HS_IDLE_CLOSED 0x10 /* Closed channel state */
#define HS_IDLE_BREAK 0x12 /* Transmit break state */
#define HS_FORCE_CLOSED 0x14 /* Force close command */
#define HS_RESUME 0x16 /* Clear pending XOFF command */
#define HS_WFLUSH 0x18 /* Flush transmit buffer command */
#define HS_RFLUSH 0x1A /* Flush receive buffer command */
#define HS_SUSPEND 0x1C /* Suspend output command (like XOFF received) */
#define PARALLEL 0x1E /* Parallel port loopback test command (Diagnostics Only) */
#define ENABLE_RX_INTS 0x20 /* Enable receive interrupts command (Diagnostics Only) */
#define ENABLE_TX_INTS 0x22 /* Enable transmit interrupts command (Diagnostics Only) */
#define ENABLE_MDM_INTS 0x24 /* Enable modem interrupts command (Diagnostics Only) */
#define DISABLE_INTS 0x26 /* Disable interrupts command (Diagnostics Only) */
/* SXCHANNEL.hi_mr1 definitions... */
#define MR1_BITS 0x03 /* Data bits mask */
#define MR1_5_BITS 0x00 /* 5 data bits */
#define MR1_6_BITS 0x01 /* 6 data bits */
#define MR1_7_BITS 0x02 /* 7 data bits */
#define MR1_8_BITS 0x03 /* 8 data bits */
#define MR1_PARITY 0x1C /* Parity mask */
#define MR1_ODD 0x04 /* Odd parity */
#define MR1_EVEN 0x00 /* Even parity */
#define MR1_WITH 0x00 /* Parity enabled */
#define MR1_FORCE 0x08 /* Force parity */
#define MR1_NONE 0x10 /* No parity */
#define MR1_NOPARITY MR1_NONE /* No parity */
#define MR1_ODDPARITY (MR1_WITH|MR1_ODD) /* Odd parity */
#define MR1_EVENPARITY (MR1_WITH|MR1_EVEN) /* Even parity */
#define MR1_MARKPARITY (MR1_FORCE|MR1_ODD) /* Mark parity */
#define MR1_SPACEPARITY (MR1_FORCE|MR1_EVEN) /* Space parity */
#define MR1_RTS_RXFLOW 0x80 /* RTS receive flow control */
/* SXCHANNEL.hi_mr2 definitions... */
#define MR2_STOP 0x0F /* Stop bits mask */
#define MR2_1_STOP 0x07 /* 1 stop bit */
#define MR2_2_STOP 0x0F /* 2 stop bits */
#define MR2_CTS_TXFLOW 0x10 /* CTS transmit flow control */
#define MR2_RTS_TOGGLE 0x20 /* RTS toggle on transmit */
#define MR2_NORMAL 0x00 /* Normal mode */
#define MR2_AUTO 0x40 /* Auto-echo mode (TA only) */
#define MR2_LOCAL 0x80 /* Local echo mode */
#define MR2_REMOTE 0xC0 /* Remote echo mode (TA only) */
/* SXCHANNEL.hi_csr definitions... */
#define CSR_75 0x0 /* 75 baud */
#define CSR_110 0x1 /* 110 baud (TA), 115200 (MTA/SXDC) */
#define CSR_38400 0x2 /* 38400 baud */
#define CSR_150 0x3 /* 150 baud */
#define CSR_300 0x4 /* 300 baud */
#define CSR_600 0x5 /* 600 baud */
#define CSR_1200 0x6 /* 1200 baud */
#define CSR_2000 0x7 /* 2000 baud */
#define CSR_2400 0x8 /* 2400 baud */
#define CSR_4800 0x9 /* 4800 baud */
#define CSR_1800 0xA /* 1800 baud */
#define CSR_9600 0xB /* 9600 baud */
#define CSR_19200 0xC /* 19200 baud */
#define CSR_57600 0xD /* 57600 baud */
#define CSR_EXTBAUD 0xF /* Extended baud rate (hi_txbaud/hi_rxbaud) */
/* SXCHANNEL.hi_op definitions... */
#define OP_RTS 0x01 /* RTS modem output signal */
#define OP_DTR 0x02 /* DTR modem output signal */
/* SXCHANNEL.hi_ip definitions... */
#define IP_CTS 0x02 /* CTS modem input signal */
#define IP_DCD 0x04 /* DCD modem input signal */
#define IP_DSR 0x20 /* DTR modem input signal */
#define IP_RI 0x40 /* RI modem input signal */
/* SXCHANNEL.hi_state definitions... */
#define ST_BREAK 0x01 /* Break received (clear with config) */
#define ST_DCD 0x02 /* DCD signal changed state */
/* SXCHANNEL.hi_prtcl definitions... */
#define SP_TANY 0x01 /* Transmit XON/XANY (if SP_TXEN enabled) */
#define SP_TXEN 0x02 /* Transmit XON/XOFF flow control */
#define SP_CEN 0x04 /* Cooking enabled */
#define SP_RXEN 0x08 /* Rx XON/XOFF enabled */
#define SP_DCEN 0x20 /* DCD / DTR check */
#define SP_DTR_RXFLOW 0x40 /* DTR receive flow control */
#define SP_PAEN 0x80 /* Parity checking enabled */
/* SXCHANNEL.hi_break definitions... */
#define BR_IGN 0x01 /* Ignore any received breaks */
#define BR_INT 0x02 /* Interrupt on received break */
#define BR_PARMRK 0x04 /* Enable parmrk parity error processing */
#define BR_PARIGN 0x08 /* Ignore chars with parity errors */
#define BR_ERRINT 0x80 /* Treat parity/framing/overrun errors as exceptions */
/* SXCHANNEL.par_error definitions.. */
#define DIAG_IRQ_RX 0x01 /* Indicate serial receive interrupt (diags only) */
#define DIAG_IRQ_TX 0x02 /* Indicate serial transmit interrupt (diags only) */
#define DIAG_IRQ_MD 0x04 /* Indicate serial modem interrupt (diags only) */
/* SXCHANNEL.hi_txbaud/hi_rxbaud definitions... (SXDC only) */
#define BAUD_75 0x00 /* 75 baud */
#define BAUD_115200 0x01 /* 115200 baud */
#define BAUD_38400 0x02 /* 38400 baud */
#define BAUD_150 0x03 /* 150 baud */
#define BAUD_300 0x04 /* 300 baud */
#define BAUD_600 0x05 /* 600 baud */
#define BAUD_1200 0x06 /* 1200 baud */
#define BAUD_2000 0x07 /* 2000 baud */
#define BAUD_2400 0x08 /* 2400 baud */
#define BAUD_4800 0x09 /* 4800 baud */
#define BAUD_1800 0x0A /* 1800 baud */
#define BAUD_9600 0x0B /* 9600 baud */
#define BAUD_19200 0x0C /* 19200 baud */
#define BAUD_57600 0x0D /* 57600 baud */
#define BAUD_230400 0x0E /* 230400 baud */
#define BAUD_460800 0x0F /* 460800 baud */
#define BAUD_921600 0x10 /* 921600 baud */
#define BAUD_50 0x11 /* 50 baud */
#define BAUD_110 0x12 /* 110 baud */
#define BAUD_134_5 0x13 /* 134.5 baud */
#define BAUD_200 0x14 /* 200 baud */
#define BAUD_7200 0x15 /* 7200 baud */
#define BAUD_56000 0x16 /* 56000 baud */
#define BAUD_64000 0x17 /* 64000 baud */
#define BAUD_76800 0x18 /* 76800 baud */
#define BAUD_128000 0x19 /* 128000 baud */
#define BAUD_150000 0x1A /* 150000 baud */
#define BAU
|