mirror of
https://github.com/lwip-tcpip/lwip.git
synced 2024-09-13 02:05:43 +00:00
PPP, MPPE, removed address, control and protocol from compressor input
Our PPP stack deals with packet without address and control byte nor 2-byte protocol field, improved mppe_compress() so we don't have to worry about them.
This commit is contained in:
parent
9164c4f309
commit
dc93c2afec
@ -132,7 +132,7 @@ int mppe_comp_init(void *arg, unsigned char *options, int optlen, int unit,
|
|||||||
int hdrlen, int debug);
|
int hdrlen, int debug);
|
||||||
void mppe_comp_reset(void *arg);
|
void mppe_comp_reset(void *arg);
|
||||||
int mppe_compress(void *arg, unsigned char *ibuf, unsigned char *obuf,
|
int mppe_compress(void *arg, unsigned char *ibuf, unsigned char *obuf,
|
||||||
int isize, int osize);
|
int isize, int osize, u16_t protocol);
|
||||||
int mppe_decomp_init(void *arg, unsigned char *options, int optlen, int unit,
|
int mppe_decomp_init(void *arg, unsigned char *options, int optlen, int unit,
|
||||||
int hdrlen, int mru, int debug);
|
int hdrlen, int mru, int debug);
|
||||||
void mppe_decomp_reset(void *arg);
|
void mppe_decomp_reset(void *arg);
|
||||||
|
@ -282,28 +282,20 @@ void mppe_comp_reset(void *arg)
|
|||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
mppe_compress(void *arg, unsigned char *ibuf, unsigned char *obuf,
|
mppe_compress(void *arg, unsigned char *ibuf, unsigned char *obuf,
|
||||||
int isize, int osize)
|
int isize, int osize, u16_t protocol)
|
||||||
{
|
{
|
||||||
struct ppp_mppe_state *state = (struct ppp_mppe_state *) arg;
|
struct ppp_mppe_state *state = (struct ppp_mppe_state *) arg;
|
||||||
int proto;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Check that the protocol is in the range we handle.
|
|
||||||
*/
|
|
||||||
proto = PPP_PROTOCOL(ibuf);
|
|
||||||
if (proto < 0x0021 || proto > 0x00fa)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
/* Make sure we have enough room to generate an encrypted packet. */
|
/* Make sure we have enough room to generate an encrypted packet. */
|
||||||
if (osize < isize + MPPE_OVHD - PPP_HDRLEN + 2) {
|
if (osize < isize + MPPE_OVHD + 2) {
|
||||||
/* Drop the packet if we should encrypt it, but can't. */
|
/* Drop the packet if we should encrypt it, but can't. */
|
||||||
PPPDEBUG(LOG_DEBUG, ("mppe_compress[%d]: osize too small! "
|
PPPDEBUG(LOG_DEBUG, ("mppe_compress[%d]: osize too small! "
|
||||||
"(have: %d need: %d)\n", state->unit,
|
"(have: %d need: %d)\n", state->unit,
|
||||||
osize, osize + MPPE_OVHD - PPP_HDRLEN + 2));
|
osize, osize + MPPE_OVHD + 2));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
osize = isize + MPPE_OVHD - PPP_HDRLEN + 2;
|
osize = isize + MPPE_OVHD + 2;
|
||||||
|
|
||||||
|
|
||||||
state->ccount = (state->ccount + 1) % MPPE_CCOUNT_SPACE;
|
state->ccount = (state->ccount + 1) % MPPE_CCOUNT_SPACE;
|
||||||
@ -326,10 +318,14 @@ mppe_compress(void *arg, unsigned char *ibuf, unsigned char *obuf,
|
|||||||
}
|
}
|
||||||
obuf[0] |= state->bits;
|
obuf[0] |= state->bits;
|
||||||
state->bits &= ~MPPE_BIT_FLUSHED; /* reset for next xmit */
|
state->bits &= ~MPPE_BIT_FLUSHED; /* reset for next xmit */
|
||||||
|
|
||||||
obuf += MPPE_OVHD;
|
obuf += MPPE_OVHD;
|
||||||
ibuf += 2; /* skip to proto field */
|
|
||||||
isize -= 2;
|
/* Add and encrypt protocol */
|
||||||
|
/* FIXME: add PFC support */
|
||||||
|
obuf[0] = protocol >> 8;
|
||||||
|
obuf[1] = protocol;
|
||||||
|
arc4_crypt(&state->arc4, obuf, 2);
|
||||||
|
obuf += 2;
|
||||||
|
|
||||||
/* Encrypt packet */
|
/* Encrypt packet */
|
||||||
MEMCPY(obuf, ibuf, isize);
|
MEMCPY(obuf, ibuf, isize);
|
||||||
|
Loading…
Reference in New Issue
Block a user