From: Konstantin Sharlaimov Date: Mon, 24 Sep 2007 21:01:54 +0000 (+0200) Subject: [PPP]: Fix osize too small errors when decoding mppe. X-Git-Tag: v2.6.16.54-rc1~3 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=44315cc76567e2d911d56091665637e305af182d;p=thirdparty%2Fkernel%2Fstable.git [PPP]: Fix osize too small errors when decoding mppe. The mppe_decompress() function required a buffer that is 1 byte too small when receiving a message of mru size. This fixes buffer allocation to prevent this from occurring. Signed-off-by: Konstantin Sharlaimov Signed-off-by: David S. Miller Signed-off-by: Adrian Bunk --- diff --git a/drivers/net/ppp_generic.c b/drivers/net/ppp_generic.c index e37648c256fc9..802f249b87c81 100644 --- a/drivers/net/ppp_generic.c +++ b/drivers/net/ppp_generic.c @@ -1721,7 +1721,18 @@ ppp_decompress_frame(struct ppp *ppp, struct sk_buff *skb) goto err; if (proto == PPP_COMP) { - ns = dev_alloc_skb(ppp->mru + PPP_HDRLEN); + int obuff_size; + + switch(ppp->rcomp->compress_proto) { + case CI_MPPE: + obuff_size = ppp->mru + PPP_HDRLEN + 1; + break; + default: + obuff_size = ppp->mru + PPP_HDRLEN; + break; + } + + ns = dev_alloc_skb(obuff_size); if (ns == 0) { printk(KERN_ERR "ppp_decompress_frame: no memory\n"); goto err;