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