Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp55394pxa; Mon, 3 Aug 2020 22:39:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzXHVBQkurvXspklD0s+4MpNGFhhAra0OAmO8jBTMrRp+/f+CP9xXoJfFEklCYlC6FlK6V0 X-Received: by 2002:a05:6402:3199:: with SMTP id di25mr19133627edb.315.1596519567167; Mon, 03 Aug 2020 22:39:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596519567; cv=none; d=google.com; s=arc-20160816; b=WHjnvMU6aaxL/SW1khlZwer0x6vEwUFIdRPKaFXXlgOORcI6IDIsoBpHYcNOk5ZVHJ oguBJJQcmGKjdmExeW81SKw4kyMGk/+BVPpsoKd3cd53YRUTHcptqUfO3fr88XxtK9Jn FHVjO8T/8XrJk+7mFMB3kveVAMx2D6vtKEjNzgkKISf1L1zxkVeH+LTwDJ1CCV2iC4ge 10Kv2Nb5ypd/ABBMz6Qyq0i2+0U/XiI25oAS7pAcPFTg4PgQhJrqPbsmEivDQJlAdhB1 dqmQ4/nLL1ktaOkmxpmR7YnlGBjB1LF083P+yv1m1OwRoYOCHq2Rgbnn82falz09tqFF 7Hig== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:in-reply-to:content-disposition :mime-version:references:mail-followup-to:message-id:subject:cc:from :date:dkim-signature; bh=Cv9dwVi/Wv30ZWHkdUpxmHaYyxiCbxozjhCWMQldsSA=; b=bgUMMGtcb4KGcuTLdb6reLhS/WGdGyH92i+Wtkhm3RCh3QUHuQ0fIaYbBCf6YesZQs sNSZYkl0tIpDs8VPnfzK1EZ1aIs5tUDPUjphTWCZ7Qvbqiaort9/EyUY2CfdEOseQgSm +gbC4CNUEv6O73qW/XKlI7tMaxIp71bjLmz0ekOwedaZ/+2hRcf5M8ncFh4q2QQMqANI ndp/z9Tio8DVs9z53okh7a0XZQ1AEuQCQrOtdB1OmbFxgTRlrihXwNhff/cSn2NzvVLG HD913GtilKrJVQovvvZA9qb53ebHYQy1fmwyYnUmOZ1ZguwnuDqowGiiHD6t3d+SYKw1 VDcQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=hid86rnu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ca18si11793409edb.414.2020.08.03.22.39.04; Mon, 03 Aug 2020 22:39:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=hid86rnu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729275AbgHDFiT (ORCPT + 99 others); Tue, 4 Aug 2020 01:38:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60154 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727035AbgHDFiT (ORCPT ); Tue, 4 Aug 2020 01:38:19 -0400 Received: from mail-wm1-x344.google.com (mail-wm1-x344.google.com [IPv6:2a00:1450:4864:20::344]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9F7D4C06174A for ; Mon, 3 Aug 2020 22:38:18 -0700 (PDT) Received: by mail-wm1-x344.google.com with SMTP id c80so1503051wme.0 for ; Mon, 03 Aug 2020 22:38:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=date:from:to:cc:subject:message-id:mail-followup-to:references :mime-version:content-disposition:in-reply-to; bh=Cv9dwVi/Wv30ZWHkdUpxmHaYyxiCbxozjhCWMQldsSA=; b=hid86rnu5RdeUriBzIBEf2/tA0fNBYdk6DhoKMlhiCAMpSXUwfxj3XLOQYGYor+YKh obVBT6XDDh/nIOP/LLJHUDkolrw4gukhJtqws5Ae8PJmgsBp4SXJvioc/neeKpv+QxUx OCjfoxlE59A4ZzmPaytbEqYfW9PwqrL1k/rk0= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :in-reply-to; bh=Cv9dwVi/Wv30ZWHkdUpxmHaYyxiCbxozjhCWMQldsSA=; b=jf5Q3qEudH7x53Q/fuTmUjLqPk6q0EZ58Ni6iTUyGtK+Mcobrt7aGNEMLHos2a0Alo ykh9tl5DfJJ466NuXh/9l8rxUkcsra905e3LXFRfLZO4YEq/+RK/8FB7sBlv5Ez9EiXE M5+VeYmg7n2lNdVL5IQavPit14sOwi2+zLJYHRpIbs/5bnWkJuAWU7QZzMEgOUOtrgJ1 5RlPr1eaESk/y+w03PNy3DSykvKBxmKcvhR/L7yg/xnKRiA5s5n4PhT2BfZ31O4Yxu1d Riv5TFSAyAyb6GGwBZYqEV9d+jjhQ01T2GNbxRO0f5VsOURa2PcJUenyAPYa00Z08NlT P3og== X-Gm-Message-State: AOAM531eO1jHHGrbFCVfH4rkNAXMXy5bv7NOlXodzxt3Vedi1HQgympM A+OkY+pjGg/nqXC4/OOl5jojoA== X-Received: by 2002:a7b:c257:: with SMTP id b23mr2251985wmj.164.1596519497267; Mon, 03 Aug 2020 22:38:17 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id f63sm3156762wmf.9.2020.08.03.22.38.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 03 Aug 2020 22:38:16 -0700 (PDT) Date: Tue, 4 Aug 2020 07:38:14 +0200 From: daniel@ffwll.ch Cc: Daniel Vetter , Greg Kroah-Hartman , Jiri Slaby , Linux Fbdev development list , Bartlomiej Zolnierkiewicz , Linux Kernel Mailing List , dri-devel , syzbot Subject: Re: [PATCH v2] fbmem: pull fbcon_update_vcs() out of fb_set_var() Message-ID: <20200804053814.GG6419@phenom.ffwll.local> Mail-Followup-To: Tetsuo Handa , Greg Kroah-Hartman , Jiri Slaby , Linux Fbdev development list , Bartlomiej Zolnierkiewicz , Linux Kernel Mailing List , dri-devel , syzbot References: <1596000620-4075-1-git-send-email-penguin-kernel@I-love.SAKURA.ne.jp> <075b7e37-3278-cd7d-31ab-c5073cfa8e92@i-love.sakura.ne.jp> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <075b7e37-3278-cd7d-31ab-c5073cfa8e92@i-love.sakura.ne.jp> X-Operating-System: Linux phenom 5.7.0-1-amd64 To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jul 30, 2020 at 07:47:14PM +0900, Tetsuo Handa wrote: > syzbot is reporting OOB read bug in vc_do_resize() [1] caused by memcpy() > based on outdated old_{rows,row_size} values, for resize_screen() can > recurse into vc_do_resize() which changes vc->vc_{cols,rows} that outdates > old_{rows,row_size} values which were saved before calling resize_screen(). > > Daniel Vetter explained that resize_screen() should not recurse into > fbcon_update_vcs() path due to FBINFO_MISC_USEREVENT being still set > when calling resize_screen(). > > Instead of masking FBINFO_MISC_USEREVENT before calling fbcon_update_vcs(), > we can remove FBINFO_MISC_USEREVENT by calling fbcon_update_vcs() only if > fb_set_var() returned 0. This change assumes that it is harmless to call > fbcon_update_vcs() when fb_set_var() returned 0 without reaching > fb_notifier_call_chain(). > > [1] https://syzkaller.appspot.com/bug?id=c70c88cfd16dcf6e1d3c7f0ab8648b3144b5b25e > > Reported-and-tested-by: syzbot > Suggested-by: Daniel Vetter > Signed-off-by: Tetsuo Handa > Reported-by: kernel test robot for missing #include Thanks a lot for your patch, queued up to hopefully still make it for 5.9-rc1. Cheers, Daniel > --- > drivers/video/fbdev/core/fbmem.c | 8 ++------ > drivers/video/fbdev/core/fbsysfs.c | 4 ++-- > drivers/video/fbdev/ps3fb.c | 5 +++-- > include/linux/fb.h | 2 -- > 4 files changed, 7 insertions(+), 12 deletions(-) > > diff --git a/drivers/video/fbdev/core/fbmem.c b/drivers/video/fbdev/core/fbmem.c > index 30e73ec..da7c88f 100644 > --- a/drivers/video/fbdev/core/fbmem.c > +++ b/drivers/video/fbdev/core/fbmem.c > @@ -957,7 +957,6 @@ static int fb_check_caps(struct fb_info *info, struct fb_var_screeninfo *var, > int > fb_set_var(struct fb_info *info, struct fb_var_screeninfo *var) > { > - int flags = info->flags; > int ret = 0; > u32 activate; > struct fb_var_screeninfo old_var; > @@ -1052,9 +1051,6 @@ static int fb_check_caps(struct fb_info *info, struct fb_var_screeninfo *var, > event.data = &mode; > fb_notifier_call_chain(FB_EVENT_MODE_CHANGE, &event); > > - if (flags & FBINFO_MISC_USEREVENT) > - fbcon_update_vcs(info, activate & FB_ACTIVATE_ALL); > - > return 0; > } > EXPORT_SYMBOL(fb_set_var); > @@ -1105,9 +1101,9 @@ static long do_fb_ioctl(struct fb_info *info, unsigned int cmd, > return -EFAULT; > console_lock(); > lock_fb_info(info); > - info->flags |= FBINFO_MISC_USEREVENT; > ret = fb_set_var(info, &var); > - info->flags &= ~FBINFO_MISC_USEREVENT; > + if (!ret) > + fbcon_update_vcs(info, var.activate & FB_ACTIVATE_ALL); > unlock_fb_info(info); > console_unlock(); > if (!ret && copy_to_user(argp, &var, sizeof(var))) > diff --git a/drivers/video/fbdev/core/fbsysfs.c b/drivers/video/fbdev/core/fbsysfs.c > index d54c88f..65dae05 100644 > --- a/drivers/video/fbdev/core/fbsysfs.c > +++ b/drivers/video/fbdev/core/fbsysfs.c > @@ -91,9 +91,9 @@ static int activate(struct fb_info *fb_info, struct fb_var_screeninfo *var) > > var->activate |= FB_ACTIVATE_FORCE; > console_lock(); > - fb_info->flags |= FBINFO_MISC_USEREVENT; > err = fb_set_var(fb_info, var); > - fb_info->flags &= ~FBINFO_MISC_USEREVENT; > + if (!err) > + fbcon_update_vcs(fb_info, var->activate & FB_ACTIVATE_ALL); > console_unlock(); > if (err) > return err; > diff --git a/drivers/video/fbdev/ps3fb.c b/drivers/video/fbdev/ps3fb.c > index 9df78fb..203c254 100644 > --- a/drivers/video/fbdev/ps3fb.c > +++ b/drivers/video/fbdev/ps3fb.c > @@ -29,6 +29,7 @@ > #include > #include > #include > +#include > #include > > #include > @@ -824,12 +825,12 @@ static int ps3fb_ioctl(struct fb_info *info, unsigned int cmd, > var = info->var; > fb_videomode_to_var(&var, vmode); > console_lock(); > - info->flags |= FBINFO_MISC_USEREVENT; > /* Force, in case only special bits changed */ > var.activate |= FB_ACTIVATE_FORCE; > par->new_mode_id = val; > retval = fb_set_var(info, &var); > - info->flags &= ~FBINFO_MISC_USEREVENT; > + if (!retval) > + fbcon_update_vcs(info, var.activate & FB_ACTIVATE_ALL); > console_unlock(); > } > break; > diff --git a/include/linux/fb.h b/include/linux/fb.h > index 3b4b2f0..b11eb02 100644 > --- a/include/linux/fb.h > +++ b/include/linux/fb.h > @@ -400,8 +400,6 @@ struct fb_tile_ops { > #define FBINFO_HWACCEL_YPAN 0x2000 /* optional */ > #define FBINFO_HWACCEL_YWRAP 0x4000 /* optional */ > > -#define FBINFO_MISC_USEREVENT 0x10000 /* event request > - from userspace */ > #define FBINFO_MISC_TILEBLITTING 0x20000 /* use tile blitting */ > > /* A driver may set this flag to indicate that it does want a set_par to be > -- > 1.8.3.1 > -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch