xref: /utopia/UTPA2-700.0.x/projects/tools/lint/mips-linux-gnu_include/linux/if_ppp.h (revision 53ee8cc121a030b8d368113ac3e966b4705770ef)
1*53ee8cc1Swenshuai.xi /*	$Id: if_ppp.h,v 1.21 2000/03/27 06:03:36 paulus Exp $	*/
2*53ee8cc1Swenshuai.xi 
3*53ee8cc1Swenshuai.xi /*
4*53ee8cc1Swenshuai.xi  * if_ppp.h - Point-to-Point Protocol definitions.
5*53ee8cc1Swenshuai.xi  *
6*53ee8cc1Swenshuai.xi  * Copyright (c) 1989 Carnegie Mellon University.
7*53ee8cc1Swenshuai.xi  * All rights reserved.
8*53ee8cc1Swenshuai.xi  *
9*53ee8cc1Swenshuai.xi  * Redistribution and use in source and binary forms are permitted
10*53ee8cc1Swenshuai.xi  * provided that the above copyright notice and this paragraph are
11*53ee8cc1Swenshuai.xi  * duplicated in all such forms and that any documentation,
12*53ee8cc1Swenshuai.xi  * advertising materials, and other materials related to such
13*53ee8cc1Swenshuai.xi  * distribution and use acknowledge that the software was developed
14*53ee8cc1Swenshuai.xi  * by Carnegie Mellon University.  The name of the
15*53ee8cc1Swenshuai.xi  * University may not be used to endorse or promote products derived
16*53ee8cc1Swenshuai.xi  * from this software without specific prior written permission.
17*53ee8cc1Swenshuai.xi  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
18*53ee8cc1Swenshuai.xi  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
19*53ee8cc1Swenshuai.xi  * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
20*53ee8cc1Swenshuai.xi  *
21*53ee8cc1Swenshuai.xi  */
22*53ee8cc1Swenshuai.xi 
23*53ee8cc1Swenshuai.xi /*
24*53ee8cc1Swenshuai.xi  *  ==FILEVERSION 20050812==
25*53ee8cc1Swenshuai.xi  *
26*53ee8cc1Swenshuai.xi  *  NOTE TO MAINTAINERS:
27*53ee8cc1Swenshuai.xi  *     If you modify this file at all, please set the above date.
28*53ee8cc1Swenshuai.xi  *     if_ppp.h is shipped with a PPP distribution as well as with the kernel;
29*53ee8cc1Swenshuai.xi  *     if everyone increases the FILEVERSION number above, then scripts
30*53ee8cc1Swenshuai.xi  *     can do the right thing when deciding whether to install a new if_ppp.h
31*53ee8cc1Swenshuai.xi  *     file.  Don't change the format of that line otherwise, so the
32*53ee8cc1Swenshuai.xi  *     installation script can recognize it.
33*53ee8cc1Swenshuai.xi  */
34*53ee8cc1Swenshuai.xi 
35*53ee8cc1Swenshuai.xi #ifndef _IF_PPP_H_
36*53ee8cc1Swenshuai.xi #define _IF_PPP_H_
37*53ee8cc1Swenshuai.xi 
38*53ee8cc1Swenshuai.xi 
39*53ee8cc1Swenshuai.xi /*
40*53ee8cc1Swenshuai.xi  * Packet sizes
41*53ee8cc1Swenshuai.xi  */
42*53ee8cc1Swenshuai.xi 
43*53ee8cc1Swenshuai.xi #define	PPP_MTU		1500	/* Default MTU (size of Info field) */
44*53ee8cc1Swenshuai.xi #define PPP_MAXMRU	65000	/* Largest MRU we allow */
45*53ee8cc1Swenshuai.xi #define PROTO_IPX	0x002b	/* protocol numbers */
46*53ee8cc1Swenshuai.xi #define PROTO_DNA_RT    0x0027  /* DNA Routing */
47*53ee8cc1Swenshuai.xi 
48*53ee8cc1Swenshuai.xi 
49*53ee8cc1Swenshuai.xi /*
50*53ee8cc1Swenshuai.xi  * Bit definitions for flags.
51*53ee8cc1Swenshuai.xi  */
52*53ee8cc1Swenshuai.xi 
53*53ee8cc1Swenshuai.xi #define SC_COMP_PROT	0x00000001	/* protocol compression (output) */
54*53ee8cc1Swenshuai.xi #define SC_COMP_AC	0x00000002	/* header compression (output) */
55*53ee8cc1Swenshuai.xi #define	SC_COMP_TCP	0x00000004	/* TCP (VJ) compression (output) */
56*53ee8cc1Swenshuai.xi #define SC_NO_TCP_CCID	0x00000008	/* disable VJ connection-id comp. */
57*53ee8cc1Swenshuai.xi #define SC_REJ_COMP_AC	0x00000010	/* reject adrs/ctrl comp. on input */
58*53ee8cc1Swenshuai.xi #define SC_REJ_COMP_TCP	0x00000020	/* reject TCP (VJ) comp. on input */
59*53ee8cc1Swenshuai.xi #define SC_CCP_OPEN	0x00000040	/* Look at CCP packets */
60*53ee8cc1Swenshuai.xi #define SC_CCP_UP	0x00000080	/* May send/recv compressed packets */
61*53ee8cc1Swenshuai.xi #define SC_ENABLE_IP	0x00000100	/* IP packets may be exchanged */
62*53ee8cc1Swenshuai.xi #define SC_LOOP_TRAFFIC	0x00000200	/* send traffic to pppd */
63*53ee8cc1Swenshuai.xi #define SC_MULTILINK	0x00000400	/* do multilink encapsulation */
64*53ee8cc1Swenshuai.xi #define SC_MP_SHORTSEQ	0x00000800	/* use short MP sequence numbers */
65*53ee8cc1Swenshuai.xi #define SC_COMP_RUN	0x00001000	/* compressor has been inited */
66*53ee8cc1Swenshuai.xi #define SC_DECOMP_RUN	0x00002000	/* decompressor has been inited */
67*53ee8cc1Swenshuai.xi #define SC_MP_XSHORTSEQ	0x00004000	/* transmit short MP seq numbers */
68*53ee8cc1Swenshuai.xi #define SC_DEBUG	0x00010000	/* enable debug messages */
69*53ee8cc1Swenshuai.xi #define SC_LOG_INPKT	0x00020000	/* log contents of good pkts recvd */
70*53ee8cc1Swenshuai.xi #define SC_LOG_OUTPKT	0x00040000	/* log contents of pkts sent */
71*53ee8cc1Swenshuai.xi #define SC_LOG_RAWIN	0x00080000	/* log all chars received */
72*53ee8cc1Swenshuai.xi #define SC_LOG_FLUSH	0x00100000	/* log all chars flushed */
73*53ee8cc1Swenshuai.xi #define	SC_SYNC		0x00200000	/* synchronous serial mode */
74*53ee8cc1Swenshuai.xi #define	SC_MUST_COMP    0x00400000	/* no uncompressed packets may be sent or received */
75*53ee8cc1Swenshuai.xi #define	SC_MASK		0x0f600fff	/* bits that user can change */
76*53ee8cc1Swenshuai.xi 
77*53ee8cc1Swenshuai.xi /* state bits */
78*53ee8cc1Swenshuai.xi #define SC_XMIT_BUSY	0x10000000	/* (used by isdn_ppp?) */
79*53ee8cc1Swenshuai.xi #define SC_RCV_ODDP	0x08000000	/* have rcvd char with odd parity */
80*53ee8cc1Swenshuai.xi #define SC_RCV_EVNP	0x04000000	/* have rcvd char with even parity */
81*53ee8cc1Swenshuai.xi #define SC_RCV_B7_1	0x02000000	/* have rcvd char with bit 7 = 1 */
82*53ee8cc1Swenshuai.xi #define SC_RCV_B7_0	0x01000000	/* have rcvd char with bit 7 = 0 */
83*53ee8cc1Swenshuai.xi #define SC_DC_FERROR	0x00800000	/* fatal decomp error detected */
84*53ee8cc1Swenshuai.xi #define SC_DC_ERROR	0x00400000	/* non-fatal decomp error detected */
85*53ee8cc1Swenshuai.xi 
86*53ee8cc1Swenshuai.xi /*
87*53ee8cc1Swenshuai.xi  * Ioctl definitions.
88*53ee8cc1Swenshuai.xi  */
89*53ee8cc1Swenshuai.xi 
90*53ee8cc1Swenshuai.xi struct npioctl {
91*53ee8cc1Swenshuai.xi 	int		protocol;	/* PPP protocol, e.g. PPP_IP */
92*53ee8cc1Swenshuai.xi 	enum NPmode	mode;
93*53ee8cc1Swenshuai.xi };
94*53ee8cc1Swenshuai.xi 
95*53ee8cc1Swenshuai.xi /* Structure describing a CCP configuration option, for PPPIOCSCOMPRESS */
96*53ee8cc1Swenshuai.xi struct ppp_option_data {
97*53ee8cc1Swenshuai.xi 	__u8 *ptr;
98*53ee8cc1Swenshuai.xi 	__u32	length;
99*53ee8cc1Swenshuai.xi 	int	transmit;
100*53ee8cc1Swenshuai.xi };
101*53ee8cc1Swenshuai.xi 
102*53ee8cc1Swenshuai.xi struct ifpppstatsreq {
103*53ee8cc1Swenshuai.xi 	struct ifreq	 b;
104*53ee8cc1Swenshuai.xi 	struct ppp_stats stats;			/* statistic information */
105*53ee8cc1Swenshuai.xi };
106*53ee8cc1Swenshuai.xi 
107*53ee8cc1Swenshuai.xi struct ifpppcstatsreq {
108*53ee8cc1Swenshuai.xi 	struct ifreq	      b;
109*53ee8cc1Swenshuai.xi 	struct ppp_comp_stats stats;
110*53ee8cc1Swenshuai.xi };
111*53ee8cc1Swenshuai.xi 
112*53ee8cc1Swenshuai.xi /* For PPPIOCGL2TPSTATS */
113*53ee8cc1Swenshuai.xi struct pppol2tp_ioc_stats {
114*53ee8cc1Swenshuai.xi 	__u16		tunnel_id;	/* redundant */
115*53ee8cc1Swenshuai.xi 	__u16		session_id;	/* if zero, get tunnel stats */
116*53ee8cc1Swenshuai.xi 	__u32		using_ipsec:1;	/* valid only for session_id == 0 */
117*53ee8cc1Swenshuai.xi 	aligned_u64	tx_packets;
118*53ee8cc1Swenshuai.xi 	aligned_u64	tx_bytes;
119*53ee8cc1Swenshuai.xi 	aligned_u64	tx_errors;
120*53ee8cc1Swenshuai.xi 	aligned_u64	rx_packets;
121*53ee8cc1Swenshuai.xi 	aligned_u64	rx_bytes;
122*53ee8cc1Swenshuai.xi 	aligned_u64	rx_seq_discards;
123*53ee8cc1Swenshuai.xi 	aligned_u64	rx_oos_packets;
124*53ee8cc1Swenshuai.xi 	aligned_u64	rx_errors;
125*53ee8cc1Swenshuai.xi };
126*53ee8cc1Swenshuai.xi 
127*53ee8cc1Swenshuai.xi #define ifr__name       b.ifr_ifrn.ifrn_name
128*53ee8cc1Swenshuai.xi #define stats_ptr       b.ifr_ifru.ifru_data
129*53ee8cc1Swenshuai.xi 
130*53ee8cc1Swenshuai.xi /*
131*53ee8cc1Swenshuai.xi  * Ioctl definitions.
132*53ee8cc1Swenshuai.xi  */
133*53ee8cc1Swenshuai.xi 
134*53ee8cc1Swenshuai.xi #define	PPPIOCGFLAGS	_IOR('t', 90, int)	/* get configuration flags */
135*53ee8cc1Swenshuai.xi #define	PPPIOCSFLAGS	_IOW('t', 89, int)	/* set configuration flags */
136*53ee8cc1Swenshuai.xi #define	PPPIOCGASYNCMAP	_IOR('t', 88, int)	/* get async map */
137*53ee8cc1Swenshuai.xi #define	PPPIOCSASYNCMAP	_IOW('t', 87, int)	/* set async map */
138*53ee8cc1Swenshuai.xi #define	PPPIOCGUNIT	_IOR('t', 86, int)	/* get ppp unit number */
139*53ee8cc1Swenshuai.xi #define	PPPIOCGRASYNCMAP _IOR('t', 85, int)	/* get receive async map */
140*53ee8cc1Swenshuai.xi #define	PPPIOCSRASYNCMAP _IOW('t', 84, int)	/* set receive async map */
141*53ee8cc1Swenshuai.xi #define	PPPIOCGMRU	_IOR('t', 83, int)	/* get max receive unit */
142*53ee8cc1Swenshuai.xi #define	PPPIOCSMRU	_IOW('t', 82, int)	/* set max receive unit */
143*53ee8cc1Swenshuai.xi #define	PPPIOCSMAXCID	_IOW('t', 81, int)	/* set VJ max slot ID */
144*53ee8cc1Swenshuai.xi #define PPPIOCGXASYNCMAP _IOR('t', 80, ext_accm) /* get extended ACCM */
145*53ee8cc1Swenshuai.xi #define PPPIOCSXASYNCMAP _IOW('t', 79, ext_accm) /* set extended ACCM */
146*53ee8cc1Swenshuai.xi #define PPPIOCXFERUNIT	_IO('t', 78)		/* transfer PPP unit */
147*53ee8cc1Swenshuai.xi #define PPPIOCSCOMPRESS	_IOW('t', 77, struct ppp_option_data)
148*53ee8cc1Swenshuai.xi #define PPPIOCGNPMODE	_IOWR('t', 76, struct npioctl) /* get NP mode */
149*53ee8cc1Swenshuai.xi #define PPPIOCSNPMODE	_IOW('t', 75, struct npioctl)  /* set NP mode */
150*53ee8cc1Swenshuai.xi #define PPPIOCSPASS	_IOW('t', 71, struct sock_fprog) /* set pass filter */
151*53ee8cc1Swenshuai.xi #define PPPIOCSACTIVE	_IOW('t', 70, struct sock_fprog) /* set active filt */
152*53ee8cc1Swenshuai.xi #define PPPIOCGDEBUG	_IOR('t', 65, int)	/* Read debug level */
153*53ee8cc1Swenshuai.xi #define PPPIOCSDEBUG	_IOW('t', 64, int)	/* Set debug level */
154*53ee8cc1Swenshuai.xi #define PPPIOCGIDLE	_IOR('t', 63, struct ppp_idle) /* get idle time */
155*53ee8cc1Swenshuai.xi #define PPPIOCNEWUNIT	_IOWR('t', 62, int)	/* create new ppp unit */
156*53ee8cc1Swenshuai.xi #define PPPIOCATTACH	_IOW('t', 61, int)	/* attach to ppp unit */
157*53ee8cc1Swenshuai.xi #define PPPIOCDETACH	_IOW('t', 60, int)	/* detach from ppp unit/chan */
158*53ee8cc1Swenshuai.xi #define PPPIOCSMRRU	_IOW('t', 59, int)	/* set multilink MRU */
159*53ee8cc1Swenshuai.xi #define PPPIOCCONNECT	_IOW('t', 58, int)	/* connect channel to unit */
160*53ee8cc1Swenshuai.xi #define PPPIOCDISCONN	_IO('t', 57)		/* disconnect channel */
161*53ee8cc1Swenshuai.xi #define PPPIOCATTCHAN	_IOW('t', 56, int)	/* attach to ppp channel */
162*53ee8cc1Swenshuai.xi #define PPPIOCGCHAN	_IOR('t', 55, int)	/* get ppp channel number */
163*53ee8cc1Swenshuai.xi #define PPPIOCGL2TPSTATS _IOR('t', 54, struct pppol2tp_ioc_stats)
164*53ee8cc1Swenshuai.xi 
165*53ee8cc1Swenshuai.xi #define SIOCGPPPSTATS   (SIOCDEVPRIVATE + 0)
166*53ee8cc1Swenshuai.xi #define SIOCGPPPVER     (SIOCDEVPRIVATE + 1)	/* NEVER change this!! */
167*53ee8cc1Swenshuai.xi #define SIOCGPPPCSTATS  (SIOCDEVPRIVATE + 2)
168*53ee8cc1Swenshuai.xi 
169*53ee8cc1Swenshuai.xi #if !defined(ifr_mtu)
170*53ee8cc1Swenshuai.xi #define ifr_mtu	ifr_ifru.ifru_metric
171*53ee8cc1Swenshuai.xi #endif
172*53ee8cc1Swenshuai.xi 
173*53ee8cc1Swenshuai.xi #endif /* _IF_PPP_H_ */
174