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