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