Linux v2.6.15-rc6
[pohmelfs.git] / include / linux / sdla_fr.h
blobcdfa77fcb06b0a562b1bcc35a136e2f01850c62c
1 /*****************************************************************************
2 * sdla_fr.h Sangoma frame relay firmware API definitions.
4 * Author: Gideon Hack
5 * Nenad Corbic <ncorbic@sangoma.com>
7 * Copyright: (c) 1995-2000 Sangoma Technologies Inc.
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version
12 * 2 of the License, or (at your option) any later version.
13 * ============================================================================
14 * Oct 04, 1999 Gideon Hack Updated API structures
15 * Jun 02, 1999 Gideon Hack Modifications for S514 support
16 * Oct 12, 1997 Jaspreet Singh Added FR_READ_DLCI_IB_MAPPING
17 * Jul 21, 1997 Jaspreet Singh Changed FRRES_TOO_LONG and FRRES_TOO_MANY to
18 * 0x05 and 0x06 respectively.
19 * Dec 23, 1996 Gene Kozin v2.0
20 * Apr 29, 1996 Gene Kozin v1.0 (merged version S502 & S508 definitions).
21 * Sep 26, 1995 Gene Kozin Initial version.
22 *****************************************************************************/
23 #ifndef _SDLA_FR_H
24 #define _SDLA_FR_H
26 /*----------------------------------------------------------------------------
27 * Notes:
28 * ------
29 * 1. All structures defined in this file are byte-alined.
31 * Compiler Platform
32 * -------- --------
33 * GNU C Linux
36 #ifndef PACKED
37 # define PACKED __attribute__((packed))
38 #endif /* PACKED */
40 /* Adapter memory layout */
41 #define FR_MB_VECTOR 0xE000 /* mailbox window vector */
42 #define FR502_RX_VECTOR 0xA000 /* S502 direct receive window vector */
43 #define FR502_MBOX_OFFS 0xF60 /* S502 mailbox offset */
44 #define FR508_MBOX_OFFS 0 /* S508 mailbox offset */
45 #define FR502_FLAG_OFFS 0x1FF0 /* S502 status flags offset */
46 #define FR508_FLAG_OFFS 0x1000 /* S508 status flags offset */
47 #define FR502_RXMB_OFFS 0x900 /* S502 direct receive mailbox offset */
48 #define FR508_TXBC_OFFS 0x1100 /* S508 Tx buffer info offset */
49 #define FR508_RXBC_OFFS 0x1120 /* S508 Rx buffer info offset */
51 /* Important constants */
52 #define FR502_MAX_DATA 4096 /* maximum data buffer length */
53 #define FR508_MAX_DATA 4080 /* maximum data buffer length */
54 #define MIN_LGTH_FR_DATA_CFG 300 /* min Information frame length
55 (for configuration purposes) */
56 #define FR_MAX_NO_DATA_BYTES_IN_FRAME 15354 /* max Information frame length */
58 #define HIGHEST_VALID_DLCI 991
60 /****** Data Structures *****************************************************/
62 /*----------------------------------------------------------------------------
63 * Frame relay command block.
65 typedef struct fr_cmd
67 unsigned char command PACKED; /* command code */
68 unsigned short length PACKED; /* length of data buffer */
69 unsigned char result PACKED; /* return code */
70 unsigned short dlci PACKED; /* DLCI number */
71 unsigned char attr PACKED; /* FECN, BECN, DE and C/R bits */
72 unsigned short rxlost1 PACKED; /* frames discarded at int. level */
73 unsigned long rxlost2 PACKED; /* frames discarded at app. level */
74 unsigned char rsrv[2] PACKED; /* reserved for future use */
75 } fr_cmd_t;
77 /* 'command' field defines */
78 #define FR_WRITE 0x01
79 #define FR_READ 0x02
80 #define FR_ISSUE_IS_FRAME 0x03
81 #define FR_SET_CONFIG 0x10
82 #define FR_READ_CONFIG 0x11
83 #define FR_COMM_DISABLE 0x12
84 #define FR_COMM_ENABLE 0x13
85 #define FR_READ_STATUS 0x14
86 #define FR_READ_STATISTICS 0x15
87 #define FR_FLUSH_STATISTICS 0x16
88 #define FR_LIST_ACTIVE_DLCI 0x17
89 #define FR_FLUSH_DATA_BUFFERS 0x18
90 #define FR_READ_ADD_DLC_STATS 0x19
91 #define FR_ADD_DLCI 0x20
92 #define FR_DELETE_DLCI 0x21
93 #define FR_ACTIVATE_DLCI 0x22
94 #define FR_DEACTIVATE_DLCI 0x22
95 #define FR_READ_MODEM_STATUS 0x30
96 #define FR_SET_MODEM_STATUS 0x31
97 #define FR_READ_ERROR_STATS 0x32
98 #define FR_FLUSH_ERROR_STATS 0x33
99 #define FR_READ_DLCI_IB_MAPPING 0x34
100 #define FR_READ_CODE_VERSION 0x40
101 #define FR_SET_INTR_MODE 0x50
102 #define FR_READ_INTR_MODE 0x51
103 #define FR_SET_TRACE_CONFIG 0x60
104 #define FR_FT1_STATUS_CTRL 0x80
105 #define FR_SET_FT1_MODE 0x81
107 /* Special UDP drivers management commands */
108 #define FPIPE_ENABLE_TRACING 0x41
109 #define FPIPE_DISABLE_TRACING 0x42
110 #define FPIPE_GET_TRACE_INFO 0x43
111 #define FPIPE_FT1_READ_STATUS 0x44
112 #define FPIPE_DRIVER_STAT_IFSEND 0x45
113 #define FPIPE_DRIVER_STAT_INTR 0x46
114 #define FPIPE_DRIVER_STAT_GEN 0x47
115 #define FPIPE_FLUSH_DRIVER_STATS 0x48
116 #define FPIPE_ROUTER_UP_TIME 0x49
118 /* 'result' field defines */
119 #define FRRES_OK 0x00 /* command executed successfully */
120 #define FRRES_DISABLED 0x01 /* communications not enabled */
121 #define FRRES_INOPERATIVE 0x02 /* channel inoperative */
122 #define FRRES_DLCI_INACTIVE 0x03 /* DLCI is inactive */
123 #define FRRES_DLCI_INVALID 0x04 /* DLCI is not configured */
124 #define FRRES_TOO_LONG 0x05
125 #define FRRES_TOO_MANY 0x06
126 #define FRRES_CIR_OVERFLOW 0x07 /* Tx throughput has exceeded CIR */
127 #define FRRES_BUFFER_OVERFLOW 0x08
128 #define FRRES_MODEM_FAILURE 0x10 /* DCD and/or CTS dropped */
129 #define FRRES_CHANNEL_DOWN 0x11 /* channel became inoperative */
130 #define FRRES_CHANNEL_UP 0x12 /* channel became operative */
131 #define FRRES_DLCI_CHANGE 0x13 /* DLCI status (or number) changed */
132 #define FRRES_DLCI_MISMATCH 0x14
133 #define FRRES_INVALID_CMD 0x1F /* invalid command */
135 /* 'attr' field defines */
136 #define FRATTR_
138 /*----------------------------------------------------------------------------
139 * Frame relay mailbox.
140 * This structure is located at offset FR50?_MBOX_OFFS into FR_MB_VECTOR.
141 * For S502 it is also located at offset FR502_RXMB_OFFS into
142 * FR502_RX_VECTOR.
144 typedef struct fr_mbox
146 unsigned char opflag PACKED; /* 00h: execution flag */
147 fr_cmd_t cmd PACKED; /* 01h: command block */
148 unsigned char data[1] PACKED; /* 10h: variable length data buffer */
149 } fr_mbox_t;
151 /*----------------------------------------------------------------------------
152 * S502 frame relay status flags.
153 * This structure is located at offset FR502_FLAG_OFFS into FR_MB_VECTOR.
155 typedef struct fr502_flags
157 unsigned char rsrv1[1] PACKED; /* 00h: */
158 unsigned char tx_ready PACKED; /* 01h: Tx buffer available */
159 unsigned char rx_ready PACKED; /* 02h: Rx frame available */
160 unsigned char event PACKED; /* 03h: asynchronous event */
161 unsigned char mstatus PACKED; /* 04h: modem status */
162 unsigned char rsrv2[8] PACKED; /* 05h: */
163 unsigned char iflag PACKED; /* 0Dh: interrupt flag */
164 unsigned char imask PACKED; /* 0Eh: interrupt mask */
165 } fr502_flags_t;
167 /*----------------------------------------------------------------------------
168 * S508 frame relay status flags.
169 * This structure is located at offset FR508_FLAG_OFFS into FR_MB_VECTOR.
171 typedef struct fr508_flags
173 unsigned char rsrv1[3] PACKED; /* 00h: reserved */
174 unsigned char event PACKED; /* 03h: asynchronous event */
175 unsigned char mstatus PACKED; /* 04h: modem status */
176 unsigned char rsrv2[11] PACKED; /* 05h: reserved */
177 unsigned char iflag PACKED; /* 10h: interrupt flag */
178 unsigned char imask PACKED; /* 11h: interrupt mask */
179 unsigned long tse_offs PACKED; /* 12h: Tx status element */
180 unsigned short dlci PACKED; /* 16h: DLCI NUMBER */
181 } fr508_flags_t;
183 /* 'event' field defines */
184 #define FR_EVENT_STATUS 0x01 /* channel status change */
185 #define FR_EVENT_DLC_STATUS 0x02 /* DLC status change */
186 #define FR_EVENT_BAD_DLCI 0x04 /* FSR included wrong DLCI */
187 #define FR_EVENT_LINK_DOWN 0x40 /* DCD or CTS low */
189 /* 'mstatus' field defines */
190 #define FR_MDM_DCD 0x08 /* mdm_status: DCD */
191 #define FR_MDM_CTS 0x20 /* mdm_status: CTS */
193 /* 'iflag' & 'imask' fields defines */
194 #define FR_INTR_RXRDY 0x01 /* Rx ready */
195 #define FR_INTR_TXRDY 0x02 /* Tx ready */
196 #define FR_INTR_MODEM 0x04 /* modem status change (DCD, CTS) */
197 #define FR_INTR_READY 0x08 /* interface command completed */
198 #define FR_INTR_DLC 0x10 /* DLC status change */
199 #define FR_INTR_TIMER 0x20 /* millisecond timer */
200 #define FR_INTR_TX_MULT_DLCIs 0x80 /* Tx interrupt on multiple DLCIs */
203 /*----------------------------------------------------------------------------
204 * Receive Buffer Configuration Info. S508 only!
205 * This structure is located at offset FR508_RXBC_OFFS into FR_MB_VECTOR.
207 typedef struct fr_buf_info
209 unsigned short rse_num PACKED; /* 00h: number of status elements */
210 unsigned long rse_base PACKED; /* 02h: receive status array base */
211 unsigned long rse_next PACKED; /* 06h: next status element */
212 unsigned long buf_base PACKED; /* 0Ah: rotational buffer base */
213 unsigned short reserved PACKED; /* 0Eh: */
214 unsigned long buf_top PACKED; /* 10h: rotational buffer top */
215 } fr_buf_info_t;
217 /*----------------------------------------------------------------------------
218 * Buffer Status Element. S508 only!
219 * Array of structures of this type is located at offset defined by the
220 * 'rse_base' field of the frBufInfo_t structure into absolute adapter
221 * memory address space.
223 typedef struct fr_rx_buf_ctl
225 unsigned char flag PACKED; /* 00h: ready flag */
226 unsigned short length PACKED; /* 01h: frame length */
227 unsigned short dlci PACKED; /* 03h: DLCI */
228 unsigned char attr PACKED; /* 05h: FECN/BECN/DE/CR */
229 unsigned short tmstamp PACKED; /* 06h: time stamp */
230 unsigned short rsrv[2] PACKED; /* 08h: */
231 unsigned long offset PACKED; /* 0Ch: buffer absolute address */
232 } fr_rx_buf_ctl_t;
234 typedef struct fr_tx_buf_ctl
236 unsigned char flag PACKED; /* 00h: ready flag */
237 unsigned short rsrv0[2] PACKED; /* 01h: */
238 unsigned short length PACKED; /* 05h: frame length */
239 unsigned short dlci PACKED; /* 07h: DLCI */
240 unsigned char attr PACKED; /* 09h: FECN/BECN/DE/CR */
241 unsigned short rsrv1 PACKED; /* 0Ah: */
242 unsigned long offset PACKED; /* 0Ch: buffer absolute address */
243 } fr_tx_buf_ctl_t;
245 /*----------------------------------------------------------------------------
246 * Global Configuration Block. Passed to FR_SET_CONFIG command when dlci == 0.
248 typedef struct fr_conf
250 unsigned short station PACKED; /* 00h: CPE/Node */
251 unsigned short options PACKED; /* 02h: configuration options */
252 unsigned short kbps PACKED; /* 04h: baud rate in kbps */
253 unsigned short port PACKED; /* 06h: RS-232/V.35 */
254 unsigned short mtu PACKED; /* 08h: max. transmit length */
255 unsigned short t391 PACKED; /* 0Ah: */
256 unsigned short t392 PACKED; /* 0Ch: */
257 unsigned short n391 PACKED; /* 0Eh: */
258 unsigned short n392 PACKED; /* 10h: */
259 unsigned short n393 PACKED; /* 12h: */
260 unsigned short cir_fwd PACKED; /* 14h: */
261 unsigned short bc_fwd PACKED; /* 16h: */
262 unsigned short be_fwd PACKED; /* 18h: */
263 unsigned short cir_bwd PACKED; /* 1Ah: */
264 unsigned short bc_bwd PACKED; /* 1Ch: */
265 unsigned short be_bwd PACKED; /* 1Eh: */
266 unsigned short dlci[0] PACKED; /* 20h: */
267 } fr_conf_t;
269 /* 'station_type' defines */
270 #define FRCFG_STATION_CPE 0
271 #define FRCFG_STATION_NODE 1
273 /* 'conf_flags' defines */
274 #define FRCFG_IGNORE_TX_CIR 0x0001
275 #define FRCFG_IGNORE_RX_CIR 0x0002
276 #define FRCFG_DONT_RETRANSMIT 0x0004
277 #define FRCFG_IGNORE_CBS 0x0008
278 #define FRCFG_THROUGHPUT 0x0010 /* enable throughput calculation */
279 #define FRCFG_DIRECT_RX 0x0080 /* enable direct receive buffer */
280 #define FRCFG_AUTO_CONFIG 0x8000 /* enable auto DLCI configuration */
282 /* 'baud_rate' defines */
283 #define FRCFG_BAUD_1200 12
284 #define FRCFG_BAUD_2400 24
285 #define FRCFG_BAUD_4800 48
286 #define FRCFG_BAUD_9600 96
287 #define FRCFG_BAUD_19200 19
288 #define FRCFG_BAUD_38400 38
289 #define FRCFG_BAUD_56000 56
290 #define FRCFG_BAUD_64000 64
291 #define FRCFG_BAUD_128000 128
293 /* 'port_mode' defines */
294 #define FRCFG_MODE_EXT_CLK 0x0000
295 #define FRCFG_MODE_INT_CLK 0x0001
296 #define FRCFG_MODE_V35 0x0000 /* S508 only */
297 #define FRCFG_MODE_RS232 0x0002 /* S508 only */
299 /* defines for line tracing */
301 /* the line trace status element presented by the frame relay code */
302 typedef struct {
303 unsigned char flag PACKED; /* ready flag */
304 unsigned short length PACKED; /* trace length */
305 unsigned char rsrv0[2] PACKED; /* reserved */
306 unsigned char attr PACKED; /* trace attributes */
307 unsigned short tmstamp PACKED; /* time stamp */
308 unsigned char rsrv1[4] PACKED; /* reserved */
309 unsigned long offset PACKED; /* buffer absolute address */
310 } fr_trc_el_t;
312 typedef struct {
313 unsigned char status PACKED; /* status flag */
314 unsigned char data_passed PACKED; /* 0 if no data passed, 1 if */
315 /* data passed */
316 unsigned short length PACKED; /* frame length */
317 unsigned short tmstamp PACKED; /* time stamp */
318 } fpipemon_trc_hdr_t;
320 typedef struct {
321 fpipemon_trc_hdr_t fpipemon_trc_hdr PACKED;
322 unsigned char data[FR_MAX_NO_DATA_BYTES_IN_FRAME] PACKED;
323 } fpipemon_trc_t;
325 /* bit settings for the 'status' byte - note that bits 1, 2 and 3 are used */
326 /* for returning the number of frames being passed to fpipemon */
327 #define TRC_OUTGOING_FRM 0x01
328 #define TRC_ABORT_ERROR 0x10
329 #define TRC_CRC_ERROR 0x20
330 #define TRC_OVERRUN_ERROR 0x40
331 #define MORE_TRC_DATA 0x80
333 #define MAX_FRMS_TRACED 0x07
335 #define NO_TRC_ELEMENTS_OFF 0x9000
336 #define BASE_TRC_ELEMENTS_OFF 0x9002
337 #define TRC_ACTIVE 0x01
338 #define FLUSH_TRC_BUFFERS 0x02
339 #define FLUSH_TRC_STATISTICS 0x04
340 #define TRC_SIGNALLING_FRMS 0x10
341 #define TRC_INFO_FRMS 0x20
342 #define ACTIVATE_TRC (TRC_ACTIVE | TRC_SIGNALLING_FRMS | TRC_INFO_FRMS)
343 #define RESET_TRC (FLUSH_TRC_BUFFERS | FLUSH_TRC_STATISTICS)
345 /*----------------------------------------------------------------------------
346 * Channel configuration.
347 * This structure is passed to the FR_SET_CONFIG command when dlci != 0.
349 typedef struct fr_dlc_conf
351 unsigned short conf_flags PACKED; /* 00h: configuration bits */
352 unsigned short cir_fwd PACKED; /* 02h: */
353 unsigned short bc_fwd PACKED; /* 04h: */
354 unsigned short be_fwd PACKED; /* 06h: */
355 unsigned short cir_bwd PACKED; /* 08h: */
356 unsigned short bc_bwd PACKED; /* 0Ah: */
357 unsigned short be_bwd PACKED; /* 0Ch: */
358 } fr_dlc_conf_t;
360 /*----------------------------------------------------------------------------
361 * S502 interrupt mode control block.
362 * This structure is passed to the FR_SET_INTR_FLAGS and returned by the
363 * FR_READ_INTR_FLAGS commands.
365 typedef struct fr502_intr_ctl
367 unsigned char mode PACKED; /* 00h: interrupt enable flags */
368 unsigned short tx_len PACKED; /* 01h: required Tx buffer size */
369 } fr502_intr_ctl_t;
371 /*----------------------------------------------------------------------------
372 * S508 interrupt mode control block.
373 * This structure is passed to the FR_SET_INTR_FLAGS and returned by the
374 * FR_READ_INTR_FLAGS commands.
376 typedef struct fr508_intr_ctl
378 unsigned char mode PACKED; /* 00h: interrupt enable flags */
379 unsigned short tx_len PACKED; /* 01h: required Tx buffer size */
380 unsigned char irq PACKED; /* 03h: IRQ level to activate */
381 unsigned char flags PACKED; /* 04h: ?? */
382 unsigned short timeout PACKED; /* 05h: ms, for timer interrupt */
383 } fr508_intr_ctl_t;
385 /*----------------------------------------------------------------------------
386 * Channel status.
387 * This structure is returned by the FR_READ_STATUS command.
389 typedef struct fr_dlc_Status
391 unsigned char status PACKED; /* 00h: link/DLCI status */
392 struct
394 unsigned short dlci PACKED; /* 01h: DLCI number */
395 unsigned char status PACKED; /* 03h: DLCI status */
396 } circuit[1] PACKED;
397 } fr_dlc_status_t;
399 /* 'status' defines */
400 #define FR_LINK_INOPER 0x00 /* for global status (DLCI == 0) */
401 #define FR_LINK_OPER 0x01
402 #define FR_DLCI_DELETED 0x01 /* for circuit status (DLCI != 0) */
403 #define FR_DLCI_ACTIVE 0x02
404 #define FR_DLCI_WAITING 0x04
405 #define FR_DLCI_NEW 0x08
406 #define FR_DLCI_REPORT 0x40
408 /*----------------------------------------------------------------------------
409 * Global Statistics Block.
410 * This structure is returned by the FR_READ_STATISTICS command when
411 * dcli == 0.
413 typedef struct fr_link_stat
415 unsigned short rx_too_long PACKED; /* 00h: */
416 unsigned short rx_dropped PACKED; /* 02h: */
417 unsigned short rx_dropped2 PACKED; /* 04h: */
418 unsigned short rx_bad_dlci PACKED; /* 06h: */
419 unsigned short rx_bad_format PACKED; /* 08h: */
420 unsigned short retransmitted PACKED; /* 0Ah: */
421 unsigned short cpe_tx_FSE PACKED; /* 0Ch: */
422 unsigned short cpe_tx_LIV PACKED; /* 0Eh: */
423 unsigned short cpe_rx_FSR PACKED; /* 10h: */
424 unsigned short cpe_rx_LIV PACKED; /* 12h: */
425 unsigned short node_rx_FSE PACKED; /* 14h: */
426 unsigned short node_rx_LIV PACKED; /* 16h: */
427 unsigned short node_tx_FSR PACKED; /* 18h: */
428 unsigned short node_tx_LIV PACKED; /* 1Ah: */
429 unsigned short rx_ISF_err PACKED; /* 1Ch: */
430 unsigned short rx_unsolicited PACKED; /* 1Eh: */
431 unsigned short rx_SSN_err PACKED; /* 20h: */
432 unsigned short rx_RSN_err PACKED; /* 22h: */
433 unsigned short T391_timeouts PACKED; /* 24h: */
434 unsigned short T392_timeouts PACKED; /* 26h: */
435 unsigned short N392_reached PACKED; /* 28h: */
436 unsigned short cpe_SSN_RSN PACKED; /* 2Ah: */
437 unsigned short current_SSN PACKED; /* 2Ch: */
438 unsigned short current_RSN PACKED; /* 2Eh: */
439 unsigned short curreny_T391 PACKED; /* 30h: */
440 unsigned short current_T392 PACKED; /* 32h: */
441 unsigned short current_N392 PACKED; /* 34h: */
442 unsigned short current_N393 PACKED; /* 36h: */
443 } fr_link_stat_t;
445 /*----------------------------------------------------------------------------
446 * DLCI statistics.
447 * This structure is returned by the FR_READ_STATISTICS command when
448 * dlci != 0.
450 typedef struct fr_dlci_stat
452 unsigned long tx_frames PACKED; /* 00h: */
453 unsigned long tx_bytes PACKED; /* 04h: */
454 unsigned long rx_frames PACKED; /* 08h: */
455 unsigned long rx_bytes PACKED; /* 0Ch: */
456 unsigned long rx_dropped PACKED; /* 10h: */
457 unsigned long rx_inactive PACKED; /* 14h: */
458 unsigned long rx_exceed_CIR PACKED; /* 18h: */
459 unsigned long rx_DE_set PACKED; /* 1Ch: */
460 unsigned long tx_throughput PACKED; /* 20h: */
461 unsigned long tx_calc_timer PACKED; /* 24h: */
462 unsigned long rx_throughput PACKED; /* 28h: */
463 unsigned long rx_calc_timer PACKED; /* 2Ch: */
464 } fr_dlci_stat_t;
466 /*----------------------------------------------------------------------------
467 * Communications error statistics.
468 * This structure is returned by the FR_READ_ERROR_STATS command.
470 typedef struct fr_comm_stat
472 unsigned char rx_overruns PACKED; /* 00h: */
473 unsigned char rx_bad_crc PACKED; /* 01h: */
474 unsigned char rx_aborts PACKED; /* 02h: */
475 unsigned char rx_too_long PACKED; /* 03h: */
476 unsigned char tx_aborts PACKED; /* 04h: */
477 unsigned char tx_underruns PACKED; /* 05h: */
478 unsigned char tx_missed_undr PACKED; /* 06h: */
479 unsigned char dcd_dropped PACKED; /* 07h: */
480 unsigned char cts_dropped PACKED; /* 08h: */
481 } fr_comm_stat_t;
483 /*----------------------------------------------------------------------------
484 * Defines for the FR_ISSUE_IS_FRAME command.
486 #define FR_ISF_LVE 2 /* issue Link Verification Enquiry */
487 #define FR_ISF_FSE 3 /* issue Full Status Enquiry */
489 /*----------------------------------------------------------------------------
490 * Frame Relay ARP Header -- Used for Dynamic route creation with InvARP
493 typedef struct arphdr_fr
495 unsigned short ar_hrd PACKED; /* format of hardware addr */
496 unsigned short ar_pro PACKED; /* format of protocol addr */
497 unsigned char ar_hln PACKED; /* length of hardware addr */
498 unsigned char ar_pln PACKED; /* length of protocol addr */
499 unsigned short ar_op PACKED; /* ARP opcode */
500 unsigned short ar_sha PACKED; /* Sender DLCI addr 2 bytes */
501 unsigned long ar_sip PACKED; /* Sender IP addr 4 bytes */
502 unsigned short ar_tha PACKED; /* Target DLCI addr 2 bytes */
503 unsigned long ar_tip PACKED; /* Target IP addr 4 bytes */
504 } arphdr_fr_t;
506 /*----------------------------------------------------------------------------
507 * Frame Relay RFC 1490 SNAP Header -- Used to check for ARP packets
509 typedef struct arphdr_1490
511 unsigned char control PACKED; /* UI, etc... */
512 unsigned char pad PACKED; /* Pad */
513 unsigned char NLPID PACKED; /* SNAP */
514 unsigned char OUI[3] PACKED; /* Ethertype, etc... */
515 unsigned short PID PACKED; /* ARP, IP, etc... */
516 } arphdr_1490_t;
518 /* UDP/IP packet (for UDP management) layout */
520 /* The embedded control block for UDP mgmt
521 This is essentially a mailbox structure, without the large data field */
523 typedef struct {
524 unsigned char opp_flag PACKED; /* the opp flag */
525 unsigned char command PACKED; /* command code */
526 unsigned short length PACKED; /* length of data buffer */
527 unsigned char result PACKED; /* return code */
528 unsigned short dlci PACKED; /* DLCI number */
529 unsigned char attr PACKED; /* FECN, BECN, DE and C/R bits */
530 unsigned short rxlost1 PACKED; /* frames discarded at int. level */
531 unsigned long rxlost2 PACKED; /* frames discarded at app. level */
532 unsigned char rsrv[2] PACKED; /* reserved for future use */
533 } cblock_t;
536 /* UDP management packet layout (data area of ip packet) */
538 typedef struct {
539 unsigned char control PACKED;
540 unsigned char NLPID PACKED;
541 } fr_encap_hdr_t;
543 typedef struct {
544 // fr_encap_hdr_t fr_encap_hdr PACKED;
545 ip_pkt_t ip_pkt PACKED;
546 udp_pkt_t udp_pkt PACKED;
547 wp_mgmt_t wp_mgmt PACKED;
548 cblock_t cblock PACKED;
549 unsigned char data[4080] PACKED;
550 } fr_udp_pkt_t;
553 /* valid ip_protocol for UDP management */
554 #define UDPMGMT_UDP_PROTOCOL 0x11
556 #define UDPMGMT_FPIPE_SIGNATURE "FPIPE8ND"
557 #define UDPMGMT_DRVRSTATS_SIGNATURE "DRVSTATS"
559 /* values for request/reply byte */
560 #define UDPMGMT_REQUEST 0x01
561 #define UDPMGMT_REPLY 0x02
562 #define UDP_OFFSET 12
564 typedef struct {
565 unsigned long if_send_entry;
566 unsigned long if_send_skb_null;
567 unsigned long if_send_broadcast;
568 unsigned long if_send_multicast;
569 unsigned long if_send_critical_ISR;
570 unsigned long if_send_critical_non_ISR;
571 unsigned long if_send_busy;
572 unsigned long if_send_busy_timeout;
573 unsigned long if_send_DRVSTATS_request;
574 unsigned long if_send_FPIPE_request;
575 unsigned long if_send_wan_disconnected;
576 unsigned long if_send_dlci_disconnected;
577 unsigned long if_send_no_bfrs;
578 unsigned long if_send_adptr_bfrs_full;
579 unsigned long if_send_bfrs_passed_to_adptr;
580 unsigned long if_send_consec_send_fail;
581 } drvstats_if_send_t;
583 typedef struct {
584 unsigned long rx_intr_no_socket;
585 unsigned long rx_intr_dev_not_started;
586 unsigned long rx_intr_DRVSTATS_request;
587 unsigned long rx_intr_FPIPE_request;
588 unsigned long rx_intr_bfr_not_passed_to_stack;
589 unsigned long rx_intr_bfr_passed_to_stack;
590 } drvstats_rx_intr_t;
592 typedef struct {
593 unsigned long UDP_FPIPE_mgmt_kmalloc_err;
594 unsigned long UDP_FPIPE_mgmt_direction_err;
595 unsigned long UDP_FPIPE_mgmt_adptr_type_err;
596 unsigned long UDP_FPIPE_mgmt_adptr_cmnd_OK;
597 unsigned long UDP_FPIPE_mgmt_adptr_cmnd_timeout;
598 unsigned long UDP_FPIPE_mgmt_adptr_send_passed;
599 unsigned long UDP_FPIPE_mgmt_adptr_send_failed;
600 unsigned long UDP_FPIPE_mgmt_not_passed_to_stack;
601 unsigned long UDP_FPIPE_mgmt_passed_to_stack;
602 unsigned long UDP_FPIPE_mgmt_no_socket;
603 unsigned long UDP_DRVSTATS_mgmt_kmalloc_err;
604 unsigned long UDP_DRVSTATS_mgmt_adptr_cmnd_OK;
605 unsigned long UDP_DRVSTATS_mgmt_adptr_cmnd_timeout;
606 unsigned long UDP_DRVSTATS_mgmt_adptr_send_passed;
607 unsigned long UDP_DRVSTATS_mgmt_adptr_send_failed;
608 unsigned long UDP_DRVSTATS_mgmt_not_passed_to_stack;
609 unsigned long UDP_DRVSTATS_mgmt_passed_to_stack;
610 unsigned long UDP_DRVSTATS_mgmt_no_socket;
611 } drvstats_gen_t;
613 typedef struct {
614 unsigned char attr PACKED;
615 unsigned short time_stamp PACKED;
616 unsigned char reserved[13] PACKED;
617 } api_rx_hdr_t;
619 typedef struct {
620 api_rx_hdr_t api_rx_hdr PACKED;
621 void * data PACKED;
622 } api_rx_element_t;
624 typedef struct {
625 unsigned char attr PACKED;
626 unsigned char reserved[15] PACKED;
627 } api_tx_hdr_t;
629 typedef struct {
630 api_tx_hdr_t api_tx_hdr PACKED;
631 void * data PACKED;
632 } api_tx_element_t;
634 #ifdef _MSC_
635 # pragma pack()
636 #endif
637 #endif /* _SDLA_FR_H */