]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
irda: prevent heap corruption on invalid nickname
authorDan Rosenberg <drosenberg@vsecurity.com>
Sat, 19 Mar 2011 20:14:30 +0000 (20:14 +0000)
committerWilly Tarreau <w@1wt.eu>
Sat, 30 Apr 2011 14:53:26 +0000 (16:53 +0200)
commit d50e7e3604778bfc2dc40f440e0742dbae399d54 upstream.

Invalid nicknames containing only spaces will result in an underflow in
a memcpy size calculation, subsequently destroying the heap and
panicking.

v2 also catches the case where the provided nickname is longer than the
buffer size, which can result in controllable heap corruption.

Signed-off-by: Dan Rosenberg <drosenberg@vsecurity.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
net/irda/irnet/irnet_ppp.c

index 6d8ae03c14f5b8e3dc12af9906a14e1b0ae3b666..8f5664fdb69ff0ca8f0bd67ccae0e06981cfa431 100644 (file)
@@ -104,6 +104,9 @@ irnet_ctrl_write(irnet_socket *     ap,
              while(isspace(start[length - 1]))
                length--;
 
+             DABORT(length < 5 || length > NICKNAME_MAX_LEN + 5,
+                    -EINVAL, CTRL_ERROR, "Invalid nickname.\n");
+
              /* Copy the name for later reuse */
              memcpy(ap->rname, start + 5, length - 5);
              ap->rname[length - 5] = '\0';