!C99Shell v. 1.0 pre-release build #16!

Software: Apache/2.0.54 (Fedora). PHP/5.0.4 

uname -a: Linux mina-info.me 2.6.17-1.2142_FC4smp #1 SMP Tue Jul 11 22:57:02 EDT 2006 i686 

uid=48(apache) gid=48(apache) groups=48(apache)
context=system_u:system_r:httpd_sys_script_t
 

Safe-mode: OFF (not secure)

/usr/include/linux/   drwxr-xr-x
Free 3.83 GB of 27.03 GB (14.17%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     sdla_fr.h (23.91 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/*****************************************************************************
* sdla_fr.h    Sangoma frame relay firmware API definitions.
*
* Author:       Gideon Hack      
*        Nenad Corbic <ncorbic@sangoma.com>     
*
* Copyright:    (c) 1995-2000 Sangoma Technologies Inc.
*
*        This program is free software; you can redistribute it and/or
*        modify it under the terms of the GNU General Public License
*        as published by the Free Software Foundation; either version
*        2 of the License, or (at your option) any later version.
* ============================================================================
* Oct 04, 1999  Gideon Hack     Updated API structures
* Jun 02, 1999  Gideon Hack     Modifications for S514 support
* Oct 12, 1997    Jaspreet Singh    Added FR_READ_DLCI_IB_MAPPING
* Jul 21, 1997     Jaspreet Singh    Changed FRRES_TOO_LONG and FRRES_TOO_MANY to
*                0x05 and 0x06 respectively.
* Dec 23, 1996    Gene Kozin    v2.0
* Apr 29, 1996    Gene Kozin    v1.0 (merged version S502 & S508 definitions).
* Sep 26, 1995    Gene Kozin    Initial version.
*****************************************************************************/
#ifndef    _SDLA_FR_H
#define    _SDLA_FR_H

/*----------------------------------------------------------------------------
* Notes:
* ------
* 1. All structures defined in this file are byte-alined.  
*
*    Compiler    Platform
*    --------    --------
*    GNU C        Linux
*/

#ifndef    PACKED
#    define    PACKED    __attribute__((packed))
#endif    /* PACKED */

/* Adapter memory layout */
#define    FR_MB_VECTOR    0xE000    /* mailbox window vector */
#define    FR502_RX_VECTOR    0xA000    /* S502 direct receive window vector */
#define    FR502_MBOX_OFFS    0xF60    /* S502 mailbox offset */
#define    FR508_MBOX_OFFS    0    /* S508 mailbox offset */
#define    FR502_FLAG_OFFS    0x1FF0    /* S502 status flags offset */
#define    FR508_FLAG_OFFS    0x1000    /* S508 status flags offset */
#define    FR502_RXMB_OFFS    0x900    /* S502 direct receive mailbox offset */
#define    FR508_TXBC_OFFS    0x1100    /* S508 Tx buffer info offset */
#define    FR508_RXBC_OFFS    0x1120    /* S508 Rx buffer info offset */

/* Important constants */
#define FR502_MAX_DATA    4096    /* maximum data buffer length */
#define FR508_MAX_DATA    4080    /* maximum data buffer length */
#define MIN_LGTH_FR_DATA_CFG         300     /* min Information frame length
(for configuration purposes) */
#define FR_MAX_NO_DATA_BYTES_IN_FRAME  15354     /* max Information frame length */

#define HIGHEST_VALID_DLCI    991

/****** Data Structures *****************************************************/

/*----------------------------------------------------------------------------
* Frame relay command block.
*/
typedef struct fr_cmd
{
    unsigned char  command    PACKED;    /* command code */
    unsigned short length    PACKED;    /* length of data buffer */
    unsigned char  result    PACKED;    /* return code */
    unsigned short dlci    PACKED;    /* DLCI number */
    unsigned char  attr    PACKED;    /* FECN, BECN, DE and C/R bits */
    unsigned short rxlost1    PACKED;    /* frames discarded at int. level */
    unsigned long  rxlost2    PACKED;    /* frames discarded at app. level */
    unsigned char  rsrv[2]    PACKED;    /* reserved for future use */
} fr_cmd_t;

/* 'command' field defines */
#define    FR_WRITE        0x01
#define    FR_READ            0x02
#define    FR_ISSUE_IS_FRAME    0x03
#define FR_SET_CONFIG        0x10
#define FR_READ_CONFIG        0x11
#define FR_COMM_DISABLE        0x12
#define FR_COMM_ENABLE        0x13
#define FR_READ_STATUS        0x14
#define FR_READ_STATISTICS    0x15
#define FR_FLUSH_STATISTICS    0x16
#define    FR_LIST_ACTIVE_DLCI    0x17
#define FR_FLUSH_DATA_BUFFERS    0x18
#define FR_READ_ADD_DLC_STATS    0x19
#define    FR_ADD_DLCI        0x20
#define    FR_DELETE_DLCI        0x21
#define    FR_ACTIVATE_DLCI    0x22
#define    FR_DEACTIVATE_DLCI    0x22
#define FR_READ_MODEM_STATUS    0x30
#define FR_SET_MODEM_STATUS    0x31
#define FR_READ_ERROR_STATS    0x32
#define FR_FLUSH_ERROR_STATS    0x33
#define FR_READ_DLCI_IB_MAPPING 0x34
#define FR_READ_CODE_VERSION    0x40
#define    FR_SET_INTR_MODE    0x50
#define    FR_READ_INTR_MODE    0x51
#define FR_SET_TRACE_CONFIG    0x60
#define FR_FT1_STATUS_CTRL     0x80
#define FR_SET_FT1_MODE        0x81

/* Special UDP drivers management commands */
#define FPIPE_ENABLE_TRACING              0x41
#define FPIPE_DISABLE_TRACING        0x42
#define FPIPE_GET_TRACE_INFO            0x43
#define FPIPE_FT1_READ_STATUS           0x44
#define FPIPE_DRIVER_STAT_IFSEND        0x45
#define FPIPE_DRIVER_STAT_INTR          0x46
#define FPIPE_DRIVER_STAT_GEN           0x47
#define FPIPE_FLUSH_DRIVER_STATS        0x48
#define FPIPE_ROUTER_UP_TIME            0x49

/* 'result' field defines */
#define FRRES_OK        0x00    /* command executed successfully */
#define    FRRES_DISABLED        0x01    /* communications not enabled */
#define    FRRES_INOPERATIVE    0x02    /* channel inoperative */
#define    FRRES_DLCI_INACTIVE    0x03    /* DLCI is inactive */
#define    FRRES_DLCI_INVALID    0x04    /* DLCI is not configured */
#define    FRRES_TOO_LONG        0x05
#define    FRRES_TOO_MANY        0x06
#define    FRRES_CIR_OVERFLOW    0x07    /* Tx throughput has exceeded CIR */
#define    FRRES_BUFFER_OVERFLOW    0x08
#define    FRRES_MODEM_FAILURE    0x10    /* DCD and/or CTS dropped */
#define    FRRES_CHANNEL_DOWN    0x11    /* channel became inoperative */
#define    FRRES_CHANNEL_UP    0x12    /* channel became operative */
#define    FRRES_DLCI_CHANGE    0x13    /* DLCI status (or number) changed */
#define    FRRES_DLCI_MISMATCH    0x14
#define    FRRES_INVALID_CMD    0x1F    /* invalid command */

/* 'attr' field defines */
#define    FRATTR_

/*----------------------------------------------------------------------------
* Frame relay mailbox.
*    This structure is located at offset FR50?_MBOX_OFFS into FR_MB_VECTOR.
*    For S502 it is also located at offset FR502_RXMB_OFFS into
*    FR502_RX_VECTOR.
*/
typedef struct fr_mbox
{
    unsigned char opflag    PACKED;    /* 00h: execution flag */
    fr_cmd_t cmd        PACKED;    /* 01h: command block */
    unsigned char data[1]    PACKED;    /* 10h: variable length data buffer */
} fr_mbox_t;

/*----------------------------------------------------------------------------
* S502 frame relay status flags.
*    This structure is located at offset FR502_FLAG_OFFS into FR_MB_VECTOR.
*/
typedef struct    fr502_flags
{    
    unsigned char rsrv1[1]    PACKED;    /* 00h: */
    unsigned char tx_ready    PACKED;    /* 01h: Tx buffer available */
    unsigned char rx_ready    PACKED;    /* 02h: Rx frame available */
    unsigned char event    PACKED;    /* 03h: asynchronous event */
    unsigned char mstatus    PACKED;    /* 04h: modem status */
    unsigned char rsrv2[8]    PACKED;    /* 05h: */
    unsigned char iflag    PACKED;    /* 0Dh: interrupt flag */
    unsigned char imask    PACKED;    /* 0Eh: interrupt mask */
} fr502_flags_t;

/*----------------------------------------------------------------------------
* S508 frame relay status flags.
*    This structure is located at offset FR508_FLAG_OFFS into FR_MB_VECTOR.
*/
typedef struct    fr508_flags
{
    unsigned char rsrv1[3]    PACKED;    /* 00h: reserved */
    unsigned char event    PACKED;    /* 03h: asynchronous event */
    unsigned char mstatus    PACKED;    /* 04h: modem status */
    unsigned char rsrv2[11]    PACKED;    /* 05h: reserved */
    unsigned char iflag    PACKED;    /* 10h: interrupt flag */
    unsigned char imask    PACKED;    /* 11h: interrupt mask */
    unsigned long tse_offs    PACKED;    /* 12h: Tx status element */
    unsigned short dlci    PACKED; /* 16h: DLCI NUMBER */
} fr508_flags_t;

/* 'event' field defines */
#define    FR_EVENT_STATUS        0x01    /* channel status change */
#define    FR_EVENT_DLC_STATUS    0x02    /* DLC status change */
#define    FR_EVENT_BAD_DLCI    0x04    /* FSR included wrong DLCI */
#define    FR_EVENT_LINK_DOWN    0x40    /* DCD or CTS low */

/* 'mstatus' field defines */
#define    FR_MDM_DCD        0x08    /* mdm_status: DCD */
#define    FR_MDM_CTS        0x20    /* mdm_status: CTS */

/* 'iflag' & 'imask' fields defines */
#define    FR_INTR_RXRDY        0x01    /* Rx ready */
#define    FR_INTR_TXRDY        0x02    /* Tx ready */
#define    FR_INTR_MODEM        0x04    /* modem status change (DCD, CTS) */
#define    FR_INTR_READY        0x08    /* interface command completed */
#define    FR_INTR_DLC        0x10    /* DLC status change */
#define    FR_INTR_TIMER        0x20    /* millisecond timer */
#define FR_INTR_TX_MULT_DLCIs    0x80    /* Tx interrupt on multiple DLCIs */


/*----------------------------------------------------------------------------
* Receive Buffer Configuration Info. S508 only!
*    This structure is located at offset FR508_RXBC_OFFS into FR_MB_VECTOR.
*/
typedef struct    fr_buf_info
{
    unsigned short rse_num    PACKED;    /* 00h: number of status elements */
    unsigned long rse_base    PACKED;    /* 02h: receive status array base */
    unsigned long rse_next    PACKED;    /* 06h: next status element */
    unsigned long buf_base    PACKED;    /* 0Ah: rotational buffer base */
    unsigned short reserved    PACKED;    /* 0Eh:  */
    unsigned long buf_top    PACKED;    /* 10h: rotational buffer top */
} fr_buf_info_t;

/*----------------------------------------------------------------------------
* Buffer Status Element. S508 only!
*    Array of structures of this type is located at offset defined by the
*    'rse_base' field of the frBufInfo_t structure into absolute adapter
*    memory address space.
*/
typedef struct    fr_rx_buf_ctl
{
    unsigned char flag    PACKED;    /* 00h: ready flag */
    unsigned short length    PACKED;    /* 01h: frame length */
    unsigned short dlci    PACKED;    /* 03h: DLCI */
    unsigned char attr    PACKED;    /* 05h: FECN/BECN/DE/CR */
    unsigned short tmstamp    PACKED;    /* 06h: time stamp */
    unsigned short rsrv[2]    PACKED; /* 08h:  */
    unsigned long offset    PACKED;    /* 0Ch: buffer absolute address */
} fr_rx_buf_ctl_t;

typedef struct  fr_tx_buf_ctl
{
        unsigned char flag      PACKED; /* 00h: ready flag */
    unsigned short rsrv0[2]    PACKED;    /* 01h: */
        unsigned short length   PACKED; /* 05h: frame length */
        unsigned short dlci     PACKED; /* 07h: DLCI */
        unsigned char attr      PACKED; /* 09h: FECN/BECN/DE/CR */
        unsigned short rsrv1     PACKED; /* 0Ah:  */
        unsigned long offset    PACKED; /* 0Ch: buffer absolute address */
} fr_tx_buf_ctl_t;

/*----------------------------------------------------------------------------
* Global Configuration Block. Passed to FR_SET_CONFIG command when dlci == 0.
*/
typedef struct    fr_conf
{
    unsigned short station    PACKED;    /* 00h: CPE/Node */
    unsigned short options    PACKED;    /* 02h: configuration options */
    unsigned short kbps    PACKED;    /* 04h: baud rate in kbps */
    unsigned short port    PACKED;    /* 06h: RS-232/V.35 */
    unsigned short mtu    PACKED;    /* 08h: max. transmit length */
    unsigned short t391    PACKED;    /* 0Ah:  */
    unsigned short t392    PACKED;    /* 0Ch:  */
    unsigned short n391    PACKED;    /* 0Eh:  */
    unsigned short n392    PACKED;    /* 10h:  */
    unsigned short n393    PACKED;    /* 12h:  */
    unsigned short cir_fwd    PACKED;    /* 14h:  */
    unsigned short bc_fwd    PACKED;    /* 16h:  */
    unsigned short be_fwd    PACKED;    /* 18h:  */
    unsigned short cir_bwd    PACKED;    /* 1Ah:  */
    unsigned short bc_bwd    PACKED;    /* 1Ch:  */
    unsigned short be_bwd    PACKED;    /* 1Eh:  */
    unsigned short dlci[0]    PACKED;    /* 20h:  */
} fr_conf_t;

/* 'station_type' defines */
#define    FRCFG_STATION_CPE    0
#define    FRCFG_STATION_NODE    1

/* 'conf_flags' defines */
#define    FRCFG_IGNORE_TX_CIR    0x0001
#define    FRCFG_IGNORE_RX_CIR    0x0002
#define    FRCFG_DONT_RETRANSMIT    0x0004
#define    FRCFG_IGNORE_CBS    0x0008
#define    FRCFG_THROUGHPUT    0x0010    /* enable throughput calculation */
#define    FRCFG_DIRECT_RX        0x0080    /* enable direct receive buffer */
#define    FRCFG_AUTO_CONFIG    0x8000    /* enable  auto DLCI configuration */

/* 'baud_rate' defines */
#define    FRCFG_BAUD_1200        12
#define    FRCFG_BAUD_2400        24
#define    FRCFG_BAUD_4800        48
#define    FRCFG_BAUD_9600        96
#define    FRCFG_BAUD_19200    19
#define    FRCFG_BAUD_38400    38
#define    FRCFG_BAUD_56000    56
#define    FRCFG_BAUD_64000    64
#define    FRCFG_BAUD_128000    128

/* 'port_mode' defines */
#define    FRCFG_MODE_EXT_CLK    0x0000
#define    FRCFG_MODE_INT_CLK    0x0001
#define    FRCFG_MODE_V35        0x0000    /* S508 only */
#define    FRCFG_MODE_RS232    0x0002    /* S508 only */

/* defines for line tracing */

/* the line trace status element presented by the frame relay code */
typedef struct {
        unsigned char flag      PACKED; /* ready flag */
        unsigned short length   PACKED; /* trace length */
        unsigned char rsrv0[2]  PACKED; /* reserved */
        unsigned char attr      PACKED; /* trace attributes */
        unsigned short tmstamp  PACKED; /* time stamp */
        unsigned char rsrv1[4]  PACKED; /* reserved */
        unsigned long offset    PACKED; /* buffer absolute address */
} fr_trc_el_t;

typedef struct {
        unsigned char status        PACKED; /* status flag */
    unsigned char data_passed    PACKED;    /* 0 if no data passed, 1 if */
                        /* data passed */
        unsigned short length       PACKED; /* frame length */
        unsigned short tmstamp      PACKED; /* time stamp */
} fpipemon_trc_hdr_t;

typedef struct {
    fpipemon_trc_hdr_t fpipemon_trc_hdr            PACKED;
        unsigned char data[FR_MAX_NO_DATA_BYTES_IN_FRAME]    PACKED;
} fpipemon_trc_t;

/* bit settings for the 'status' byte  - note that bits 1, 2 and 3 are used */
/* for returning the number of frames being passed to fpipemon */
#define TRC_OUTGOING_FRM    0x01
#define TRC_ABORT_ERROR         0x10
#define TRC_CRC_ERROR           0x20
#define TRC_OVERRUN_ERROR       0x40
#define MORE_TRC_DATA        0x80

#define MAX_FRMS_TRACED        0x07

#define NO_TRC_ELEMENTS_OFF        0x9000
#define BASE_TRC_ELEMENTS_OFF        0x9002
#define TRC_ACTIVE            0x01
#define FLUSH_TRC_BUFFERS         0x02
#define FLUSH_TRC_STATISTICS        0x04
#define TRC_SIGNALLING_FRMS        0x10
#define TRC_INFO_FRMS            0x20
#define ACTIVATE_TRC    (TRC_ACTIVE | TRC_SIGNALLING_FRMS | TRC_INFO_FRMS)
#define RESET_TRC    (FLUSH_TRC_BUFFERS | FLUSH_TRC_STATISTICS)

/*----------------------------------------------------------------------------
* Channel configuration.
*    This structure is passed to the FR_SET_CONFIG command when dlci != 0.
*/
typedef struct    fr_dlc_conf
{
    unsigned short conf_flags    PACKED;    /* 00h: configuration bits */
    unsigned short cir_fwd        PACKED;    /* 02h:  */
    unsigned short bc_fwd        PACKED;    /* 04h:  */
    unsigned short be_fwd        PACKED;    /* 06h:  */
    unsigned short cir_bwd        PACKED;    /* 08h:  */
    unsigned short bc_bwd        PACKED;    /* 0Ah:  */
    unsigned short be_bwd        PACKED;    /* 0Ch:  */
} fr_dlc_conf_t;

/*----------------------------------------------------------------------------
* S502 interrupt mode control block.
*    This structure is passed to the FR_SET_INTR_FLAGS and returned by the
*    FR_READ_INTR_FLAGS commands.
*/
typedef struct fr502_intr_ctl
{
    unsigned char mode    PACKED;    /* 00h: interrupt enable flags */
    unsigned short tx_len    PACKED;    /* 01h: required Tx buffer size */
} fr502_intr_ctl_t;

/*----------------------------------------------------------------------------
* S508 interrupt mode control block.
*    This structure is passed to the FR_SET_INTR_FLAGS and returned by the
*    FR_READ_INTR_FLAGS commands.
*/
typedef struct fr508_intr_ctl
{
    unsigned char mode    PACKED;    /* 00h: interrupt enable flags */
    unsigned short tx_len    PACKED;    /* 01h: required Tx buffer size */
    unsigned char irq    PACKED;    /* 03h: IRQ level to activate */
    unsigned char flags    PACKED;    /* 04h: ?? */
    unsigned short timeout    PACKED;    /* 05h: ms, for timer interrupt */
} fr508_intr_ctl_t;

/*----------------------------------------------------------------------------
* Channel status.
*    This structure is returned by the FR_READ_STATUS command.
*/
typedef struct    fr_dlc_Status
{
    unsigned char status        PACKED;    /* 00h: link/DLCI status */
    struct
    {
        unsigned short dlci    PACKED;    /* 01h: DLCI number */
        unsigned char status    PACKED;    /* 03h: DLCI status */
    } circuit[1]            PACKED;
} fr_dlc_status_t;

/* 'status' defines */
#define    FR_LINK_INOPER    0x00        /* for global status (DLCI == 0) */
#define    FR_LINK_OPER    0x01
#define    FR_DLCI_DELETED    0x01        /* for circuit status (DLCI != 0) */
#define    FR_DLCI_ACTIVE    0x02
#define    FR_DLCI_WAITING    0x04
#define    FR_DLCI_NEW    0x08
#define    FR_DLCI_REPORT    0x40

/*----------------------------------------------------------------------------
* Global Statistics Block.
*    This structure is returned by the FR_READ_STATISTICS command when
*    dcli == 0.
*/
typedef struct    fr_link_stat
{
    unsigned short rx_too_long    PACKED;    /* 00h:  */
    unsigned short rx_dropped    PACKED;    /* 02h:  */
    unsigned short rx_dropped2    PACKED;    /* 04h:  */
    unsigned short rx_bad_dlci    PACKED;    /* 06h:  */
    unsigned short rx_bad_format    PACKED;    /* 08h:  */
    unsigned short retransmitted    PACKED;    /* 0Ah:  */
    unsigned short cpe_tx_FSE    PACKED;    /* 0Ch:  */
    unsigned short cpe_tx_LIV    PACKED;    /* 0Eh:  */
    unsigned short cpe_rx_FSR    PACKED;    /* 10h:  */
    unsigned short cpe_rx_LIV    PACKED;    /* 12h:  */
    unsigned short node_rx_FSE    PACKED;    /* 14h:  */
    unsigned short node_rx_LIV    PACKED;    /* 16h:  */
    unsigned short node_tx_FSR    PACKED;    /* 18h:  */
    unsigned short node_tx_LIV    PACKED;    /* 1Ah:  */
    unsigned short rx_ISF_err    PACKED;    /* 1Ch:  */
    unsigned short rx_unsolicited    PACKED;    /* 1Eh:  */
    unsigned short rx_SSN_err    PACKED;    /* 20h:  */
    unsigned short rx_RSN_err    PACKED;    /* 22h:  */
    unsigned short T391_timeouts    PACKED;    /* 24h:  */
    unsigned short T392_timeouts    PACKED;    /* 26h:  */
    unsigned short N392_reached    PACKED;    /* 28h:  */
    unsigned short cpe_SSN_RSN    PACKED;    /* 2Ah:  */
    unsigned short current_SSN    PACKED;    /* 2Ch:  */
    unsigned short current_RSN    PACKED;    /* 2Eh:  */
    unsigned short curreny_T391    PACKED;    /* 30h:  */
    unsigned short current_T392    PACKED;    /* 32h:  */
    unsigned short current_N392    PACKED;    /* 34h:  */
    unsigned short current_N393    PACKED;    /* 36h:  */
} fr_link_stat_t;

/*----------------------------------------------------------------------------
* DLCI statistics.
*    This structure is returned by the FR_READ_STATISTICS command when
*    dlci != 0.
*/
typedef struct    fr_dlci_stat
{
    unsigned long tx_frames        PACKED;    /* 00h:  */
    unsigned long tx_bytes        PACKED;    /* 04h:  */
    unsigned long rx_frames        PACKED;    /* 08h:  */
    unsigned long rx_bytes        PACKED;    /* 0Ch:  */
    unsigned long rx_dropped    PACKED;    /* 10h:  */
    unsigned long rx_inactive    PACKED;    /* 14h:  */
    unsigned long rx_exceed_CIR    PACKED;    /* 18h:  */
    unsigned long rx_DE_set        PACKED;    /* 1Ch:  */
    unsigned long tx_throughput    PACKED;    /* 20h:  */
    unsigned long tx_calc_timer    PACKED;    /* 24h:  */
    unsigned long rx_throughput    PACKED;    /* 28h:  */
    unsigned long rx_calc_timer    PACKED;    /* 2Ch:  */
} fr_dlci_stat_t;

/*----------------------------------------------------------------------------
* Communications error statistics.
*    This structure is returned by the FR_READ_ERROR_STATS command.
*/
typedef struct    fr_comm_stat
{
    unsigned char rx_overruns    PACKED;    /* 00h:  */
    unsigned char rx_bad_crc    PACKED;    /* 01h:  */
    unsigned char rx_aborts        PACKED;    /* 02h:  */
    unsigned char rx_too_long    PACKED;    /* 03h:  */
    unsigned char tx_aborts        PACKED;    /* 04h:  */
    unsigned char tx_underruns    PACKED;    /* 05h:  */
    unsigned char tx_missed_undr    PACKED;    /* 06h:  */
    unsigned char dcd_dropped    PACKED;    /* 07h:  */
    unsigned char cts_dropped    PACKED;    /* 08h:  */
} fr_comm_stat_t;

/*----------------------------------------------------------------------------
* Defines for the FR_ISSUE_IS_FRAME command.
*/
#define    FR_ISF_LVE    2        /* issue Link Verification Enquiry */
#define    FR_ISF_FSE    3        /* issue Full Status Enquiry */

/*----------------------------------------------------------------------------
* Frame Relay ARP Header -- Used for Dynamic route creation with InvARP
*/

typedef struct arphdr_fr
    {
    unsigned short ar_hrd PACKED;        /* format of hardware addr */
    unsigned short ar_pro PACKED;        /* format of protocol addr */
    unsigned char  ar_hln PACKED;        /* length of hardware addr */    
    unsigned char  ar_pln PACKED;        /* length of protocol addr */
    unsigned short ar_op  PACKED;        /* ARP opcode           */
    unsigned short ar_sha PACKED;        /* Sender DLCI addr 2 bytes */
    unsigned long  ar_sip PACKED;        /* Sender IP   addr 4 bytes */
    unsigned short ar_tha PACKED;        /* Target DLCI addr 2 bytes */
    unsigned long  ar_tip PACKED;        /* Target IP   addr 4 bytes */
    } arphdr_fr_t;

/*----------------------------------------------------------------------------
* Frame Relay RFC 1490 SNAP Header -- Used to check for ARP packets
*/
typedef struct arphdr_1490
    {
    unsigned char control PACKED;        /* UI, etc...  */
    unsigned char pad     PACKED;        /* Pad */
    unsigned char NLPID   PACKED;        /* SNAP */
    unsigned char OUI[3]  PACKED;        /* Ethertype, etc... */
    unsigned short PID    PACKED;        /* ARP, IP, etc... */
    }  arphdr_1490_t;

/* UDP/IP packet (for UDP management) layout */

/* The embedded control block for UDP mgmt
   This is essentially a mailbox structure, without the large data field */

typedef struct {
        unsigned char  opp_flag PACKED; /* the opp flag */
        unsigned char  command  PACKED; /* command code */
        unsigned short length   PACKED; /* length of data buffer */
        unsigned char  result   PACKED; /* return code */
        unsigned short dlci     PACKED; /* DLCI number */
        unsigned char  attr     PACKED; /* FECN, BECN, DE and C/R bits */
        unsigned short rxlost1  PACKED; /* frames discarded at int. level */
        unsigned long  rxlost2  PACKED; /* frames discarded at app. level */
        unsigned char  rsrv[2]  PACKED; /* reserved for future use */
} cblock_t;


/* UDP management packet layout (data area of ip packet) */

typedef struct {
        unsigned char   control                 PACKED;
        unsigned char   NLPID                   PACKED;
} fr_encap_hdr_t;

typedef struct {
//    fr_encap_hdr_t         fr_encap_hdr    PACKED;
    ip_pkt_t         ip_pkt        PACKED;
    udp_pkt_t        udp_pkt        PACKED;
    wp_mgmt_t         wp_mgmt           PACKED;
        cblock_t                cblock          PACKED;
        unsigned char           data[4080]      PACKED;
} fr_udp_pkt_t;


/* valid ip_protocol for UDP management */
#define UDPMGMT_UDP_PROTOCOL 0x11

#define UDPMGMT_FPIPE_SIGNATURE         "FPIPE8ND"
#define UDPMGMT_DRVRSTATS_SIGNATURE     "DRVSTATS"

/* values for request/reply byte */
#define UDPMGMT_REQUEST    0x01
#define UDPMGMT_REPLY    0x02
#define UDP_OFFSET    12

typedef struct {
        unsigned long if_send_entry;
        unsigned long if_send_skb_null;
        unsigned long if_send_broadcast;
        unsigned long if_send_multicast;
        unsigned long if_send_critical_ISR;
        unsigned long if_send_critical_non_ISR;
        unsigned long if_send_busy;
        unsigned long if_send_busy_timeout;
    unsigned long if_send_DRVSTATS_request;
        unsigned long if_send_FPIPE_request;
        unsigned long if_send_wan_disconnected;
        unsigned long if_send_dlci_disconnected;
        unsigned long if_send_no_bfrs;
        unsigned long if_send_adptr_bfrs_full;
        unsigned long if_send_bfrs_passed_to_adptr;
    unsigned long if_send_consec_send_fail;
} drvstats_if_send_t;

typedef struct {
        unsigned long rx_intr_no_socket;
        unsigned long rx_intr_dev_not_started;
        unsigned long rx_intr_DRVSTATS_request;
        unsigned long rx_intr_FPIPE_request;
        unsigned long rx_intr_bfr_not_passed_to_stack;
        unsigned long rx_intr_bfr_passed_to_stack;
} drvstats_rx_intr_t;

typedef struct {
        unsigned long UDP_FPIPE_mgmt_kmalloc_err;
        unsigned long UDP_FPIPE_mgmt_direction_err;
        unsigned long UDP_FPIPE_mgmt_adptr_type_err;
        unsigned long UDP_FPIPE_mgmt_adptr_cmnd_OK;
        unsigned long UDP_FPIPE_mgmt_adptr_cmnd_timeout;
        unsigned long UDP_FPIPE_mgmt_adptr_send_passed;
        unsigned long UDP_FPIPE_mgmt_adptr_send_failed;
        unsigned long UDP_FPIPE_mgmt_not_passed_to_stack;
        unsigned long UDP_FPIPE_mgmt_passed_to_stack;
        unsigned long UDP_FPIPE_mgmt_no_socket;
        unsigned long UDP_DRVSTATS_mgmt_kmalloc_err;
        unsigned long UDP_DRVSTATS_mgmt_adptr_cmnd_OK;
        unsigned long UDP_DRVSTATS_mgmt_adptr_cmnd_timeout;
        unsigned long UDP_DRVSTATS_mgmt_adptr_send_passed;
        unsigned long UDP_DRVSTATS_mgmt_adptr_send_failed;
        unsigned long UDP_DRVSTATS_mgmt_not_passed_to_stack;
        unsigned long UDP_DRVSTATS_mgmt_passed_to_stack;
        unsigned long UDP_DRVSTATS_mgmt_no_socket;
} drvstats_gen_t;

typedef struct {
        unsigned char   attr          PACKED;
        unsigned short  time_stamp      PACKED;
        unsigned char   reserved[13]    PACKED;
} api_rx_hdr_t;

typedef struct {
        api_rx_hdr_t    api_rx_hdr      PACKED;
        void *          data            PACKED;
} api_rx_element_t;

typedef struct {
        unsigned char   attr            PACKED;
        unsigned char   reserved[15]    PACKED;
} api_tx_hdr_t;

typedef struct {
        api_tx_hdr_t    api_tx_hdr      PACKED;
        void *          data            PACKED;
} api_tx_element_t;

#ifdef        _MSC_
#  pragma    pack()
#endif
#endif    /* _SDLA_FR_H */


:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 1.0 pre-release build #16 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0045 ]--