Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3527131pxj; Mon, 24 May 2021 08:41:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwivN+wHUWk21xN5KC7GVAunbBMT1vT+DikD2Io7bd4Pow8rj3kWIno+GlXUQVQkWvpYADx X-Received: by 2002:a17:906:d8cb:: with SMTP id re11mr24069579ejb.482.1621870889129; Mon, 24 May 2021 08:41:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621870889; cv=none; d=google.com; s=arc-20160816; b=0MWEM/JaGVUv5jj1h+Y3mEDD8vY7/2npM5Tsf+dgBYvacgmj4cPVMTrgqSVy0+40Me JUtMzuE5YFuWyydQbjo0DtXtty3AuKLBfUiQn4u/1x0krisxRtXsNiCA/gIv8wndYcSJ h2VrQuqgQT1BFVqdNVq0DaXp+P3rch+t7tLN+EqZEL6jYjSM6uQuydbfYO0UK3SYLE1v efWDdEBLLK7l+wWgKeeUhf/62EXg9oApEoXz0jJ6LRpW4YdGeKfbnwZ7V96pnPX21xD6 hVbOj66aFTCWL2kC15i8MtXQ84Fe2BrT127+H5i/pXUZDfGf7Lvuvs1KJgiPJf7D0dVs TpWw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=wTC/W+ZLpaUE3NsB5gf7Xo2Iy38E6wMgzUqPW04TJSw=; b=z+sl//3Bz0dUJqQwIKuMfAQhLmqU3eJvgeLp2NMUXyX1JZtbTGQyAOPZam+LsXHCSt E7POCfw6vO0zC7l6zLL7NesDhlgcXPd644lDWXzl6NFvSShlvZlQiv8g7LK4Hta6vfAV 5BN6a4oIBrka+kzapjF6+UBJqepPb1jfC3//PQddAqy0+zYdvEiSZjnvwsEeMV7uUT1u GX2ByUyIza4tcss3n/ZI8voAkS7nSAqBb0xRH5hM/rCrOg+/qVUUaqi7TPQQj+jOQk1O k4pduTZERwT0nUkk7xPC/58Btq2kw989AjsIGbqKhQiRY8vfLHu4P7OUJYCUN3BYeHq3 wMlg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=e0Cq4DYp; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b11si12452823ejd.10.2021.05.24.08.41.06; Mon, 24 May 2021 08:41:29 -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=pass header.i=@linuxfoundation.org header.s=korg header.b=e0Cq4DYp; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234175AbhEXPjJ (ORCPT + 99 others); Mon, 24 May 2021 11:39:09 -0400 Received: from mail.kernel.org ([198.145.29.99]:50502 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233881AbhEXPgW (ORCPT ); Mon, 24 May 2021 11:36:22 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 192176140F; Mon, 24 May 2021 15:32:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1621870355; bh=98wRBNLBzd4db1Bd/DlbUqjH+bZ4Vk7SYTJYePNOnKc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=e0Cq4DYpeNw1KouJ/Z+38eQjQG6i0CmLr7F4C8I79FGLQ9EAFcM7szm8IQ0Z+aeG/ KInTb1pfK5qkSDVddrPjd2cpsNjXdqxda0BSInjRA5OD5rf54p85Jq7mAT1enhcSC6 Sg2YpzJuzKpNWESJdJz+AsBmK/cOsxDt7ZCdHayg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Maciej W. Rozycki" , Linus Torvalds Subject: [PATCH 4.9 33/36] vgacon: Record video mode changes with VT_RESIZEX Date: Mon, 24 May 2021 17:25:18 +0200 Message-Id: <20210524152325.224791457@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210524152324.158146731@linuxfoundation.org> References: <20210524152324.158146731@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Maciej W. Rozycki commit d4d0ad57b3865795c4cde2fb5094c594c2e8f469 upstream. Fix an issue with VGA console font size changes made after the initial video text mode has been changed with a user tool like `svgatextmode' calling the VT_RESIZEX ioctl. As it stands in that case the original screen geometry continues being used to validate further VT resizing. Consequently when the video adapter is firstly reprogrammed from the original say 80x25 text mode using a 9x16 character cell (720x400 pixel resolution) to say 80x37 text mode and the same character cell (720x592 pixel resolution), and secondly the CRTC character cell updated to 9x8 (by loading a suitable font with the KD_FONT_OP_SET request of the KDFONTOP ioctl), the VT geometry does not get further updated from 80x37 and only upper half of the screen is used for the VT, with the lower half showing rubbish corresponding to whatever happens to be there in the video memory that maps to that part of the screen. Of course the proportions change according to text mode geometries and font sizes chosen. Address the problem then, by updating the text mode geometry defaults rather than checking against them whenever the VT is resized via a user ioctl. Signed-off-by: Maciej W. Rozycki Fixes: e400b6ec4ede ("vt/vgacon: Check if screen resize request comes from userspace") Cc: stable@vger.kernel.org # v2.6.24+ Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- drivers/video/console/vgacon.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) --- a/drivers/video/console/vgacon.c +++ b/drivers/video/console/vgacon.c @@ -1174,12 +1174,20 @@ static int vgacon_resize(struct vc_data if ((width << 1) * height > vga_vram_size) return -EINVAL; + if (user) { + /* + * Ho ho! Someone (svgatextmode, eh?) may have reprogrammed + * the video mode! Set the new defaults then and go away. + */ + screen_info.orig_video_cols = width; + screen_info.orig_video_lines = height; + vga_default_font_height = c->vc_font.height; + return 0; + } if (width % 2 || width > screen_info.orig_video_cols || height > (screen_info.orig_video_lines * vga_default_font_height)/ c->vc_font.height) - /* let svgatextmode tinker with video timings and - return success */ - return (user) ? 0 : -EINVAL; + return -EINVAL; if (con_is_visible(c) && !vga_is_gfx) /* who knows */ vgacon_doresize(c, width, height);