xref: /netbsd-src/external/bsd/ppp/dist/pppd/lcp.h (revision 6d322f2f4598f0d8a138f10ea648ec4fabe41f8b)
1 /*	$NetBSD: lcp.h,v 1.2 2013/11/28 22:33:42 christos Exp $	*/
2 
3 /*
4  * lcp.h - Link Control Protocol definitions.
5  *
6  * Copyright (c) 1984-2000 Carnegie Mellon University. All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * 1. Redistributions of source code must retain the above copyright
13  *    notice, this list of conditions and the following disclaimer.
14  *
15  * 2. Redistributions in binary form must reproduce the above copyright
16  *    notice, this list of conditions and the following disclaimer in
17  *    the documentation and/or other materials provided with the
18  *    distribution.
19  *
20  * 3. The name "Carnegie Mellon University" must not be used to
21  *    endorse or promote products derived from this software without
22  *    prior written permission. For permission or any legal
23  *    details, please contact
24  *      Office of Technology Transfer
25  *      Carnegie Mellon University
26  *      5000 Forbes Avenue
27  *      Pittsburgh, PA  15213-3890
28  *      (412) 268-4387, fax: (412) 268-7395
29  *      tech-transfer@andrew.cmu.edu
30  *
31  * 4. Redistributions of any form whatsoever must retain the following
32  *    acknowledgment:
33  *    "This product includes software developed by Computing Services
34  *     at Carnegie Mellon University (http://www.cmu.edu/computing/)."
35  *
36  * CARNEGIE MELLON UNIVERSITY DISCLAIMS ALL WARRANTIES WITH REGARD TO
37  * THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
38  * AND FITNESS, IN NO EVENT SHALL CARNEGIE MELLON UNIVERSITY BE LIABLE
39  * FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
40  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
41  * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
42  * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
43  *
44  * Id: lcp.h,v 1.20 2004/11/14 22:53:42 carlsonj Exp
45  */
46 
47 /*
48  * Options.
49  */
50 #define CI_VENDOR	0	/* Vendor Specific */
51 #define CI_MRU		1	/* Maximum Receive Unit */
52 #define CI_ASYNCMAP	2	/* Async Control Character Map */
53 #define CI_AUTHTYPE	3	/* Authentication Type */
54 #define CI_QUALITY	4	/* Quality Protocol */
55 #define CI_MAGICNUMBER	5	/* Magic Number */
56 #define CI_PCOMPRESSION	7	/* Protocol Field Compression */
57 #define CI_ACCOMPRESSION 8	/* Address/Control Field Compression */
58 #define CI_FCSALTERN	9	/* FCS-Alternatives */
59 #define CI_SDP		10	/* Self-Describing-Pad */
60 #define CI_NUMBERED	11	/* Numbered-Mode */
61 #define CI_CALLBACK	13	/* callback */
62 #define CI_MRRU		17	/* max reconstructed receive unit; multilink */
63 #define CI_SSNHF	18	/* short sequence numbers for multilink */
64 #define CI_EPDISC	19	/* endpoint discriminator */
65 #define CI_MPPLUS	22	/* Multi-Link-Plus-Procedure */
66 #define CI_LDISC	23	/* Link-Discriminator */
67 #define CI_LCPAUTH	24	/* LCP Authentication */
68 #define CI_COBS		25	/* Consistent Overhead Byte Stuffing */
69 #define CI_PREFELIS	26	/* Prefix Elision */
70 #define CI_MPHDRFMT	27	/* MP Header Format */
71 #define CI_I18N		28	/* Internationalization */
72 #define CI_SDL		29	/* Simple Data Link */
73 
74 /*
75  * LCP-specific packet types (code numbers).
76  */
77 #define PROTREJ		8	/* Protocol Reject */
78 #define ECHOREQ		9	/* Echo Request */
79 #define ECHOREP		10	/* Echo Reply */
80 #define DISCREQ		11	/* Discard Request */
81 #define IDENTIF		12	/* Identification */
82 #define TIMEREM		13	/* Time Remaining */
83 
84 /* Value used as data for CI_CALLBACK option */
85 #define CBCP_OPT	6	/* Use callback control protocol */
86 
87 /*
88  * The state of options is described by an lcp_options structure.
89  */
90 typedef struct lcp_options {
91     bool passive;		/* Don't die if we don't get a response */
92     bool silent;		/* Wait for the other end to start first */
93     bool restart;		/* Restart vs. exit after close */
94     bool neg_mru;		/* Negotiate the MRU? */
95     bool neg_asyncmap;		/* Negotiate the async map? */
96     bool neg_upap;		/* Ask for UPAP authentication? */
97     bool neg_chap;		/* Ask for CHAP authentication? */
98     bool neg_eap;		/* Ask for EAP authentication? */
99     bool neg_magicnumber;	/* Ask for magic number? */
100     bool neg_pcompression;	/* HDLC Protocol Field Compression? */
101     bool neg_accompression;	/* HDLC Address/Control Field Compression? */
102     bool neg_lqr;		/* Negotiate use of Link Quality Reports */
103     bool neg_cbcp;		/* Negotiate use of CBCP */
104     bool neg_mrru;		/* negotiate multilink MRRU */
105     bool neg_ssnhf;		/* negotiate short sequence numbers */
106     bool neg_endpoint;		/* negotiate endpoint discriminator */
107     int  mru;			/* Value of MRU */
108     int	 mrru;			/* Value of MRRU, and multilink enable */
109     u_char chap_mdtype;		/* which MD types (hashing algorithm) */
110     u_int32_t asyncmap;		/* Value of async map */
111     u_int32_t magicnumber;
112     int  numloops;		/* Number of loops during magic number neg. */
113     u_int32_t lqr_period;	/* Reporting period for LQR 1/100ths second */
114     struct epdisc endpoint;	/* endpoint discriminator */
115 } lcp_options;
116 
117 extern fsm lcp_fsm[];
118 extern lcp_options lcp_wantoptions[];
119 extern lcp_options lcp_gotoptions[];
120 extern lcp_options lcp_allowoptions[];
121 extern lcp_options lcp_hisoptions[];
122 
123 #define DEFMRU	1500		/* Try for this */
124 #define MINMRU	128		/* No MRUs below this */
125 #define MAXMRU	16384		/* Normally limit MRU to this */
126 
127 void lcp_open __P((int));
128 void lcp_close __P((int, char *));
129 void lcp_lowerup __P((int));
130 void lcp_lowerdown __P((int));
131 void lcp_sprotrej __P((int, u_char *, int));	/* send protocol reject */
132 
133 extern struct protent lcp_protent;
134 
135 /* Default number of times we receive our magic number from the peer
136    before deciding the link is looped-back. */
137 #define DEFLOOPBACKFAIL	10
138