mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-19 11:04:00 +08:00
irda: prevent heap corruption on invalid nickname
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> Cc: stable@kernel.org Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e433430a0c
commit
d50e7e3604
@ -105,6 +105,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';
|
||||
|
Loading…
Reference in New Issue
Block a user