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