diff options
author | Fullway Wang <fullwaywang@outlook.com> | 2024-01-18 04:49:40 +0100 |
---|---|---|
committer | Helge Deller <deller@gmx.de> | 2024-01-21 09:00:14 +0100 |
commit | 04e5eac8f3ab2ff52fa191c187a46d4fdbc1e288 (patch) | |
tree | 80af462962b78bade7861a2f84b644370d89d73d /drivers/video | |
parent | fbdev: vt8500lcdfb: Remove unnecessary print function dev_err() (diff) | |
download | linux-04e5eac8f3ab2ff52fa191c187a46d4fdbc1e288.tar.xz linux-04e5eac8f3ab2ff52fa191c187a46d4fdbc1e288.zip |
fbdev: savage: Error out if pixclock equals zero
The userspace program could pass any values to the driver through
ioctl() interface. If the driver doesn't check the value of pixclock,
it may cause divide-by-zero error.
Although pixclock is checked in savagefb_decode_var(), but it is not
checked properly in savagefb_probe(). Fix this by checking whether
pixclock is zero in the function savagefb_check_var() before
info->var.pixclock is used as the divisor.
This is similar to CVE-2022-3061 in i740fb which was fixed by
commit 15cf0b8.
Signed-off-by: Fullway Wang <fullwaywang@outlook.com>
Signed-off-by: Helge Deller <deller@gmx.de>
Diffstat (limited to 'drivers/video')
-rw-r--r-- | drivers/video/fbdev/savage/savagefb_driver.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/video/fbdev/savage/savagefb_driver.c b/drivers/video/fbdev/savage/savagefb_driver.c index dddd6afcb972..ebc9aeffdde7 100644 --- a/drivers/video/fbdev/savage/savagefb_driver.c +++ b/drivers/video/fbdev/savage/savagefb_driver.c @@ -869,6 +869,9 @@ static int savagefb_check_var(struct fb_var_screeninfo *var, DBG("savagefb_check_var"); + if (!var->pixclock) + return -EINVAL; + var->transp.offset = 0; var->transp.length = 0; switch (var->bits_per_pixel) { |