diff options
author | Eric Dumazet <edumazet@google.com> | 2024-12-13 17:25:18 +0000 |
---|---|---|
committer | Jakub Kicinski <kuba@kernel.org> | 2024-12-15 13:26:47 -0800 |
commit | ee76746387f6233bdfa93d7406990f923641568f (patch) | |
tree | 9cc1589a192666be8a8a63c313c7188522d2a167 /drivers/net | |
parent | 2d5df3a680ffdaf606baa10636bdb1daf757832e (diff) | |
download | lwn-ee76746387f6233bdfa93d7406990f923641568f.tar.gz lwn-ee76746387f6233bdfa93d7406990f923641568f.zip |
netdevsim: prevent bad user input in nsim_dev_health_break_write()
If either a zero count or a large one is provided, kernel can crash.
Fixes: 82c93a87bf8b ("netdevsim: implement couple of testing devlink health reporters")
Reported-by: syzbot+ea40e4294e58b0292f74@syzkaller.appspotmail.com
Closes: https://lore.kernel.org/netdev/675c6862.050a0220.37aaf.00b1.GAE@google.com/T/#u
Signed-off-by: Eric Dumazet <edumazet@google.com>
Cc: Jiri Pirko <jiri@nvidia.com>
Reviewed-by: Joe Damato <jdamato@fastly.com>
Link: https://patch.msgid.link/20241213172518.2415666-1-edumazet@google.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/netdevsim/health.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/net/netdevsim/health.c b/drivers/net/netdevsim/health.c index 70e8bdf34be9..688f05316b5e 100644 --- a/drivers/net/netdevsim/health.c +++ b/drivers/net/netdevsim/health.c @@ -149,6 +149,8 @@ static ssize_t nsim_dev_health_break_write(struct file *file, char *break_msg; int err; + if (count == 0 || count > PAGE_SIZE) + return -EINVAL; break_msg = memdup_user_nul(data, count); if (IS_ERR(break_msg)) return PTR_ERR(break_msg); |