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