Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp163888pxb; Mon, 2 Nov 2020 17:25:36 -0800 (PST) X-Google-Smtp-Source: ABdhPJzWh8QYlRuzHvXfNtbodxNaJ9+82fU55aiEaukYlotAwkUy/u/ouD2Gmgupl2TAt3olUWnN X-Received: by 2002:aa7:d351:: with SMTP id m17mr2112704edr.215.1604366736133; Mon, 02 Nov 2020 17:25:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604366736; cv=none; d=google.com; s=arc-20160816; b=vLJnt566j5JZMZRjloGZs3UgXOBMeGcNGUJWXO/+pe9b7B+avjKNeX1lnjqXvIknep nhvjIZyFQmTavFCW+lA/A68MFdDK6A2TZSL9lcTCTVlMHY3fiLVUSwrFKGBlP0STwFGi JGGI04e6EtvHBio4UtNvOnfmEdsgDzKM3+JD+pVBXJKqSk7mEeOj4a/hl3u6QAmduSvd HRZpucRlZNAtaphC4h09dD7ksrkVBbfOO2h5A7DN0qBtTyp/S3TbCsPzanzKwuLLGV8Z ZV2aKZ7EmjeXCf82XkMGRz35RBWW3/9b6yqeAza4Wuz8GEhoMSGbbnKcQQyI6J4tHIRL Magg== 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=Aem0Vr4c5vQXEnR92vjzhLj5YZvuOa2s9yXaJhyzIfQ=; b=0empLvNwxwSzNFBouNzBxyhUiFo95YdmPGOVQC/kYbHj1FE/LhU9vg3quwfs7WSYsq wheDhScsdv1APsqtl7YBc71gnce8caA23mxAoqI2u6QntK7lR1PanjnUiVDCFkgSGZ+J C3+kQtyfiFfRmwSBKm+ly0uDRbIONT2/aVIhxjjWrznkrjlGyHp5+uHqK57pptwCeRH1 pS85iT7VviHe2B4723pUHx3N0umeSheoo1O5KXm3txAe3UaOqOpq6VanRmffk/1uU5Ad lRCNbOytRZ3p7+vktxiS4VsdS8oecgh1eh89OZXARY4e1BnBRpwIL77dyKALANaiiQL1 JX8A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=M3BJALMb; 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 r12si11170034ejr.690.2020.11.02.17.25.13; Mon, 02 Nov 2020 17:25:36 -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=M3BJALMb; 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 S1728242AbgKCBUv (ORCPT + 99 others); Mon, 2 Nov 2020 20:20:51 -0500 Received: from mail.kernel.org ([198.145.29.99]:35788 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728205AbgKCBUo (ORCPT ); Mon, 2 Nov 2020 20:20:44 -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 6F6442242E; Tue, 3 Nov 2020 01:20:43 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604366444; bh=1F4wsseaD7dA/55JAb7Imc6P+6gBNObou4dyyvIU1mA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=M3BJALMb1hkt8H1nhf3DYIUxuol8vWoLdnAVuyilfB+mw2d58zbcXYhsLJeZKyUtV w4EqWRy3zeKBpYOiTL5fC7IzvYIvPVDkzJieaIY/bOwmcIBGPozz6kQ5N4rZIEMI/V QdCfc5IrLDffvudg67U+eMuPu0uZvjgFdV3spRfs= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Kairui Song , Ingo Molnar , Sasha Levin Subject: [PATCH AUTOSEL 4.19 03/11] x86/kexec: Use up-to-dated screen_info copy to fill boot params Date: Mon, 2 Nov 2020 20:20:31 -0500 Message-Id: <20201103012039.183672-3-sashal@kernel.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20201103012039.183672-1-sashal@kernel.org> References: <20201103012039.183672-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 9490a2845f14b..273687986a263 100644 --- a/arch/x86/kernel/kexec-bzimage64.c +++ b/arch/x86/kernel/kexec-bzimage64.c @@ -211,8 +211,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