Skip to content
This repository was archived by the owner on Nov 8, 2023. It is now read-only.

Commit ecbfd9e

Browse files
tdzgregkh
authored andcommitted
fbcon: Fix OOB access in font allocation
commit 9b2f5ef upstream. Commit 1a194e6 ("fbcon: fix integer overflow in fbcon_do_set_font") introduced an out-of-bounds access by storing data and allocation sizes in the same variable. Restore the old size calculation and use the new variable 'alloc_size' for the allocation. Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de> Fixes: 1a194e6 ("fbcon: fix integer overflow in fbcon_do_set_font") Reported-by: Jani Nikula <jani.nikula@linux.intel.com> Closes: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/15020 Closes: https://gitlab.freedesktop.org/drm/xe/kernel/-/issues/6201 Cc: Samasth Norway Ananda <samasth.norway.ananda@oracle.com> Cc: Thomas Zimmermann <tzimmermann@suse.de> Cc: George Kennedy <george.kennedy@oracle.com> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Simona Vetter <simona@ffwll.ch> Cc: Helge Deller <deller@gmx.de> Cc: "Ville Syrjälä" <ville.syrjala@linux.intel.com> Cc: Sam Ravnborg <sam@ravnborg.org> Cc: Qianqiang Liu <qianqiang.liu@163.com> Cc: Shixiong Ou <oushixiong@kylinos.cn> Cc: Kees Cook <kees@kernel.org> Cc: <stable@vger.kernel.org> # v5.9+ Cc: Zsolt Kajtar <soci@c64.rulez.org> Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com> Reviewed-by: Qianqiang Liu <qianqiang.liu@163.com> Link: https://lore.kernel.org/r/20250922134619.257684-1-tzimmermann@suse.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent b8a6e85 commit ecbfd9e

File tree

1 file changed

+3
-3
lines changed

1 file changed

+3
-3
lines changed

drivers/video/fbdev/core/fbcon.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2479,7 +2479,7 @@ static int fbcon_set_font(struct vc_data *vc, struct console_font *font,
24792479
unsigned charcount = font->charcount;
24802480
int w = font->width;
24812481
int h = font->height;
2482-
int size;
2482+
int size, alloc_size;
24832483
int i, csum;
24842484
u8 *new_data, *data = font->data;
24852485
int pitch = PITCH(font->width);
@@ -2512,10 +2512,10 @@ static int fbcon_set_font(struct vc_data *vc, struct console_font *font,
25122512
return -EINVAL;
25132513

25142514
/* Check for overflow in allocation size calculation */
2515-
if (check_add_overflow(FONT_EXTRA_WORDS * sizeof(int), size, &size))
2515+
if (check_add_overflow(FONT_EXTRA_WORDS * sizeof(int), size, &alloc_size))
25162516
return -EINVAL;
25172517

2518-
new_data = kmalloc(size, GFP_USER);
2518+
new_data = kmalloc(alloc_size, GFP_USER);
25192519

25202520
if (!new_data)
25212521
return -ENOMEM;

0 commit comments

Comments
 (0)