Received: by 2002:a05:7412:d1aa:b0:fc:a2b0:25d7 with SMTP id ba42csp1921015rdb; Wed, 31 Jan 2024 13:18:18 -0800 (PST) X-Google-Smtp-Source: AGHT+IFUTjgHAbYEggKrTBoP1V9O7SM88CCpNdnEgUKsRYgSn+ysp3b+L1M6hukw+Ydut7nowuD7 X-Received: by 2002:a17:906:ca97:b0:a35:3fac:7b6c with SMTP id js23-20020a170906ca9700b00a353fac7b6cmr331132ejb.3.1706735898095; Wed, 31 Jan 2024 13:18:18 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1706735898; cv=pass; d=google.com; s=arc-20160816; b=wIYGYheCIVjg6sd0j+vruvVofvN+H4U8lgQISRUDKxW/ysOF1hXa/ExXAkDmYinQSN pCqR1+x3X/jy3hbwGCFyh2U58i62/Vevwc6is2iNtpd2nNKKSV69/xBMKeF7XwUjVmEJ JNKc0uaGNzY9thGzlJrTO06XlX4iVR8DINEIWhACMTcK/Fw74HLpiCPkWlRRBK3u8ieY i13g9NSdP6SNWjIcwsdimAGTfV6Q4NWzg+B5vHCK/TX1KIL1eq13xkwrPwOq4hzYwfod 7fcSOus2haxUkbgdjN9wUkFkGqXKJ4BOnCcKtvK8WsXprKFTJ9jg0aIcIatiBWTv68WD dDiA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:precedence:robot-unsubscribe:robot-id :message-id:mime-version:list-unsubscribe:list-subscribe:list-id :precedence:references:in-reply-to:cc:subject:to:reply-to:sender :from:dkim-signature:dkim-signature:date; bh=qB1GFWsHKuSTUsV5DHwObFwR+52c5Y/OuUx5Al7VURY=; fh=sgJJ7OXg08Adf8ajgto1JpJcOST9KEd6zrf/S/uYXXQ=; b=DbD8zsmfrqq5kLcIvrtKchOqfguLYsBhwjeWjTGIC8kPzYLvh/2FWLSXh0X5rvonzI XCrOWc/J/3n6m9BL2b/xfpB35tLkZXA9AqQ0JmWXt5xoVxYNZBoKbJmb/ynJxyRIhuwJ fo/Lt1CcbxVv5lfKyeQsxe/DcvKNsI3h/wT7aRU2U2N8tWxgihtY7tpzT4dW3ZJph9UK rWXOHxDDhWwSdOAA90HiS8n1th4tifpUXfJBY6CZuWSdbhem/YSVzJzmQFFvCxumIn9U gzOpapYv81Oaz8sxlG1v2paVO46ZU19WV6o+z2JailTd1hfRKecJHV5Wyiq909t8GgiL b9ig==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=tirqsuFv; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e; arc=pass (i=1 spf=pass spfdomain=linutronix.de dkim=pass dkdomain=linutronix.de dmarc=pass fromdomain=linutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-47131-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-47131-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de X-Forwarded-Encrypted: i=1; AJvYcCUukxxJbfxxYuzCm8uUAZojlgpzb1lhXQC8UzeVOuejBm23YCuAcwpE8FzSR1H+KYOCYLcnY9qkslJXn9xhfz0FaApowL4JVTjfu664ng== Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id u16-20020a170906069000b00a2c4b49bef1si6072115ejb.374.2024.01.31.13.18.18 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 31 Jan 2024 13:18:18 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-47131-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=tirqsuFv; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e; arc=pass (i=1 spf=pass spfdomain=linutronix.de dkim=pass dkdomain=linutronix.de dmarc=pass fromdomain=linutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-47131-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-47131-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id EF83D1F278F3 for ; Wed, 31 Jan 2024 21:17:54 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id DED123BB41; Wed, 31 Jan 2024 21:14:52 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linutronix.de header.i=@linutronix.de header.b="tirqsuFv"; dkim=permerror (0-bit key) header.d=linutronix.de header.i=@linutronix.de header.b="6HF5g5B1" Received: from galois.linutronix.de (Galois.linutronix.de [193.142.43.55]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 0769D39ACB; Wed, 31 Jan 2024 21:14:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=193.142.43.55 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706735692; cv=none; b=QrZN5caVWsw1uDfAnoeHPgO9Ag3mVREfJITLbeqTfMzW7y3VhGJy0GNMwuLUcx44Z5g2BhkuhAZB8Wdt9yQ762WHP3sMOHkODpbx739zwo6077eOeue2U1qd3WT0emMpXf4VGblH6UI6wpXrmPGg0ox+BQNN8Wp6zEAXSMxbH/s= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706735692; c=relaxed/simple; bh=FNNQ4v5en5QQA9wJHLquxcQTcybBQRxDpzmgCR8zsds=; h=Date:From:To:Subject:Cc:In-Reply-To:References:MIME-Version: Message-ID:Content-Type; b=bn+h2sEa/PaOnmnDICnEHChYBho7p/3/tdAiaULZs9P05YPDvNeqitMDLvZEJBg8JqVdxYpt49sCCLUvgYHFevgNo8k+DMCmDSr1sg4LBVeVywun5JgdlI4rCHMzJQ1DT/CHGMntE4/NRouEeeddQ8TKlRnJUlyr1Evvod6wkUE= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linutronix.de; spf=pass smtp.mailfrom=linutronix.de; dkim=pass (2048-bit key) header.d=linutronix.de header.i=@linutronix.de header.b=tirqsuFv; dkim=permerror (0-bit key) header.d=linutronix.de header.i=@linutronix.de header.b=6HF5g5B1; arc=none smtp.client-ip=193.142.43.55 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linutronix.de Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linutronix.de Date: Wed, 31 Jan 2024 21:14:47 -0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1706735688; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=qB1GFWsHKuSTUsV5DHwObFwR+52c5Y/OuUx5Al7VURY=; b=tirqsuFvwer57NHQkI6+6NWo/P17qIfrLInUfAPfHISFzmQUc3oo6HkZ9mtYDuFjDRPExh FFm7a1ViA4sz4QD0P+YLk61PfVK1js5gxQjc2H+qC9dvw+vlVwNymtkz5312IXpxT6gOg4 nu6MrIAtouyp/PkVQdLFYNHqSWwMwxhm3a0x4+EoRPujleAqt/IVeajWLc+nDmWawNfMZV f9kZYlX/k1K62QHo5Wk3bKYZ3RpkI2kz2haSkqWGuxKbNDCScycmpwBfFKDwvvcZRiwTHD ugpJ+vWXiFGbt1WtKPZ87Vni5ZwoQY0g6EZqw4v1ga290dWuOcxKz49OIueC2Q== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1706735688; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=qB1GFWsHKuSTUsV5DHwObFwR+52c5Y/OuUx5Al7VURY=; b=6HF5g5B1GXM2UMgKhjDKBXqrPiaOQynPDDFoiyr56joStvQZ9oSxvOIi03eTAZAuqgDb5w Q1/PDUZ0rAHO7LAA== From: "tip-bot2 for H. Peter Anvin (Intel)" Sender: tip-bot2@linutronix.de Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: x86/fred] x86/fred: Make exc_page_fault() work for FRED Cc: "H. Peter Anvin (Intel)" , Xin Li , Thomas Gleixner , "Borislav Petkov (AMD)" , Shan Kang , x86@kernel.org, linux-kernel@vger.kernel.org In-Reply-To: <20231205105030.8698-22-xin3.li@intel.com> References: <20231205105030.8698-22-xin3.li@intel.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Message-ID: <170673568749.398.7045347279493145706.tip-bot2@tip-bot2> Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Precedence: bulk Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit The following commit has been merged into the x86/fred branch of tip: Commit-ID: 58c80cc55e079933205597ecf846583c5e6e4946 Gitweb: https://git.kernel.org/tip/58c80cc55e079933205597ecf846583c5e6e4946 Author: H. Peter Anvin (Intel) AuthorDate: Tue, 05 Dec 2023 02:50:10 -08:00 Committer: Borislav Petkov (AMD) CommitterDate: Wed, 31 Jan 2024 22:02:05 +01:00 x86/fred: Make exc_page_fault() work for FRED On a FRED system, the faulting address (CR2) is passed on the stack, to avoid the problem of transient state. Thus the page fault address is read from the FRED stack frame instead of CR2 when FRED is enabled. Signed-off-by: H. Peter Anvin (Intel) Signed-off-by: Xin Li Signed-off-by: Thomas Gleixner Signed-off-by: Borislav Petkov (AMD) Tested-by: Shan Kang Link: https://lore.kernel.org/r/20231205105030.8698-22-xin3.li@intel.com --- arch/x86/mm/fault.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/arch/x86/mm/fault.c b/arch/x86/mm/fault.c index 679b09c..fa2d699 100644 --- a/arch/x86/mm/fault.c +++ b/arch/x86/mm/fault.c @@ -34,6 +34,7 @@ #include /* kvm_handle_async_pf */ #include /* fixup_vdso_exception() */ #include +#include #define CREATE_TRACE_POINTS #include @@ -1518,8 +1519,10 @@ handle_page_fault(struct pt_regs *regs, unsigned long error_code, DEFINE_IDTENTRY_RAW_ERRORCODE(exc_page_fault) { - unsigned long address = read_cr2(); irqentry_state_t state; + unsigned long address; + + address = cpu_feature_enabled(X86_FEATURE_FRED) ? fred_event_data(regs) : read_cr2(); prefetchw(¤t->mm->mmap_lock);