Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp1371743rdb; Wed, 6 Dec 2023 17:46:08 -0800 (PST) X-Google-Smtp-Source: AGHT+IG26vfOkVRJsLNhyEkbMnYF930EPJWb7TnXLlH9od80JpKRyVlm1hPShcwgHYHHue9L8kdE X-Received: by 2002:a05:6808:f08:b0:3b8:4cfe:82c0 with SMTP id m8-20020a0568080f0800b003b84cfe82c0mr2212924oiw.29.1701913568072; Wed, 06 Dec 2023 17:46:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701913568; cv=none; d=google.com; s=arc-20160816; b=P49bOVHJDTD+507cwsRkq2EGUhD/kVuIJJDDJbE7z4605WCPgUAEh+4EHl50TS5LH3 FacUi3S+vtW/bxTxH0Qn5NXY/Ow9O+f/vVkbFQWRf8FzjW/6vZQ/ze/eVhdSurpulodb PE8s6mvdpHfOyV22napX2ieQ6PV9fzN0Qe5AvhkopiiUq6ZttJO4xuttI6y50t8Y/tYK vargVVRpNFrsRfZGv9xCuSygbbSoCGgNLX+Oc9tQUzcydE7zAHaPeTRPMYGeH0WwJBbk CnCnEQaMliBrsR7rbeL5/kM83Da5c2PhebBBU6GiW34d6646MVb62TqC/V6qYzTStguG 4xIQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from :dkim-signature; bh=kg35LyEh3Itvi6CS+SRJwRzEt6b6M94+hL1AnQum0pE=; fh=QhQ6V1L50hc8fFDGNqUHQkKALRF27SHI+BHUfCmjBxQ=; b=Tb88vEsL4zsL/7gVmCwMU19+LTu2IpuOJwgeL6F3q6XgNTtMTkiTzJlINbsXrORhAk a5ZV2X+XRVVGprnh19zOK0ndCpZB02qpy4QKTYqlINTeGoxP18AoPNFduggT5UN3xpOi 93cufokEPUZ1DcoyP8A0SqJhOKgocjx1qI6oTcxEoag597kjhMEG+BgnsjWNH4h7ZPwu Ivs8sIHggTrICN3oX6co4ME9n6/JUZrra+oYcSVlz3S6YMn087Xx9NIG5p7iablVAfzJ bPXD+zbRspn1M9CG6qQzjnt4c1qhPK7aCNm3a9HuUQZXpOM4amG1/5jmpbLJ4MiBgcMX fPgw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=DCv1hmmT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from groat.vger.email (groat.vger.email. [23.128.96.35]) by mx.google.com with ESMTPS id j9-20020aa78dc9000000b006cddc343ceesi289429pfr.181.2023.12.06.17.46.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 06 Dec 2023 17:46:08 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) client-ip=23.128.96.35; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=DCv1hmmT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.35 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by groat.vger.email (Postfix) with ESMTP id 81E8F8078C95; Wed, 6 Dec 2023 17:46:05 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1442977AbjLGBp2 (ORCPT + 99 others); Wed, 6 Dec 2023 20:45:28 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58862 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231182AbjLGBp1 (ORCPT ); Wed, 6 Dec 2023 20:45:27 -0500 Received: from mgamail.intel.com (mgamail.intel.com [192.55.52.151]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 755E819E; Wed, 6 Dec 2023 17:45:33 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1701913533; x=1733449533; h=from:to:cc:subject:date:message-id; bh=KiFqkDFxamxUcRrbdcfuGE7EYU7NwqcueANUY2UM/s4=; b=DCv1hmmT5u7iHdRD3T4RZL8nio79GM35ANZ0jCvl4zsiwvVW178DMnt3 pS0GYldCX0/7PFkFaYfkqFz7ZGuGYWeI2WKDCgl6Bu7u/o6cOvutKdYeK bpuG0mmILCZms86zpjYszkZRji/XwGFB6LnJVEawEVBMnG4zVbDf+SL+G erY1+yNphe8UgjkpB1+wZFSCEPOt8LgJvKl+b2cjrz6QcHvFGFJbdZ7Rv 2Ih7k1u8y2O1iXNTqEO1vus6TZEtbIOBKpR5Cz6JK4FWfwiZ32HMI1lnY 8h5GiV4A4tBWkAOaVE9CBW/OLQVBkAuzmecuPsvDsxN6/HHwp2g+LBteE Q==; X-IronPort-AV: E=McAfee;i="6600,9927,10916"; a="374328473" X-IronPort-AV: E=Sophos;i="6.04,256,1695711600"; d="scan'208";a="374328473" Received: from orsmga001.jf.intel.com ([10.7.209.18]) by fmsmga107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 06 Dec 2023 17:45:33 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10916"; a="805839984" X-IronPort-AV: E=Sophos;i="6.04,256,1695711600"; d="scan'208";a="805839984" Received: from qiuxu-clx.sh.intel.com ([10.239.53.109]) by orsmga001-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 06 Dec 2023 17:45:30 -0800 From: Qiuxu Zhuo To: Tony Luck Cc: Qiuxu Zhuo , Borislav Petkov , Aristeu Rozanski , Mauro Carvalho Chehab , linux-edac@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 1/1] EDAC/skx_common: Filter out the invalid address Date: Thu, 7 Dec 2023 09:45:12 +0800 Message-Id: <20231207014512.78564-1-qiuxu.zhuo@intel.com> X-Mailer: git-send-email 2.17.1 X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on groat.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (groat.vger.email [0.0.0.0]); Wed, 06 Dec 2023 17:46:05 -0800 (PST) Decoding an invalid address with certain firmware decoders could cause a #PF (Page Fault) in the EFI runtime context, which could subsequently hang the system. To make {i10nm,skx}_edac more robust against such bogus firmware decoders, filter out invalid addresses before allowing the firmware decoder to process them. Suggested-by: Tony Luck Signed-off-by: Qiuxu Zhuo --- drivers/edac/skx_common.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/drivers/edac/skx_common.c b/drivers/edac/skx_common.c index ce3e0069e028..9c5b6f8bd8bd 100644 --- a/drivers/edac/skx_common.c +++ b/drivers/edac/skx_common.c @@ -648,6 +648,10 @@ int skx_mce_check_error(struct notifier_block *nb, unsigned long val, memset(&res, 0, sizeof(res)); res.mce = mce; res.addr = mce->addr & MCI_ADDR_PHYSADDR; + if (!pfn_to_online_page(res.addr >> PAGE_SHIFT)) { + pr_err("Invalid address 0x%llx in IA32_MC%d_ADDR\n", mce->addr, mce->bank); + return NOTIFY_DONE; + } /* Try driver decoder first */ if (!(driver_decode && driver_decode(&res))) { -- 2.17.1