isdnloop: several buffer overflows
authorDan Carpenter <dan.carpenter@oracle.com>
Tue, 8 Apr 2014 09:23:09 +0000 (12:23 +0300)
committerDavid S. Miller <davem@davemloft.net>
Tue, 8 Apr 2014 16:41:13 +0000 (12:41 -0400)
commit7563487cbf865284dcd35e9ef5a95380da046737
tree2310eddf3a9aa21aa7b2a0fb1e5d9fec83c1b2a5
parent6859e7df6d9045a461412777e63bd8cef12f9705
isdnloop: several buffer overflows

There are three buffer overflows addressed in this patch.

1) In isdnloop_fake_err() we add an 'E' to a 60 character string and
then copy it into a 60 character buffer.  I have made the destination
buffer 64 characters and I'm changed the sprintf() to a snprintf().

2) In isdnloop_parse_cmd(), p points to a 6 characters into a 60
character buffer so we have 54 characters.  The ->eazlist[] is 11
characters long.  I have modified the code to return if the source
buffer is too long.

3) In isdnloop_command() the cbuf[] array was 60 characters long but the
max length of the string then can be up to 79 characters.  I made the
cbuf array 80 characters long and changed the sprintf() to snprintf().
I also removed the temporary "dial" buffer and changed it to use "p"
directly.

Unfortunately, we pass the "cbuf" string from isdnloop_command() to
isdnloop_writecmd() which truncates anything over 60 characters to make
it fit in card->omsg[].  (It can accept values up to 255 characters so
long as there is a '\n' character every 60 characters).  For now I have
just fixed the memory corruption bug and left the other problems in this
driver alone.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/isdn/isdnloop/isdnloop.c