/*- * SPDX-License-Identifier: BSD-2-Clause * * Copyright (c) 1996 - 2001 Brian Somers * based on work by Toshiharu OHNO * Internet Initiative Japan, Inc (IIJ) * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ #define CCP_MAXCODE CODE_RESETACK #define TY_OUI 0 /* OUI */ #define TY_PRED1 1 /* Predictor type 1 */ #define TY_PRED2 2 /* Predictor type 2 */ #define TY_PUDDLE 3 /* Puddle Jumper */ #define TY_HWPPC 16 /* Hewlett-Packard PPC */ #define TY_STAC 17 /* Stac Electronics LZS */ #define TY_MSPPC 18 /* Microsoft PPC */ #define TY_MPPE 18 /* Microsoft PPE */ #define TY_GAND 19 /* Gandalf FZA */ #define TY_V42BIS 20 /* V.42bis compression */ #define TY_BSD 21 /* BSD LZW Compress */ #define TY_PPPD_DEFLATE 24 /* Deflate (gzip) - (mis) numbered by pppd */ #define TY_DEFLATE 26 /* Deflate (gzip) - rfc 1979 */ #define CCP_NEG_DEFLATE 0 #define CCP_NEG_PRED1 1 #define CCP_NEG_DEFLATE24 2 #ifndef NODES #define CCP_NEG_MPPE 3 #define CCP_NEG_TOTAL 4 #else #define CCP_NEG_TOTAL 3 #endif #ifndef NODES enum mppe_negstate { MPPE_ANYSTATE, MPPE_STATELESS, MPPE_STATEFUL }; #endif struct mbuf; struct link; struct ccp_config { struct { struct { int winsize; } in, out; } deflate; #ifndef NODES struct { int keybits; enum mppe_negstate state; unsigned required : 1; } mppe; #endif struct fsm_retry fsm; /* How often/frequently to resend requests */ unsigned neg[CCP_NEG_TOTAL]; }; struct ccp_opt { struct ccp_opt *next; int algorithm; struct fsm_opt val; }; struct ccp { struct fsm fsm; /* The finite state machine */ int his_proto; /* peer's compression protocol */ int my_proto; /* our compression protocol */ int reset_sent; /* If != -1, ignore compressed 'till ack */ int last_reset; /* We can receive more (dups) w/ this id */ struct { int algorithm; /* Algorithm in use */ void *state; /* Returned by implementations Init() */ struct fsm_opt opt; /* Set by implementation's OptInit() */ } in; struct { int algorithm; /* Algorithm in use */ void *state; /* Returned by implementations Init() */ struct ccp_opt *opt; /* Set by implementation's OptInit() */ } out; u_int32_t his_reject; /* Request codes rejected by peer */ u_int32_t my_reject; /* Request codes I have rejected */ u_long uncompout, compout; /* Outgoing bytes before/after compression */ u_long uncompin, compin; /* Incoming bytes after/before decompression */ struct ccp_config cfg; }; #define fsm2ccp(fp) (fp->proto == PROTO_CCP ? (struct ccp *)fp : NULL) struct ccp_algorithm { int id; int Neg; /* ccp_config neg array item */ const char *(*Disp)(struct fsm_opt *); /* Use result immediately ! */ int (*Usable)(struct fsm *); /* Ok to negotiate ? */ int (*Required)(struct fsm *); /* Must negotiate ? */ struct { int (*Set)(struct bundle *, struct fsm_opt *, const struct ccp_config *); void *(*Init)(struct bundle *, struct fsm_opt *); void (*Term)(void *); void (*Reset)(void *); struct mbuf *(*Read)(void *, struct ccp *, u_short *, struct mbuf *); void (*DictSetup)(void *, struct ccp *, u_short, struct mbuf *); } i; struct { int MTUOverhead; void (*OptInit)(struct bundle *, struct fsm_opt *, const struct ccp_config *); int (*Set)(struct bundle *, struct fsm_opt *, const struct ccp_config *); void *(*Init)(struct bundle *, struct fsm_opt *); void (*Term)(void *); int (*Reset)(void *); struct mbuf *(*Write)(void *, struct ccp *, struct link *, int, u_short *, struct mbuf *); } o; }; extern void ccp_Init(struct ccp *, struct bundle *, struct link *, const struct fsm_parent *); extern void ccp_Setup(struct ccp *); extern int ccp_Required(struct ccp *); extern int ccp_MTUOverhead(struct ccp *); extern void ccp_SendResetReq(struct fsm *); extern struct mbuf *ccp_Input(struct bundle *, struct link *, struct mbuf *); extern int ccp_ReportStatus(struct cmdargs const *); extern u_short ccp_Proto(struct ccp *); extern void ccp_SetupCallbacks(struct ccp *); extern int ccp_SetOpenMode(struct ccp *); extern int ccp_DefaultUsable(struct fsm *); extern int ccp_DefaultRequired(struct fsm *); extern struct layer ccplayer;