1*53ee8cc1Swenshuai.xi /***************************************************************************** 2*53ee8cc1Swenshuai.xi * wanrouter.h Definitions for the WAN Multiprotocol Router Module. 3*53ee8cc1Swenshuai.xi * This module provides API and common services for WAN Link 4*53ee8cc1Swenshuai.xi * Drivers and is completely hardware-independent. 5*53ee8cc1Swenshuai.xi * 6*53ee8cc1Swenshuai.xi * Author: Nenad Corbic <ncorbic@sangoma.com> 7*53ee8cc1Swenshuai.xi * Gideon Hack 8*53ee8cc1Swenshuai.xi * Additions: Arnaldo Melo 9*53ee8cc1Swenshuai.xi * 10*53ee8cc1Swenshuai.xi * Copyright: (c) 1995-2000 Sangoma Technologies Inc. 11*53ee8cc1Swenshuai.xi * 12*53ee8cc1Swenshuai.xi * This program is free software; you can redistribute it and/or 13*53ee8cc1Swenshuai.xi * modify it under the terms of the GNU General Public License 14*53ee8cc1Swenshuai.xi * as published by the Free Software Foundation; either version 15*53ee8cc1Swenshuai.xi * 2 of the License, or (at your option) any later version. 16*53ee8cc1Swenshuai.xi * ============================================================================ 17*53ee8cc1Swenshuai.xi * Jul 21, 2000 Nenad Corbic Added WAN_FT1_READY State 18*53ee8cc1Swenshuai.xi * Feb 24, 2000 Nenad Corbic Added support for socket based x25api 19*53ee8cc1Swenshuai.xi * Jan 28, 2000 Nenad Corbic Added support for the ASYNC protocol. 20*53ee8cc1Swenshuai.xi * Oct 04, 1999 Nenad Corbic Updated for 2.1.0 release 21*53ee8cc1Swenshuai.xi * Jun 02, 1999 Gideon Hack Added support for the S514 adapter. 22*53ee8cc1Swenshuai.xi * May 23, 1999 Arnaldo Melo Added local_addr to wanif_conf_t 23*53ee8cc1Swenshuai.xi * WAN_DISCONNECTING state added 24*53ee8cc1Swenshuai.xi * Jul 20, 1998 David Fong Added Inverse ARP options to 'wanif_conf_t' 25*53ee8cc1Swenshuai.xi * Jun 12, 1998 David Fong Added Cisco HDLC support. 26*53ee8cc1Swenshuai.xi * Dec 16, 1997 Jaspreet Singh Moved 'enable_IPX' and 'network_number' to 27*53ee8cc1Swenshuai.xi * 'wanif_conf_t' 28*53ee8cc1Swenshuai.xi * Dec 05, 1997 Jaspreet Singh Added 'pap', 'chap' to 'wanif_conf_t' 29*53ee8cc1Swenshuai.xi * Added 'authenticator' to 'wan_ppp_conf_t' 30*53ee8cc1Swenshuai.xi * Nov 06, 1997 Jaspreet Singh Changed Router Driver version to 1.1 from 1.0 31*53ee8cc1Swenshuai.xi * Oct 20, 1997 Jaspreet Singh Added 'cir','bc','be' and 'mc' to 'wanif_conf_t' 32*53ee8cc1Swenshuai.xi * Added 'enable_IPX' and 'network_number' to 33*53ee8cc1Swenshuai.xi * 'wan_device_t'. Also added defines for 34*53ee8cc1Swenshuai.xi * UDP PACKET TYPE, Interrupt test, critical values 35*53ee8cc1Swenshuai.xi * for RACE conditions. 36*53ee8cc1Swenshuai.xi * Oct 05, 1997 Jaspreet Singh Added 'dlci_num' and 'dlci[100]' to 37*53ee8cc1Swenshuai.xi * 'wan_fr_conf_t' to configure a list of dlci(s) 38*53ee8cc1Swenshuai.xi * for a NODE 39*53ee8cc1Swenshuai.xi * Jul 07, 1997 Jaspreet Singh Added 'ttl' to 'wandev_conf_t' & 'wan_device_t' 40*53ee8cc1Swenshuai.xi * May 29, 1997 Jaspreet Singh Added 'tx_int_enabled' to 'wan_device_t' 41*53ee8cc1Swenshuai.xi * May 21, 1997 Jaspreet Singh Added 'udp_port' to 'wan_device_t' 42*53ee8cc1Swenshuai.xi * Apr 25, 1997 Farhan Thawar Added 'udp_port' to 'wandev_conf_t' 43*53ee8cc1Swenshuai.xi * Jan 16, 1997 Gene Kozin router_devlist made public 44*53ee8cc1Swenshuai.xi * Jan 02, 1997 Gene Kozin Initial version (based on wanpipe.h). 45*53ee8cc1Swenshuai.xi *****************************************************************************/ 46*53ee8cc1Swenshuai.xi 47*53ee8cc1Swenshuai.xi #ifndef _ROUTER_H 48*53ee8cc1Swenshuai.xi #define _ROUTER_H 49*53ee8cc1Swenshuai.xi 50*53ee8cc1Swenshuai.xi #define ROUTER_NAME "wanrouter" /* in case we ever change it */ 51*53ee8cc1Swenshuai.xi #define ROUTER_VERSION 1 /* version number */ 52*53ee8cc1Swenshuai.xi #define ROUTER_RELEASE 1 /* release (minor version) number */ 53*53ee8cc1Swenshuai.xi #define ROUTER_IOCTL 'W' /* for IOCTL calls */ 54*53ee8cc1Swenshuai.xi #define ROUTER_MAGIC 0x524D4157L /* signature: 'WANR' reversed */ 55*53ee8cc1Swenshuai.xi 56*53ee8cc1Swenshuai.xi /* IOCTL codes for /proc/router/<device> entries (up to 255) */ 57*53ee8cc1Swenshuai.xi enum router_ioctls 58*53ee8cc1Swenshuai.xi { 59*53ee8cc1Swenshuai.xi ROUTER_SETUP = ROUTER_IOCTL<<8, /* configure device */ 60*53ee8cc1Swenshuai.xi ROUTER_DOWN, /* shut down device */ 61*53ee8cc1Swenshuai.xi ROUTER_STAT, /* get device status */ 62*53ee8cc1Swenshuai.xi ROUTER_IFNEW, /* add interface */ 63*53ee8cc1Swenshuai.xi ROUTER_IFDEL, /* delete interface */ 64*53ee8cc1Swenshuai.xi ROUTER_IFSTAT, /* get interface status */ 65*53ee8cc1Swenshuai.xi ROUTER_USER = (ROUTER_IOCTL<<8)+16, /* driver-specific calls */ 66*53ee8cc1Swenshuai.xi ROUTER_USER_MAX = (ROUTER_IOCTL<<8)+31 67*53ee8cc1Swenshuai.xi }; 68*53ee8cc1Swenshuai.xi 69*53ee8cc1Swenshuai.xi /* identifiers for displaying proc file data for dual port adapters */ 70*53ee8cc1Swenshuai.xi #define PROC_DATA_PORT_0 0x8000 /* the data is for port 0 */ 71*53ee8cc1Swenshuai.xi #define PROC_DATA_PORT_1 0x8001 /* the data is for port 1 */ 72*53ee8cc1Swenshuai.xi 73*53ee8cc1Swenshuai.xi /* NLPID for packet encapsulation (ISO/IEC TR 9577) */ 74*53ee8cc1Swenshuai.xi #define NLPID_IP 0xCC /* Internet Protocol Datagram */ 75*53ee8cc1Swenshuai.xi #define NLPID_SNAP 0x80 /* IEEE Subnetwork Access Protocol */ 76*53ee8cc1Swenshuai.xi #define NLPID_CLNP 0x81 /* ISO/IEC 8473 */ 77*53ee8cc1Swenshuai.xi #define NLPID_ESIS 0x82 /* ISO/IEC 9542 */ 78*53ee8cc1Swenshuai.xi #define NLPID_ISIS 0x83 /* ISO/IEC ISIS */ 79*53ee8cc1Swenshuai.xi #define NLPID_Q933 0x08 /* CCITT Q.933 */ 80*53ee8cc1Swenshuai.xi 81*53ee8cc1Swenshuai.xi /* Miscellaneous */ 82*53ee8cc1Swenshuai.xi #define WAN_IFNAME_SZ 15 /* max length of the interface name */ 83*53ee8cc1Swenshuai.xi #define WAN_DRVNAME_SZ 15 /* max length of the link driver name */ 84*53ee8cc1Swenshuai.xi #define WAN_ADDRESS_SZ 31 /* max length of the WAN media address */ 85*53ee8cc1Swenshuai.xi #define USED_BY_FIELD 8 /* max length of the used by field */ 86*53ee8cc1Swenshuai.xi 87*53ee8cc1Swenshuai.xi /* Defines for UDP PACKET TYPE */ 88*53ee8cc1Swenshuai.xi #define UDP_PTPIPE_TYPE 0x01 89*53ee8cc1Swenshuai.xi #define UDP_FPIPE_TYPE 0x02 90*53ee8cc1Swenshuai.xi #define UDP_CPIPE_TYPE 0x03 91*53ee8cc1Swenshuai.xi #define UDP_DRVSTATS_TYPE 0x04 92*53ee8cc1Swenshuai.xi #define UDP_INVALID_TYPE 0x05 93*53ee8cc1Swenshuai.xi 94*53ee8cc1Swenshuai.xi /* Command return code */ 95*53ee8cc1Swenshuai.xi #define CMD_OK 0 /* normal firmware return code */ 96*53ee8cc1Swenshuai.xi #define CMD_TIMEOUT 0xFF /* firmware command timed out */ 97*53ee8cc1Swenshuai.xi 98*53ee8cc1Swenshuai.xi /* UDP Packet Management */ 99*53ee8cc1Swenshuai.xi #define UDP_PKT_FRM_STACK 0x00 100*53ee8cc1Swenshuai.xi #define UDP_PKT_FRM_NETWORK 0x01 101*53ee8cc1Swenshuai.xi 102*53ee8cc1Swenshuai.xi /* Maximum interrupt test counter */ 103*53ee8cc1Swenshuai.xi #define MAX_INTR_TEST_COUNTER 100 104*53ee8cc1Swenshuai.xi 105*53ee8cc1Swenshuai.xi /* Critical Values for RACE conditions*/ 106*53ee8cc1Swenshuai.xi #define CRITICAL_IN_ISR 0xA1 107*53ee8cc1Swenshuai.xi #define CRITICAL_INTR_HANDLED 0xB1 108*53ee8cc1Swenshuai.xi 109*53ee8cc1Swenshuai.xi /****** Data Types **********************************************************/ 110*53ee8cc1Swenshuai.xi 111*53ee8cc1Swenshuai.xi /*---------------------------------------------------------------------------- 112*53ee8cc1Swenshuai.xi * X.25-specific link-level configuration. 113*53ee8cc1Swenshuai.xi */ 114*53ee8cc1Swenshuai.xi typedef struct wan_x25_conf 115*53ee8cc1Swenshuai.xi { 116*53ee8cc1Swenshuai.xi unsigned lo_pvc; /* lowest permanent circuit number */ 117*53ee8cc1Swenshuai.xi unsigned hi_pvc; /* highest permanent circuit number */ 118*53ee8cc1Swenshuai.xi unsigned lo_svc; /* lowest switched circuit number */ 119*53ee8cc1Swenshuai.xi unsigned hi_svc; /* highest switched circuit number */ 120*53ee8cc1Swenshuai.xi unsigned hdlc_window; /* HDLC window size (1..7) */ 121*53ee8cc1Swenshuai.xi unsigned pkt_window; /* X.25 packet window size (1..7) */ 122*53ee8cc1Swenshuai.xi unsigned t1; /* HDLC timer T1, sec (1..30) */ 123*53ee8cc1Swenshuai.xi unsigned t2; /* HDLC timer T2, sec (0..29) */ 124*53ee8cc1Swenshuai.xi unsigned t4; /* HDLC supervisory frame timer = T4 * T1 */ 125*53ee8cc1Swenshuai.xi unsigned n2; /* HDLC retransmission limit (1..30) */ 126*53ee8cc1Swenshuai.xi unsigned t10_t20; /* X.25 RESTART timeout, sec (1..255) */ 127*53ee8cc1Swenshuai.xi unsigned t11_t21; /* X.25 CALL timeout, sec (1..255) */ 128*53ee8cc1Swenshuai.xi unsigned t12_t22; /* X.25 RESET timeout, sec (1..255) */ 129*53ee8cc1Swenshuai.xi unsigned t13_t23; /* X.25 CLEAR timeout, sec (1..255) */ 130*53ee8cc1Swenshuai.xi unsigned t16_t26; /* X.25 INTERRUPT timeout, sec (1..255) */ 131*53ee8cc1Swenshuai.xi unsigned t28; /* X.25 REGISTRATION timeout, sec (1..255) */ 132*53ee8cc1Swenshuai.xi unsigned r10_r20; /* RESTART retransmission limit (0..250) */ 133*53ee8cc1Swenshuai.xi unsigned r12_r22; /* RESET retransmission limit (0..250) */ 134*53ee8cc1Swenshuai.xi unsigned r13_r23; /* CLEAR retransmission limit (0..250) */ 135*53ee8cc1Swenshuai.xi unsigned ccitt_compat; /* compatibility mode: 1988/1984/1980 */ 136*53ee8cc1Swenshuai.xi unsigned x25_conf_opt; /* User defined x25 config optoins */ 137*53ee8cc1Swenshuai.xi unsigned char LAPB_hdlc_only; /* Run in HDLC only mode */ 138*53ee8cc1Swenshuai.xi unsigned char logging; /* Control connection logging */ 139*53ee8cc1Swenshuai.xi unsigned char oob_on_modem; /* Whether to send modem status to the user app */ 140*53ee8cc1Swenshuai.xi } wan_x25_conf_t; 141*53ee8cc1Swenshuai.xi 142*53ee8cc1Swenshuai.xi /*---------------------------------------------------------------------------- 143*53ee8cc1Swenshuai.xi * Frame relay specific link-level configuration. 144*53ee8cc1Swenshuai.xi */ 145*53ee8cc1Swenshuai.xi typedef struct wan_fr_conf 146*53ee8cc1Swenshuai.xi { 147*53ee8cc1Swenshuai.xi unsigned signalling; /* local in-channel signalling type */ 148*53ee8cc1Swenshuai.xi unsigned t391; /* link integrity verification timer */ 149*53ee8cc1Swenshuai.xi unsigned t392; /* polling verification timer */ 150*53ee8cc1Swenshuai.xi unsigned n391; /* full status polling cycle counter */ 151*53ee8cc1Swenshuai.xi unsigned n392; /* error threshold counter */ 152*53ee8cc1Swenshuai.xi unsigned n393; /* monitored events counter */ 153*53ee8cc1Swenshuai.xi unsigned dlci_num; /* number of DLCs (access node) */ 154*53ee8cc1Swenshuai.xi unsigned dlci[100]; /* List of all DLCIs */ 155*53ee8cc1Swenshuai.xi } wan_fr_conf_t; 156*53ee8cc1Swenshuai.xi 157*53ee8cc1Swenshuai.xi /*---------------------------------------------------------------------------- 158*53ee8cc1Swenshuai.xi * PPP-specific link-level configuration. 159*53ee8cc1Swenshuai.xi */ 160*53ee8cc1Swenshuai.xi typedef struct wan_ppp_conf 161*53ee8cc1Swenshuai.xi { 162*53ee8cc1Swenshuai.xi unsigned restart_tmr; /* restart timer */ 163*53ee8cc1Swenshuai.xi unsigned auth_rsrt_tmr; /* authentication timer */ 164*53ee8cc1Swenshuai.xi unsigned auth_wait_tmr; /* authentication timer */ 165*53ee8cc1Swenshuai.xi unsigned mdm_fail_tmr; /* modem failure timer */ 166*53ee8cc1Swenshuai.xi unsigned dtr_drop_tmr; /* DTR drop timer */ 167*53ee8cc1Swenshuai.xi unsigned connect_tmout; /* connection timeout */ 168*53ee8cc1Swenshuai.xi unsigned conf_retry; /* max. retry */ 169*53ee8cc1Swenshuai.xi unsigned term_retry; /* max. retry */ 170*53ee8cc1Swenshuai.xi unsigned fail_retry; /* max. retry */ 171*53ee8cc1Swenshuai.xi unsigned auth_retry; /* max. retry */ 172*53ee8cc1Swenshuai.xi unsigned auth_options; /* authentication opt. */ 173*53ee8cc1Swenshuai.xi unsigned ip_options; /* IP options */ 174*53ee8cc1Swenshuai.xi char authenticator; /* AUTHENTICATOR or not */ 175*53ee8cc1Swenshuai.xi char ip_mode; /* Static/Host/Peer */ 176*53ee8cc1Swenshuai.xi } wan_ppp_conf_t; 177*53ee8cc1Swenshuai.xi 178*53ee8cc1Swenshuai.xi /*---------------------------------------------------------------------------- 179*53ee8cc1Swenshuai.xi * CHDLC-specific link-level configuration. 180*53ee8cc1Swenshuai.xi */ 181*53ee8cc1Swenshuai.xi typedef struct wan_chdlc_conf 182*53ee8cc1Swenshuai.xi { 183*53ee8cc1Swenshuai.xi unsigned char ignore_dcd; /* Protocol options: */ 184*53ee8cc1Swenshuai.xi unsigned char ignore_cts; /* Ignore these to determine */ 185*53ee8cc1Swenshuai.xi unsigned char ignore_keepalive; /* link status (Yes or No) */ 186*53ee8cc1Swenshuai.xi unsigned char hdlc_streaming; /* hdlc_streaming mode (Y/N) */ 187*53ee8cc1Swenshuai.xi unsigned char receive_only; /* no transmit buffering (Y/N) */ 188*53ee8cc1Swenshuai.xi unsigned keepalive_tx_tmr; /* transmit keepalive timer */ 189*53ee8cc1Swenshuai.xi unsigned keepalive_rx_tmr; /* receive keepalive timer */ 190*53ee8cc1Swenshuai.xi unsigned keepalive_err_margin; /* keepalive_error_tolerance */ 191*53ee8cc1Swenshuai.xi unsigned slarp_timer; /* SLARP request timer */ 192*53ee8cc1Swenshuai.xi } wan_chdlc_conf_t; 193*53ee8cc1Swenshuai.xi 194*53ee8cc1Swenshuai.xi 195*53ee8cc1Swenshuai.xi /*---------------------------------------------------------------------------- 196*53ee8cc1Swenshuai.xi * WAN device configuration. Passed to ROUTER_SETUP IOCTL. 197*53ee8cc1Swenshuai.xi */ 198*53ee8cc1Swenshuai.xi typedef struct wandev_conf 199*53ee8cc1Swenshuai.xi { 200*53ee8cc1Swenshuai.xi unsigned magic; /* magic number (for verification) */ 201*53ee8cc1Swenshuai.xi unsigned config_id; /* configuration structure identifier */ 202*53ee8cc1Swenshuai.xi /****** hardware configuration ******/ 203*53ee8cc1Swenshuai.xi unsigned ioport; /* adapter I/O port base */ 204*53ee8cc1Swenshuai.xi unsigned long maddr; /* dual-port memory address */ 205*53ee8cc1Swenshuai.xi unsigned msize; /* dual-port memory size */ 206*53ee8cc1Swenshuai.xi int irq; /* interrupt request level */ 207*53ee8cc1Swenshuai.xi int dma; /* DMA request level */ 208*53ee8cc1Swenshuai.xi char S514_CPU_no[1]; /* S514 PCI adapter CPU number ('A' or 'B') */ 209*53ee8cc1Swenshuai.xi unsigned PCI_slot_no; /* S514 PCI adapter slot number */ 210*53ee8cc1Swenshuai.xi char auto_pci_cfg; /* S515 PCI automatic slot detection */ 211*53ee8cc1Swenshuai.xi char comm_port; /* Communication Port (PRI=0, SEC=1) */ 212*53ee8cc1Swenshuai.xi unsigned bps; /* data transfer rate */ 213*53ee8cc1Swenshuai.xi unsigned mtu; /* maximum transmit unit size */ 214*53ee8cc1Swenshuai.xi unsigned udp_port; /* UDP port for management */ 215*53ee8cc1Swenshuai.xi unsigned char ttl; /* Time To Live for UDP security */ 216*53ee8cc1Swenshuai.xi unsigned char ft1; /* FT1 Configurator Option */ 217*53ee8cc1Swenshuai.xi char interface; /* RS-232/V.35, etc. */ 218*53ee8cc1Swenshuai.xi char clocking; /* external/internal */ 219*53ee8cc1Swenshuai.xi char line_coding; /* NRZ/NRZI/FM0/FM1, etc. */ 220*53ee8cc1Swenshuai.xi char station; /* DTE/DCE, primary/secondary, etc. */ 221*53ee8cc1Swenshuai.xi char connection; /* permanent/switched/on-demand */ 222*53ee8cc1Swenshuai.xi char read_mode; /* read mode: Polling or interrupt */ 223*53ee8cc1Swenshuai.xi char receive_only; /* disable tx buffers */ 224*53ee8cc1Swenshuai.xi char tty; /* Create a fake tty device */ 225*53ee8cc1Swenshuai.xi unsigned tty_major; /* Major number for wanpipe tty device */ 226*53ee8cc1Swenshuai.xi unsigned tty_minor; /* Minor number for wanpipe tty device */ 227*53ee8cc1Swenshuai.xi unsigned tty_mode; /* TTY operation mode SYNC or ASYNC */ 228*53ee8cc1Swenshuai.xi char backup; /* Backup Mode */ 229*53ee8cc1Swenshuai.xi unsigned hw_opt[4]; /* other hardware options */ 230*53ee8cc1Swenshuai.xi unsigned reserved[4]; 231*53ee8cc1Swenshuai.xi /****** arbitrary data ***************/ 232*53ee8cc1Swenshuai.xi unsigned data_size; /* data buffer size */ 233*53ee8cc1Swenshuai.xi void* data; /* data buffer, e.g. firmware */ 234*53ee8cc1Swenshuai.xi union /****** protocol-specific ************/ 235*53ee8cc1Swenshuai.xi { 236*53ee8cc1Swenshuai.xi wan_x25_conf_t x25; /* X.25 configuration */ 237*53ee8cc1Swenshuai.xi wan_ppp_conf_t ppp; /* PPP configuration */ 238*53ee8cc1Swenshuai.xi wan_fr_conf_t fr; /* frame relay configuration */ 239*53ee8cc1Swenshuai.xi wan_chdlc_conf_t chdlc; /* Cisco HDLC configuration */ 240*53ee8cc1Swenshuai.xi } u; 241*53ee8cc1Swenshuai.xi } wandev_conf_t; 242*53ee8cc1Swenshuai.xi 243*53ee8cc1Swenshuai.xi /* 'config_id' definitions */ 244*53ee8cc1Swenshuai.xi #define WANCONFIG_X25 101 /* X.25 link */ 245*53ee8cc1Swenshuai.xi #define WANCONFIG_FR 102 /* frame relay link */ 246*53ee8cc1Swenshuai.xi #define WANCONFIG_PPP 103 /* synchronous PPP link */ 247*53ee8cc1Swenshuai.xi #define WANCONFIG_CHDLC 104 /* Cisco HDLC Link */ 248*53ee8cc1Swenshuai.xi #define WANCONFIG_BSC 105 /* BiSync Streaming */ 249*53ee8cc1Swenshuai.xi #define WANCONFIG_HDLC 106 /* HDLC Support */ 250*53ee8cc1Swenshuai.xi #define WANCONFIG_MPPP 107 /* Multi Port PPP over RAW CHDLC */ 251*53ee8cc1Swenshuai.xi 252*53ee8cc1Swenshuai.xi /* 253*53ee8cc1Swenshuai.xi * Configuration options defines. 254*53ee8cc1Swenshuai.xi */ 255*53ee8cc1Swenshuai.xi /* general options */ 256*53ee8cc1Swenshuai.xi #define WANOPT_OFF 0 257*53ee8cc1Swenshuai.xi #define WANOPT_ON 1 258*53ee8cc1Swenshuai.xi #define WANOPT_NO 0 259*53ee8cc1Swenshuai.xi #define WANOPT_YES 1 260*53ee8cc1Swenshuai.xi 261*53ee8cc1Swenshuai.xi /* intercace options */ 262*53ee8cc1Swenshuai.xi #define WANOPT_RS232 0 263*53ee8cc1Swenshuai.xi #define WANOPT_V35 1 264*53ee8cc1Swenshuai.xi 265*53ee8cc1Swenshuai.xi /* data encoding options */ 266*53ee8cc1Swenshuai.xi #define WANOPT_NRZ 0 267*53ee8cc1Swenshuai.xi #define WANOPT_NRZI 1 268*53ee8cc1Swenshuai.xi #define WANOPT_FM0 2 269*53ee8cc1Swenshuai.xi #define WANOPT_FM1 3 270*53ee8cc1Swenshuai.xi 271*53ee8cc1Swenshuai.xi /* link type options */ 272*53ee8cc1Swenshuai.xi #define WANOPT_POINTTOPOINT 0 /* RTS always active */ 273*53ee8cc1Swenshuai.xi #define WANOPT_MULTIDROP 1 /* RTS is active when transmitting */ 274*53ee8cc1Swenshuai.xi 275*53ee8cc1Swenshuai.xi /* clocking options */ 276*53ee8cc1Swenshuai.xi #define WANOPT_EXTERNAL 0 277*53ee8cc1Swenshuai.xi #define WANOPT_INTERNAL 1 278*53ee8cc1Swenshuai.xi 279*53ee8cc1Swenshuai.xi /* station options */ 280*53ee8cc1Swenshuai.xi #define WANOPT_DTE 0 281*53ee8cc1Swenshuai.xi #define WANOPT_DCE 1 282*53ee8cc1Swenshuai.xi #define WANOPT_CPE 0 283*53ee8cc1Swenshuai.xi #define WANOPT_NODE 1 284*53ee8cc1Swenshuai.xi #define WANOPT_SECONDARY 0 285*53ee8cc1Swenshuai.xi #define WANOPT_PRIMARY 1 286*53ee8cc1Swenshuai.xi 287*53ee8cc1Swenshuai.xi /* connection options */ 288*53ee8cc1Swenshuai.xi #define WANOPT_PERMANENT 0 /* DTR always active */ 289*53ee8cc1Swenshuai.xi #define WANOPT_SWITCHED 1 /* use DTR to setup link (dial-up) */ 290*53ee8cc1Swenshuai.xi #define WANOPT_ONDEMAND 2 /* activate DTR only before sending */ 291*53ee8cc1Swenshuai.xi 292*53ee8cc1Swenshuai.xi /* frame relay in-channel signalling */ 293*53ee8cc1Swenshuai.xi #define WANOPT_FR_ANSI 1 /* ANSI T1.617 Annex D */ 294*53ee8cc1Swenshuai.xi #define WANOPT_FR_Q933 2 /* ITU Q.933A */ 295*53ee8cc1Swenshuai.xi #define WANOPT_FR_LMI 3 /* LMI */ 296*53ee8cc1Swenshuai.xi 297*53ee8cc1Swenshuai.xi /* PPP IP Mode Options */ 298*53ee8cc1Swenshuai.xi #define WANOPT_PPP_STATIC 0 299*53ee8cc1Swenshuai.xi #define WANOPT_PPP_HOST 1 300*53ee8cc1Swenshuai.xi #define WANOPT_PPP_PEER 2 301*53ee8cc1Swenshuai.xi 302*53ee8cc1Swenshuai.xi /* ASY Mode Options */ 303*53ee8cc1Swenshuai.xi #define WANOPT_ONE 1 304*53ee8cc1Swenshuai.xi #define WANOPT_TWO 2 305*53ee8cc1Swenshuai.xi #define WANOPT_ONE_AND_HALF 3 306*53ee8cc1Swenshuai.xi 307*53ee8cc1Swenshuai.xi #define WANOPT_NONE 0 308*53ee8cc1Swenshuai.xi #define WANOPT_ODD 1 309*53ee8cc1Swenshuai.xi #define WANOPT_EVEN 2 310*53ee8cc1Swenshuai.xi 311*53ee8cc1Swenshuai.xi /* CHDLC Protocol Options */ 312*53ee8cc1Swenshuai.xi /* DF Commmented out for now. 313*53ee8cc1Swenshuai.xi 314*53ee8cc1Swenshuai.xi #define WANOPT_CHDLC_NO_DCD IGNORE_DCD_FOR_LINK_STAT 315*53ee8cc1Swenshuai.xi #define WANOPT_CHDLC_NO_CTS IGNORE_CTS_FOR_LINK_STAT 316*53ee8cc1Swenshuai.xi #define WANOPT_CHDLC_NO_KEEPALIVE IGNORE_KPALV_FOR_LINK_STAT 317*53ee8cc1Swenshuai.xi */ 318*53ee8cc1Swenshuai.xi 319*53ee8cc1Swenshuai.xi /* Port options */ 320*53ee8cc1Swenshuai.xi #define WANOPT_PRI 0 321*53ee8cc1Swenshuai.xi #define WANOPT_SEC 1 322*53ee8cc1Swenshuai.xi /* read mode */ 323*53ee8cc1Swenshuai.xi #define WANOPT_INTR 0 324*53ee8cc1Swenshuai.xi #define WANOPT_POLL 1 325*53ee8cc1Swenshuai.xi 326*53ee8cc1Swenshuai.xi 327*53ee8cc1Swenshuai.xi #define WANOPT_TTY_SYNC 0 328*53ee8cc1Swenshuai.xi #define WANOPT_TTY_ASYNC 1 329*53ee8cc1Swenshuai.xi /*---------------------------------------------------------------------------- 330*53ee8cc1Swenshuai.xi * WAN Link Status Info (for ROUTER_STAT IOCTL). 331*53ee8cc1Swenshuai.xi */ 332*53ee8cc1Swenshuai.xi typedef struct wandev_stat 333*53ee8cc1Swenshuai.xi { 334*53ee8cc1Swenshuai.xi unsigned state; /* link state */ 335*53ee8cc1Swenshuai.xi unsigned ndev; /* number of configured interfaces */ 336*53ee8cc1Swenshuai.xi 337*53ee8cc1Swenshuai.xi /* link/interface configuration */ 338*53ee8cc1Swenshuai.xi unsigned connection; /* permanent/switched/on-demand */ 339*53ee8cc1Swenshuai.xi unsigned media_type; /* Frame relay/PPP/X.25/SDLC, etc. */ 340*53ee8cc1Swenshuai.xi unsigned mtu; /* max. transmit unit for this device */ 341*53ee8cc1Swenshuai.xi 342*53ee8cc1Swenshuai.xi /* physical level statistics */ 343*53ee8cc1Swenshuai.xi unsigned modem_status; /* modem status */ 344*53ee8cc1Swenshuai.xi unsigned rx_frames; /* received frames count */ 345*53ee8cc1Swenshuai.xi unsigned rx_overruns; /* receiver overrun error count */ 346*53ee8cc1Swenshuai.xi unsigned rx_crc_err; /* receive CRC error count */ 347*53ee8cc1Swenshuai.xi unsigned rx_aborts; /* received aborted frames count */ 348*53ee8cc1Swenshuai.xi unsigned rx_bad_length; /* unexpetedly long/short frames count */ 349*53ee8cc1Swenshuai.xi unsigned rx_dropped; /* frames discarded at device level */ 350*53ee8cc1Swenshuai.xi unsigned tx_frames; /* transmitted frames count */ 351*53ee8cc1Swenshuai.xi unsigned tx_underruns; /* aborted transmissions (underruns) count */ 352*53ee8cc1Swenshuai.xi unsigned tx_timeouts; /* transmission timeouts */ 353*53ee8cc1Swenshuai.xi unsigned tx_rejects; /* other transmit errors */ 354*53ee8cc1Swenshuai.xi 355*53ee8cc1Swenshuai.xi /* media level statistics */ 356*53ee8cc1Swenshuai.xi unsigned rx_bad_format; /* frames with invalid format */ 357*53ee8cc1Swenshuai.xi unsigned rx_bad_addr; /* frames with invalid media address */ 358*53ee8cc1Swenshuai.xi unsigned tx_retries; /* frames re-transmitted */ 359*53ee8cc1Swenshuai.xi unsigned reserved[16]; /* reserved for future use */ 360*53ee8cc1Swenshuai.xi } wandev_stat_t; 361*53ee8cc1Swenshuai.xi 362*53ee8cc1Swenshuai.xi /* 'state' defines */ 363*53ee8cc1Swenshuai.xi enum wan_states 364*53ee8cc1Swenshuai.xi { 365*53ee8cc1Swenshuai.xi WAN_UNCONFIGURED, /* link/channel is not configured */ 366*53ee8cc1Swenshuai.xi WAN_DISCONNECTED, /* link/channel is disconnected */ 367*53ee8cc1Swenshuai.xi WAN_CONNECTING, /* connection is in progress */ 368*53ee8cc1Swenshuai.xi WAN_CONNECTED, /* link/channel is operational */ 369*53ee8cc1Swenshuai.xi WAN_LIMIT, /* for verification only */ 370*53ee8cc1Swenshuai.xi WAN_DUALPORT, /* for Dual Port cards */ 371*53ee8cc1Swenshuai.xi WAN_DISCONNECTING, 372*53ee8cc1Swenshuai.xi WAN_FT1_READY /* FT1 Configurator Ready */ 373*53ee8cc1Swenshuai.xi }; 374*53ee8cc1Swenshuai.xi 375*53ee8cc1Swenshuai.xi enum { 376*53ee8cc1Swenshuai.xi WAN_LOCAL_IP, 377*53ee8cc1Swenshuai.xi WAN_POINTOPOINT_IP, 378*53ee8cc1Swenshuai.xi WAN_NETMASK_IP, 379*53ee8cc1Swenshuai.xi WAN_BROADCAST_IP 380*53ee8cc1Swenshuai.xi }; 381*53ee8cc1Swenshuai.xi 382*53ee8cc1Swenshuai.xi /* 'modem_status' masks */ 383*53ee8cc1Swenshuai.xi #define WAN_MODEM_CTS 0x0001 /* CTS line active */ 384*53ee8cc1Swenshuai.xi #define WAN_MODEM_DCD 0x0002 /* DCD line active */ 385*53ee8cc1Swenshuai.xi #define WAN_MODEM_DTR 0x0010 /* DTR line active */ 386*53ee8cc1Swenshuai.xi #define WAN_MODEM_RTS 0x0020 /* RTS line active */ 387*53ee8cc1Swenshuai.xi 388*53ee8cc1Swenshuai.xi /*---------------------------------------------------------------------------- 389*53ee8cc1Swenshuai.xi * WAN interface (logical channel) configuration (for ROUTER_IFNEW IOCTL). 390*53ee8cc1Swenshuai.xi */ 391*53ee8cc1Swenshuai.xi typedef struct wanif_conf 392*53ee8cc1Swenshuai.xi { 393*53ee8cc1Swenshuai.xi unsigned magic; /* magic number */ 394*53ee8cc1Swenshuai.xi unsigned config_id; /* configuration identifier */ 395*53ee8cc1Swenshuai.xi char name[WAN_IFNAME_SZ+1]; /* interface name, ASCIIZ */ 396*53ee8cc1Swenshuai.xi char addr[WAN_ADDRESS_SZ+1]; /* media address, ASCIIZ */ 397*53ee8cc1Swenshuai.xi char usedby[USED_BY_FIELD]; /* used by API or WANPIPE */ 398*53ee8cc1Swenshuai.xi unsigned idle_timeout; /* sec, before disconnecting */ 399*53ee8cc1Swenshuai.xi unsigned hold_timeout; /* sec, before re-connecting */ 400*53ee8cc1Swenshuai.xi unsigned cir; /* Committed Information Rate fwd,bwd*/ 401*53ee8cc1Swenshuai.xi unsigned bc; /* Committed Burst Size fwd, bwd */ 402*53ee8cc1Swenshuai.xi unsigned be; /* Excess Burst Size fwd, bwd */ 403*53ee8cc1Swenshuai.xi unsigned char enable_IPX; /* Enable or Disable IPX */ 404*53ee8cc1Swenshuai.xi unsigned char inarp; /* Send Inverse ARP requests Y/N */ 405*53ee8cc1Swenshuai.xi unsigned inarp_interval; /* sec, between InARP requests */ 406*53ee8cc1Swenshuai.xi unsigned long network_number; /* Network Number for IPX */ 407*53ee8cc1Swenshuai.xi char mc; /* Multicast on or off */ 408*53ee8cc1Swenshuai.xi char local_addr[WAN_ADDRESS_SZ+1];/* local media address, ASCIIZ */ 409*53ee8cc1Swenshuai.xi unsigned char port; /* board port */ 410*53ee8cc1Swenshuai.xi unsigned char protocol; /* prococol used in this channel (TCPOX25 or X25) */ 411*53ee8cc1Swenshuai.xi char pap; /* PAP enabled or disabled */ 412*53ee8cc1Swenshuai.xi char chap; /* CHAP enabled or disabled */ 413*53ee8cc1Swenshuai.xi unsigned char userid[511]; /* List of User Id */ 414*53ee8cc1Swenshuai.xi unsigned char passwd[511]; /* List of passwords */ 415*53ee8cc1Swenshuai.xi unsigned char sysname[31]; /* Name of the system */ 416*53ee8cc1Swenshuai.xi unsigned char ignore_dcd; /* Protocol options: */ 417*53ee8cc1Swenshuai.xi unsigned char ignore_cts; /* Ignore these to determine */ 418*53ee8cc1Swenshuai.xi unsigned char ignore_keepalive; /* link status (Yes or No) */ 419*53ee8cc1Swenshuai.xi unsigned char hdlc_streaming; /* Hdlc streaming mode (Y/N) */ 420*53ee8cc1Swenshuai.xi unsigned keepalive_tx_tmr; /* transmit keepalive timer */ 421*53ee8cc1Swenshuai.xi unsigned keepalive_rx_tmr; /* receive keepalive timer */ 422*53ee8cc1Swenshuai.xi unsigned keepalive_err_margin; /* keepalive_error_tolerance */ 423*53ee8cc1Swenshuai.xi unsigned slarp_timer; /* SLARP request timer */ 424*53ee8cc1Swenshuai.xi unsigned char ttl; /* Time To Live for UDP security */ 425*53ee8cc1Swenshuai.xi char interface; /* RS-232/V.35, etc. */ 426*53ee8cc1Swenshuai.xi char clocking; /* external/internal */ 427*53ee8cc1Swenshuai.xi unsigned bps; /* data transfer rate */ 428*53ee8cc1Swenshuai.xi unsigned mtu; /* maximum transmit unit size */ 429*53ee8cc1Swenshuai.xi unsigned char if_down; /* brind down interface when disconnected */ 430*53ee8cc1Swenshuai.xi unsigned char gateway; /* Is this interface a gateway */ 431*53ee8cc1Swenshuai.xi unsigned char true_if_encoding; /* Set the dev->type to true board protocol */ 432*53ee8cc1Swenshuai.xi 433*53ee8cc1Swenshuai.xi unsigned char asy_data_trans; /* async API options */ 434*53ee8cc1Swenshuai.xi unsigned char rts_hs_for_receive; /* async Protocol options */ 435*53ee8cc1Swenshuai.xi unsigned char xon_xoff_hs_for_receive; 436*53ee8cc1Swenshuai.xi unsigned char xon_xoff_hs_for_transmit; 437*53ee8cc1Swenshuai.xi unsigned char dcd_hs_for_transmit; 438*53ee8cc1Swenshuai.xi unsigned char cts_hs_for_transmit; 439*53ee8cc1Swenshuai.xi unsigned char async_mode; 440*53ee8cc1Swenshuai.xi unsigned tx_bits_per_char; 441*53ee8cc1Swenshuai.xi unsigned rx_bits_per_char; 442*53ee8cc1Swenshuai.xi unsigned stop_bits; 443*53ee8cc1Swenshuai.xi unsigned char parity; 444*53ee8cc1Swenshuai.xi unsigned break_timer; 445*53ee8cc1Swenshuai.xi unsigned inter_char_timer; 446*53ee8cc1Swenshuai.xi unsigned rx_complete_length; 447*53ee8cc1Swenshuai.xi unsigned xon_char; 448*53ee8cc1Swenshuai.xi unsigned xoff_char; 449*53ee8cc1Swenshuai.xi unsigned char receive_only; /* no transmit buffering (Y/N) */ 450*53ee8cc1Swenshuai.xi } wanif_conf_t; 451*53ee8cc1Swenshuai.xi 452*53ee8cc1Swenshuai.xi #endif /* _ROUTER_H */ 453