1*10465441SEvalZero /***************************************************************************** 2*10465441SEvalZero * lcp.h - Network Link Control Protocol header file. 3*10465441SEvalZero * 4*10465441SEvalZero * Copyright (c) 2003 by Marc Boucher, Services Informatiques (MBSI) inc. 5*10465441SEvalZero * portions Copyright (c) 1997 Global Election Systems Inc. 6*10465441SEvalZero * 7*10465441SEvalZero * The authors hereby grant permission to use, copy, modify, distribute, 8*10465441SEvalZero * and license this software and its documentation for any purpose, provided 9*10465441SEvalZero * that existing copyright notices are retained in all copies and that this 10*10465441SEvalZero * notice and the following disclaimer are included verbatim in any 11*10465441SEvalZero * distributions. No written agreement, license, or royalty fee is required 12*10465441SEvalZero * for any of the authorized uses. 13*10465441SEvalZero * 14*10465441SEvalZero * THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS *AS IS* AND ANY EXPRESS OR 15*10465441SEvalZero * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 16*10465441SEvalZero * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 17*10465441SEvalZero * IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 18*10465441SEvalZero * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 19*10465441SEvalZero * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 20*10465441SEvalZero * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 21*10465441SEvalZero * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 22*10465441SEvalZero * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 23*10465441SEvalZero * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 24*10465441SEvalZero * 25*10465441SEvalZero ****************************************************************************** 26*10465441SEvalZero * REVISION HISTORY 27*10465441SEvalZero * 28*10465441SEvalZero * 03-01-01 Marc Boucher <[email protected]> 29*10465441SEvalZero * Ported to lwIP. 30*10465441SEvalZero * 97-11-05 Guy Lancaster <[email protected]>, Global Election Systems Inc. 31*10465441SEvalZero * Original derived from BSD codes. 32*10465441SEvalZero *****************************************************************************/ 33*10465441SEvalZero /* 34*10465441SEvalZero * lcp.h - Link Control Protocol definitions. 35*10465441SEvalZero * 36*10465441SEvalZero * Copyright (c) 1989 Carnegie Mellon University. 37*10465441SEvalZero * All rights reserved. 38*10465441SEvalZero * 39*10465441SEvalZero * Redistribution and use in source and binary forms are permitted 40*10465441SEvalZero * provided that the above copyright notice and this paragraph are 41*10465441SEvalZero * duplicated in all such forms and that any documentation, 42*10465441SEvalZero * advertising materials, and other materials related to such 43*10465441SEvalZero * distribution and use acknowledge that the software was developed 44*10465441SEvalZero * by Carnegie Mellon University. The name of the 45*10465441SEvalZero * University may not be used to endorse or promote products derived 46*10465441SEvalZero * from this software without specific prior written permission. 47*10465441SEvalZero * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR 48*10465441SEvalZero * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED 49*10465441SEvalZero * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. 50*10465441SEvalZero * 51*10465441SEvalZero * $Id: lcp.h,v 1.4 2010/01/18 20:49:43 goldsimon Exp $ 52*10465441SEvalZero */ 53*10465441SEvalZero 54*10465441SEvalZero #ifndef LCP_H 55*10465441SEvalZero #define LCP_H 56*10465441SEvalZero /* 57*10465441SEvalZero * Options. 58*10465441SEvalZero */ 59*10465441SEvalZero #define CI_MRU 1 /* Maximum Receive Unit */ 60*10465441SEvalZero #define CI_ASYNCMAP 2 /* Async Control Character Map */ 61*10465441SEvalZero #define CI_AUTHTYPE 3 /* Authentication Type */ 62*10465441SEvalZero #define CI_QUALITY 4 /* Quality Protocol */ 63*10465441SEvalZero #define CI_MAGICNUMBER 5 /* Magic Number */ 64*10465441SEvalZero #define CI_PCOMPRESSION 7 /* Protocol Field Compression */ 65*10465441SEvalZero #define CI_ACCOMPRESSION 8 /* Address/Control Field Compression */ 66*10465441SEvalZero #define CI_CALLBACK 13 /* callback */ 67*10465441SEvalZero #define CI_MRRU 17 /* max reconstructed receive unit; multilink */ 68*10465441SEvalZero #define CI_SSNHF 18 /* short sequence numbers for multilink */ 69*10465441SEvalZero #define CI_EPDISC 19 /* endpoint discriminator */ 70*10465441SEvalZero 71*10465441SEvalZero /* 72*10465441SEvalZero * LCP-specific packet types (code numbers). 73*10465441SEvalZero */ 74*10465441SEvalZero #define PROTREJ 8 /* Protocol Reject */ 75*10465441SEvalZero #define ECHOREQ 9 /* Echo Request */ 76*10465441SEvalZero #define ECHOREP 10 /* Echo Reply */ 77*10465441SEvalZero #define DISCREQ 11 /* Discard Request */ 78*10465441SEvalZero #define CBCP_OPT 6 /* Use callback control protocol */ 79*10465441SEvalZero 80*10465441SEvalZero /* 81*10465441SEvalZero * The state of options is described by an lcp_options structure. 82*10465441SEvalZero */ 83*10465441SEvalZero typedef struct lcp_options { 84*10465441SEvalZero u_int passive : 1; /* Don't die if we don't get a response */ 85*10465441SEvalZero u_int silent : 1; /* Wait for the other end to start first */ 86*10465441SEvalZero u_int restart : 1; /* Restart vs. exit after close */ 87*10465441SEvalZero u_int neg_mru : 1; /* Negotiate the MRU? */ 88*10465441SEvalZero u_int neg_asyncmap : 1; /* Negotiate the async map? */ 89*10465441SEvalZero u_int neg_upap : 1; /* Ask for UPAP authentication? */ 90*10465441SEvalZero u_int neg_chap : 1; /* Ask for CHAP authentication? */ 91*10465441SEvalZero u_int neg_magicnumber : 1; /* Ask for magic number? */ 92*10465441SEvalZero u_int neg_pcompression : 1; /* HDLC Protocol Field Compression? */ 93*10465441SEvalZero u_int neg_accompression : 1; /* HDLC Address/Control Field Compression? */ 94*10465441SEvalZero u_int neg_lqr : 1; /* Negotiate use of Link Quality Reports */ 95*10465441SEvalZero u_int neg_cbcp : 1; /* Negotiate use of CBCP */ 96*10465441SEvalZero #ifdef PPP_MULTILINK 97*10465441SEvalZero u_int neg_mrru : 1; /* Negotiate multilink MRRU */ 98*10465441SEvalZero u_int neg_ssnhf : 1; /* Negotiate short sequence numbers */ 99*10465441SEvalZero u_int neg_endpoint : 1; /* Negotiate endpoint discriminator */ 100*10465441SEvalZero #endif 101*10465441SEvalZero u_short mru; /* Value of MRU */ 102*10465441SEvalZero #ifdef PPP_MULTILINK 103*10465441SEvalZero u_short mrru; /* Value of MRRU, and multilink enable */ 104*10465441SEvalZero #endif 105*10465441SEvalZero u_char chap_mdtype; /* which MD type (hashing algorithm) */ 106*10465441SEvalZero u32_t asyncmap; /* Value of async map */ 107*10465441SEvalZero u32_t magicnumber; 108*10465441SEvalZero int numloops; /* Number of loops during magic number neg. */ 109*10465441SEvalZero u32_t lqr_period; /* Reporting period for LQR 1/100ths second */ 110*10465441SEvalZero #ifdef PPP_MULTILINK 111*10465441SEvalZero struct epdisc endpoint; /* endpoint discriminator */ 112*10465441SEvalZero #endif 113*10465441SEvalZero } lcp_options; 114*10465441SEvalZero 115*10465441SEvalZero /* 116*10465441SEvalZero * Values for phase from BSD pppd.h based on RFC 1661. 117*10465441SEvalZero */ 118*10465441SEvalZero typedef enum { 119*10465441SEvalZero PHASE_DEAD = 0, 120*10465441SEvalZero PHASE_INITIALIZE, 121*10465441SEvalZero PHASE_ESTABLISH, 122*10465441SEvalZero PHASE_AUTHENTICATE, 123*10465441SEvalZero PHASE_CALLBACK, 124*10465441SEvalZero PHASE_NETWORK, 125*10465441SEvalZero PHASE_TERMINATE 126*10465441SEvalZero } LinkPhase; 127*10465441SEvalZero 128*10465441SEvalZero 129*10465441SEvalZero 130*10465441SEvalZero extern LinkPhase lcp_phase[NUM_PPP]; /* Phase of link session (RFC 1661) */ 131*10465441SEvalZero extern lcp_options lcp_wantoptions[]; 132*10465441SEvalZero extern lcp_options lcp_gotoptions[]; 133*10465441SEvalZero extern lcp_options lcp_allowoptions[]; 134*10465441SEvalZero extern lcp_options lcp_hisoptions[]; 135*10465441SEvalZero extern ext_accm xmit_accm[]; 136*10465441SEvalZero 137*10465441SEvalZero 138*10465441SEvalZero void lcp_init (int); 139*10465441SEvalZero void lcp_open (int); 140*10465441SEvalZero void lcp_close (int, char *); 141*10465441SEvalZero void lcp_lowerup (int); 142*10465441SEvalZero void lcp_lowerdown(int); 143*10465441SEvalZero void lcp_sprotrej (int, u_char *, int); /* send protocol reject */ 144*10465441SEvalZero 145*10465441SEvalZero extern struct protent lcp_protent; 146*10465441SEvalZero 147*10465441SEvalZero /* Default number of times we receive our magic number from the peer 148*10465441SEvalZero before deciding the link is looped-back. */ 149*10465441SEvalZero #define DEFLOOPBACKFAIL 10 150*10465441SEvalZero 151*10465441SEvalZero #endif /* LCP_H */ 152