Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp165780pxb; Mon, 2 Nov 2020 17:29:41 -0800 (PST) X-Google-Smtp-Source: ABdhPJwOwMhLeTve78aj66Tv1UGQGGC5pbMModoNAQDlKLcMvUqRhhHsM1HEI/pUusCve68jUnz/ X-Received: by 2002:a17:906:c298:: with SMTP id r24mr11701832ejz.76.1604366980878; Mon, 02 Nov 2020 17:29:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604366980; cv=none; d=google.com; s=arc-20160816; b=cTCsNFSkmvd9+8rlHm4/U8L2CzRhyo7XX9eLYSEkgr1pc8+EYrDsUFQH6IVQntg5Pe CEDRe90r9crEhrC2Q5u0Y3yJ7sVqL453THqy/3CnDzrYykhXPROZJMIdUPlBhI8tihOK 4gpw+BTidlxG6SbJVM6CfllJNtxtQqECz3zXm8s1wL2DoJWVeBycMvKFA22A2SC/97zY iGFrS0kv3eL/rXcDwjSf9D3cenUSWx5miycOz/HDSkGZ8CxgTV5PAbF7oh8wOBYhf2y4 De5dr6gpoXYRIp39b45xv8mVYGKsTdIM4zZV+z1zHJD5W6Z7gBidcducyDLE+uG9jJBu wE9w== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=hpuK1xq+HrFCnZzmn0WnuJllkuLsJ751lp5DkbGtuFs=; b=yrfByRLoNa0pqJdrVC572jg8lIPNHwnQx365tHXKHonwkeBQp8EnlWyq0Ik284M0ou aZW/98Ytz0SGdeA9E1Dtm7td2xKE7oasKwfTHwrTnOpsQI7Co81UJC7utglq4sS4EO4u GmUAsY7Ld9E22zHSA9AmCmkarXNZ/XmNFbyTZ2IpsxfsLxR99WPsNY7/5mQbscXmKIR6 5iqyL/Xu6uWxlLL1EulLJIMu1PnGJEUVHZ50WVJRQngbrft0Fh7WHBGTRPIhNNIXoJSG NlZ1aPltWgS9jZxnXeWjlHe8XiFo6T0f28vSDEBgVg0LUgioxJnGgVhQx4zZqL4Ri+fP hJfQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=bNc+kNaS; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g4si12188311edj.168.2020.11.02.17.29.18; Mon, 02 Nov 2020 17:29:40 -0800 (PST) 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=@kernel.org header.s=default header.b=bNc+kNaS; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727401AbgKCBS4 (ORCPT + 99 others); Mon, 2 Nov 2020 20:18:56 -0500 Received: from mail.kernel.org ([198.145.29.99]:60274 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727265AbgKCBSt (ORCPT ); Mon, 2 Nov 2020 20:18:49 -0500 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 76CCF22277; Tue, 3 Nov 2020 01:18:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604366329; bh=uueFz4NHq4UJJNizEaoVTQCqCi7fkiwkMdZ4QFb1lSs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bNc+kNaSi8RNwyCCjCqjTo2vcMWCoLGTzCr/TeGt2ZIDDz7ZcnIHCNtmD9CvHqz+K 37ev0ExrU8qMGzsyRVQN8ZDNiyCKWH3aGDGxqjP4AJp0gODCL38aF6v5l3KdSO+VvG O8jraoDEB1h3j58Mw24R8osWEeiI7XS7caJY7rvo= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Kairui Song , Ingo Molnar , Sasha Levin Subject: [PATCH AUTOSEL 5.9 06/35] x86/kexec: Use up-to-dated screen_info copy to fill boot params Date: Mon, 2 Nov 2020 20:18:11 -0500 Message-Id: <20201103011840.182814-6-sashal@kernel.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20201103011840.182814-1-sashal@kernel.org> References: <20201103011840.182814-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Kairui Song [ Upstream commit afc18069a2cb7ead5f86623a5f3d4ad6e21f940d ] kexec_file_load() currently reuses the old boot_params.screen_info, but if drivers have change the hardware state, boot_param.screen_info could contain invalid info. For example, the video type might be no longer VGA, or the frame buffer address might be changed. If the kexec kernel keeps using the old screen_info, kexec'ed kernel may attempt to write to an invalid framebuffer memory region. There are two screen_info instances globally available, boot_params.screen_info and screen_info. Later one is a copy, and is updated by drivers. So let kexec_file_load use the updated copy. [ mingo: Tidied up the changelog. ] Signed-off-by: Kairui Song Signed-off-by: Ingo Molnar Link: https://lore.kernel.org/r/20201014092429.1415040-2-kasong@redhat.com Signed-off-by: Sasha Levin --- arch/x86/kernel/kexec-bzimage64.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/arch/x86/kernel/kexec-bzimage64.c b/arch/x86/kernel/kexec-bzimage64.c index 57c2ecf431343..ce831f9448e71 100644 --- a/arch/x86/kernel/kexec-bzimage64.c +++ b/arch/x86/kernel/kexec-bzimage64.c @@ -200,8 +200,7 @@ setup_boot_parameters(struct kimage *image, struct boot_params *params, params->hdr.hardware_subarch = boot_params.hdr.hardware_subarch; /* Copying screen_info will do? */ - memcpy(¶ms->screen_info, &boot_params.screen_info, - sizeof(struct screen_info)); + memcpy(¶ms->screen_info, &screen_info, sizeof(struct screen_info)); /* Fill in memsize later */ params->screen_info.ext_mem_k = 0; -- 2.27.0