Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /***************************************************************************** |
| 2 | * sdla_fr.h Sangoma frame relay firmware API definitions. |
| 3 | * |
| 4 | * Author: Gideon Hack |
| 5 | * Nenad Corbic <ncorbic@sangoma.com> |
| 6 | * |
| 7 | * Copyright: (c) 1995-2000 Sangoma Technologies Inc. |
| 8 | * |
| 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 |
| 25 | |
| 26 | /*---------------------------------------------------------------------------- |
| 27 | * Notes: |
| 28 | * ------ |
| 29 | * 1. All structures defined in this file are byte-alined. |
| 30 | * |
| 31 | * Compiler Platform |
| 32 | * -------- -------- |
| 33 | * GNU C Linux |
| 34 | */ |
| 35 | |
| 36 | #ifndef PACKED |
| 37 | # define PACKED __attribute__((packed)) |
| 38 | #endif /* PACKED */ |
| 39 | |
| 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 */ |
| 50 | |
| 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 */ |
| 57 | |
| 58 | #define HIGHEST_VALID_DLCI 991 |
| 59 | |
| 60 | /****** Data Structures *****************************************************/ |
| 61 | |
| 62 | /*---------------------------------------------------------------------------- |
| 63 | * Frame relay command block. |
| 64 | */ |
| 65 | typedef struct fr_cmd |
| 66 | { |
| 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; |
| 76 | |
| 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 |
| 106 | |
| 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 |
| 117 | |
| 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 */ |
| 134 | |
| 135 | /* 'attr' field defines */ |
| 136 | #define FRATTR_ |
| 137 | |
| 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. |
| 143 | */ |
| 144 | typedef struct fr_mbox |
| 145 | { |
| 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; |
| 150 | |
| 151 | /*---------------------------------------------------------------------------- |
| 152 | * S502 frame relay status flags. |
| 153 | * This structure is located at offset FR502_FLAG_OFFS into FR_MB_VECTOR. |
| 154 | */ |
| 155 | typedef struct fr502_flags |
| 156 | { |
| 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; |
| 166 | |
| 167 | /*---------------------------------------------------------------------------- |
| 168 | * S508 frame relay status flags. |
| 169 | * This structure is located at offset FR508_FLAG_OFFS into FR_MB_VECTOR. |
| 170 | */ |
| 171 | typedef struct fr508_flags |
| 172 | { |
| 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; |
| 182 | |
| 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 */ |
| 188 | |
| 189 | /* 'mstatus' field defines */ |
| 190 | #define FR_MDM_DCD 0x08 /* mdm_status: DCD */ |
| 191 | #define FR_MDM_CTS 0x20 /* mdm_status: CTS */ |
| 192 | |
| 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 */ |
| 201 | |
| 202 | |
| 203 | /*---------------------------------------------------------------------------- |
| 204 | * Receive Buffer Configuration Info. S508 only! |
| 205 | * This structure is located at offset FR508_RXBC_OFFS into FR_MB_VECTOR. |
| 206 | */ |
| 207 | typedef struct fr_buf_info |
| 208 | { |
| 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; |
| 216 | |
| 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. |
| 222 | */ |
| 223 | typedef struct fr_rx_buf_ctl |
| 224 | { |
| 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; |
| 233 | |
| 234 | typedef struct fr_tx_buf_ctl |
| 235 | { |
| 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; |
| 244 | |
| 245 | /*---------------------------------------------------------------------------- |
| 246 | * Global Configuration Block. Passed to FR_SET_CONFIG command when dlci == 0. |
| 247 | */ |
| 248 | typedef struct fr_conf |
| 249 | { |
| 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; |
| 268 | |
| 269 | /* 'station_type' defines */ |
| 270 | #define FRCFG_STATION_CPE 0 |
| 271 | #define FRCFG_STATION_NODE 1 |
| 272 | |
| 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 */ |
| 281 | |
| 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 |
| 292 | |
| 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 */ |
| 298 | |
| 299 | /* defines for line tracing */ |
| 300 | |
| 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; |
| 311 | |
| 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; |
| 319 | |
| 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; |
| 324 | |
| 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 |
| 332 | |
| 333 | #define MAX_FRMS_TRACED 0x07 |
| 334 | |
| 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) |
| 344 | |
| 345 | /*---------------------------------------------------------------------------- |
| 346 | * Channel configuration. |
| 347 | * This structure is passed to the FR_SET_CONFIG command when dlci != 0. |
| 348 | */ |
| 349 | typedef struct fr_dlc_conf |
| 350 | { |
| 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; |
| 359 | |
| 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. |
| 364 | */ |
| 365 | typedef struct fr502_intr_ctl |
| 366 | { |
| 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; |
| 370 | |
| 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. |
| 375 | */ |
| 376 | typedef struct fr508_intr_ctl |
| 377 | { |
| 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; |
| 384 | |
| 385 | /*---------------------------------------------------------------------------- |
| 386 | * Channel status. |
| 387 | * This structure is returned by the FR_READ_STATUS command. |
| 388 | */ |
| 389 | typedef struct fr_dlc_Status |
| 390 | { |
| 391 | unsigned char status PACKED; /* 00h: link/DLCI status */ |
| 392 | struct |
| 393 | { |
| 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; |
| 398 | |
| 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 |
| 407 | |
| 408 | /*---------------------------------------------------------------------------- |
| 409 | * Global Statistics Block. |
| 410 | * This structure is returned by the FR_READ_STATISTICS command when |
| 411 | * dcli == 0. |
| 412 | */ |
| 413 | typedef struct fr_link_stat |
| 414 | { |
| 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; |
| 444 | |
| 445 | /*---------------------------------------------------------------------------- |
| 446 | * DLCI statistics. |
| 447 | * This structure is returned by the FR_READ_STATISTICS command when |
| 448 | * dlci != 0. |
| 449 | */ |
| 450 | typedef struct fr_dlci_stat |
| 451 | { |
| 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; |
| 465 | |
| 466 | /*---------------------------------------------------------------------------- |
| 467 | * Communications error statistics. |
| 468 | * This structure is returned by the FR_READ_ERROR_STATS command. |
| 469 | */ |
| 470 | typedef struct fr_comm_stat |
| 471 | { |
| 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; |
| 482 | |
| 483 | /*---------------------------------------------------------------------------- |
| 484 | * Defines for the FR_ISSUE_IS_FRAME command. |
| 485 | */ |
| 486 | #define FR_ISF_LVE 2 /* issue Link Verification Enquiry */ |
| 487 | #define FR_ISF_FSE 3 /* issue Full Status Enquiry */ |
| 488 | |
| 489 | /*---------------------------------------------------------------------------- |
| 490 | * Frame Relay ARP Header -- Used for Dynamic route creation with InvARP |
| 491 | */ |
| 492 | |
| 493 | typedef struct arphdr_fr |
| 494 | { |
| 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; |
| 505 | |
| 506 | /*---------------------------------------------------------------------------- |
| 507 | * Frame Relay RFC 1490 SNAP Header -- Used to check for ARP packets |
| 508 | */ |
| 509 | typedef struct arphdr_1490 |
| 510 | { |
| 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; |
| 517 | |
| 518 | /* UDP/IP packet (for UDP management) layout */ |
| 519 | |
| 520 | /* The embedded control block for UDP mgmt |
| 521 | This is essentially a mailbox structure, without the large data field */ |
| 522 | |
| 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; |
| 534 | |
| 535 | |
| 536 | /* UDP management packet layout (data area of ip packet) */ |
| 537 | |
| 538 | typedef struct { |
| 539 | unsigned char control PACKED; |
| 540 | unsigned char NLPID PACKED; |
| 541 | } fr_encap_hdr_t; |
| 542 | |
| 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; |
| 551 | |
| 552 | |
| 553 | /* valid ip_protocol for UDP management */ |
| 554 | #define UDPMGMT_UDP_PROTOCOL 0x11 |
| 555 | |
| 556 | #define UDPMGMT_FPIPE_SIGNATURE "FPIPE8ND" |
| 557 | #define UDPMGMT_DRVRSTATS_SIGNATURE "DRVSTATS" |
| 558 | |
| 559 | /* values for request/reply byte */ |
| 560 | #define UDPMGMT_REQUEST 0x01 |
| 561 | #define UDPMGMT_REPLY 0x02 |
| 562 | #define UDP_OFFSET 12 |
| 563 | |
| 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; |
| 582 | |
| 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; |
| 591 | |
| 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; |
| 612 | |
| 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; |
| 618 | |
| 619 | typedef struct { |
| 620 | api_rx_hdr_t api_rx_hdr PACKED; |
| 621 | void * data PACKED; |
| 622 | } api_rx_element_t; |
| 623 | |
| 624 | typedef struct { |
| 625 | unsigned char attr PACKED; |
| 626 | unsigned char reserved[15] PACKED; |
| 627 | } api_tx_hdr_t; |
| 628 | |
| 629 | typedef struct { |
| 630 | api_tx_hdr_t api_tx_hdr PACKED; |
| 631 | void * data PACKED; |
| 632 | } api_tx_element_t; |
| 633 | |
| 634 | #ifdef _MSC_ |
| 635 | # pragma pack() |
| 636 | #endif |
| 637 | #endif /* _SDLA_FR_H */ |
| 638 | |