Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp3208641pxb; Mon, 9 Nov 2020 05:38:27 -0800 (PST) X-Google-Smtp-Source: ABdhPJxxDKSkFjgVgCFlyt8MVj1Vr5ZuDAK0RWTS4wts5Xil8V7gzBoJ8KqgWfDZAAYyl37l3oAo X-Received: by 2002:a17:906:bcf9:: with SMTP id op25mr3278810ejb.223.1604929107431; Mon, 09 Nov 2020 05:38:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604929107; cv=none; d=google.com; s=arc-20160816; b=Yxug+yL8fhAUYXMYgG2PRpaPOnFTNG0FnaYNzmH88Bd1w8GPLGCgMb29GvLIqnt5+V YsZGDqT1UKW3O1uCbKMbagCIZ3k1zizpxkF8fsPnlJdCmRjaFrLcFCT4vIFQ3yvBiyea lp+q7cWKGM5WeGMlYIc5/kMob5ORegtCrIdPmNxpsoOOEESusFmVN/RScPh7cC1EzsSw jGL1ygyWq4IxJPhRNCgKAKfbBdtOlvoXkpeXvweCdjU1uUAjMvb+GuRMApYgvKNKdYKe N68iNzA8IaA5mtK24/bk8Lo9OlV8kq+5AiPRqZ17uqZjUOIKdXi6m/+IKXa17vNEa5mE wkAw== 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=aQVEyjg21xyCKcI9eA0TA4v2uH3xp5YGNvgyMmaKoW8=; b=eurH2RlhZFvXAh4BEenpEd2PZe7xz2n1uqHybkUt2ngEf6YQ6jghfAIrNUlo+kK7QT g6VXtYaLk+OiaWEe0omtIQG43dRVQ6MuiAWPIsBBPfhKZQ3fCjpeI5qD26YBoaR/btTR rP3k7dReRisnKLvc5CuBNPnWsZR+9/uT3OWzvjL9mIlVYq4VOvyHni7Hrgqsuu3VwmZh 3fJpaEsKauIhYSw25KwiLfGeVC9FH6Mo+Q6c28v3cRfTOtLGtF84pXcEU8NRrEH/wJEi cVzO2GPNhiuQvKVK3v9ABJdnKebe0lx8BGAFQzii5bPXd0ELxUjH33y3sbwrWqwuut7G NwLQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=kqhRjSTr; 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=fail (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 bx23si7051867ejb.257.2020.11.09.05.38.04; Mon, 09 Nov 2020 05:38:27 -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=kqhRjSTr; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733221AbgKINgu (ORCPT + 99 others); Mon, 9 Nov 2020 08:36:50 -0500 Received: from mail.kernel.org ([198.145.29.99]:57602 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730478AbgKINEn (ORCPT ); Mon, 9 Nov 2020 08:04:43 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 561CE221F1; Mon, 9 Nov 2020 13:04:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604927078; bh=ou48oTC5DtY++5q6fw2mIlvdI6jtnTRTnw7hAOhFVEE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=kqhRjSTrvi1/Z3JGz6ZzkBeh+uTzueTlNm0D4wP5juk1V/9YNkFyW7L2LB0Y63CYC yyLm+mqbH/jdqWPGHuK3k3IriMv0Kp48/vXHI2ceRjedJVEz+pIEPdfwB5JwfwYfQ9 KmcoZ57qjOoaKIpL2m8YnsYh5h7Aew0qJnOJOkgI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Kairui Song , Ingo Molnar , Sasha Levin Subject: [PATCH 4.9 103/117] x86/kexec: Use up-to-dated screen_info copy to fill boot params Date: Mon, 9 Nov 2020 13:55:29 +0100 Message-Id: <20201109125030.583805133@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201109125025.630721781@linuxfoundation.org> References: <20201109125025.630721781@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: 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 167ecc270ca55..316c05b8b728b 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