Received: by 2002:a05:7412:d8a:b0:e2:908c:2ebd with SMTP id b10csp2511408rdg; Mon, 16 Oct 2023 06:50:04 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGWxeQ4LSfApKOJRCmFy+4QbTjoAOFvYlTD0+d0Wd702K5+WLWlFJ4u0GNvwjG/1SKb4fhd X-Received: by 2002:a17:902:8f97:b0:1c7:4973:7b34 with SMTP id z23-20020a1709028f9700b001c749737b34mr27552793plo.50.1697464203686; Mon, 16 Oct 2023 06:50:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1697464203; cv=none; d=google.com; s=arc-20160816; b=rC/NjZvQgDBNWYT/Kzw7EnWgtT8xQ1zSzAty+tfB9Oty1XpMrSfctJcAAMq7CT7OYv kd42PYIyJl3iESfZK0mzrYffjzYNmPDyrEghDkL+nDoiNifzIY5FNfnUH0WnqHgguZaL MtI9OapFm51oeqyOjisLezDBYoSx98wdrfx4zyiaOkbmJJKS4OzCOlDZxBSYgNNPLtxT c7n508UYcYW1NSYSpf0h8j7T1xyHgVtmPaw6/u66O8yDmIawvfDUmC1caYOs2qMV58Hh oF/KTtvkGdOC6fev8Rve2qpd4UL8HMJEfMYTwsjfnZMUUeWgjNd4uRRfgeDtkA6zfEAT h02g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:robot-unsubscribe :robot-id:message-id:mime-version:references:in-reply-to:cc:subject :to:reply-to:sender:from:dkim-signature:dkim-signature:date; bh=szJCQ1qcus8xfbAR7kQCZre3aSLpl0Tn4hJkHD45Xek=; fh=ALpRGrJz8Oou4nattQwAaYNgP/tSnRRlp+SP6w6+CyQ=; b=Aycoqb0DS3VKugiWRLuADmRc+to02um4yRFi4JDDbl85NOJ+o9VSJScApFmvoQgbkW LiadvY1A8uvbMCTBhF1KLpKT2sY+fZpCRddmRFFoUAEh1FJ6be99a+pOYYmG5tjznlu/ sc1r+tFH9f7xIWjigAUeUDMFiFrBL1rAH4v1n+6y/R6yZ1qwaK3rwrbawqW/6Yulfu68 KEQc5WDZqRBLCKi5tI2zTUP0qw079mUjeZkn74S5IDDFISsXvfquf6im8UN6qeetj53a eg8mdB46n5TC3Ngl7D8va2xmouS0glVPpnTvB4B7D/H4VFVHHmmr2GfR4Z5c/URShi9T qEzg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=vnQiGgu2; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=NqV4+y7B; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [23.128.96.33]) by mx.google.com with ESMTPS id l15-20020a170902f68f00b001c62161b18esi11458611plg.580.2023.10.16.06.50.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 16 Oct 2023 06:50:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) client-ip=23.128.96.33; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=vnQiGgu2; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=NqV4+y7B; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 4819E8047D6F; Mon, 16 Oct 2023 06:50:01 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233501AbjJPNty (ORCPT + 99 others); Mon, 16 Oct 2023 09:49:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53648 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234084AbjJPNsk (ORCPT ); Mon, 16 Oct 2023 09:48:40 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [193.142.43.55]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6ABC5E8; Mon, 16 Oct 2023 06:48:14 -0700 (PDT) Date: Mon, 16 Oct 2023 13:48:12 -0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1697464093; 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=szJCQ1qcus8xfbAR7kQCZre3aSLpl0Tn4hJkHD45Xek=; b=vnQiGgu2GWXy/G9m9W0I9lZyiqVMvwVl2fnH9FtXamtA8ZVmfdHIZ1kOjP7PEIP8j0bJr2 /DKYWMQ5TKOxdVMdFtZ3AImd3mL5JY6TU+IMTHMD2waB+slNSPIyTsJtVsEHG9Qknc+YUo lPijJAHVoZgt2jOEiIUhcm1lg2A3aESM68pPp4fFSx4OVRaoF7ZvwtjITiWiHOVrmdpn9B /1ZJpbuFKx+maZAA6LUTRPNAv8O6sgZkUn8rc7itPYXlkgddbC7Ewac96f1QrU4OXQ5vLd pKETAxsQPMS4fgSO5pv+iMsF0E7+2tUGC6OBMzniyFF4OG2YHrn1LU2wOCaiSA== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1697464093; 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=szJCQ1qcus8xfbAR7kQCZre3aSLpl0Tn4hJkHD45Xek=; b=NqV4+y7B7c+jjFfCkRXdvCq9m8tCoatlEjsK3eiHyhSOAVSCT+rkpnYwDp9/WTO2uRTxMk Ti9I8AvAy5XgmGCA== From: "tip-bot2 for Yazen Ghannam" Sender: tip-bot2@linutronix.de Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: ras/core] x86/mce: Cleanup mce_usable_address() Cc: Yazen Ghannam , "Borislav Petkov (AMD)" , x86@kernel.org, linux-kernel@vger.kernel.org In-Reply-To: <20230613141142.36801-4-yazen.ghannam@amd.com> References: <20230613141142.36801-4-yazen.ghannam@amd.com> MIME-Version: 1.0 Message-ID: <169746409209.3135.13727023873339327084.tip-bot2@tip-bot2> Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.8 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.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 (lipwig.vger.email [0.0.0.0]); Mon, 16 Oct 2023 06:50:01 -0700 (PDT) The following commit has been merged into the ras/core branch of tip: Commit-ID: 1bae0cfe4a171ccc5f731426296e45beafa096b8 Gitweb: https://git.kernel.org/tip/1bae0cfe4a171ccc5f731426296e45beafa096b8 Author: Yazen Ghannam AuthorDate: Tue, 13 Jun 2023 09:11:42 -05:00 Committer: Borislav Petkov (AMD) CommitterDate: Mon, 16 Oct 2023 15:37:01 +02:00 x86/mce: Cleanup mce_usable_address() Move Intel-specific checks into a helper function. Explicitly use "bool" for return type. No functional change intended. Signed-off-by: Yazen Ghannam Signed-off-by: Borislav Petkov (AMD) Link: https://lore.kernel.org/r/20230613141142.36801-4-yazen.ghannam@amd.com --- arch/x86/include/asm/mce.h | 2 +- arch/x86/kernel/cpu/mce/core.c | 33 ++++++++--------------------- arch/x86/kernel/cpu/mce/intel.c | 20 ++++++++++++++++++- arch/x86/kernel/cpu/mce/internal.h | 2 ++- 4 files changed, 33 insertions(+), 24 deletions(-) diff --git a/arch/x86/include/asm/mce.h b/arch/x86/include/asm/mce.h index 180b1cb..6de6e1d 100644 --- a/arch/x86/include/asm/mce.h +++ b/arch/x86/include/asm/mce.h @@ -245,7 +245,7 @@ static inline void cmci_recheck(void) {} int mce_available(struct cpuinfo_x86 *c); bool mce_is_memory_error(struct mce *m); bool mce_is_correctable(struct mce *m); -int mce_usable_address(struct mce *m); +bool mce_usable_address(struct mce *m); DECLARE_PER_CPU(unsigned, mce_exception_count); DECLARE_PER_CPU(unsigned, mce_poll_count); diff --git a/arch/x86/kernel/cpu/mce/core.c b/arch/x86/kernel/cpu/mce/core.c index 06c21f5..0214d42 100644 --- a/arch/x86/kernel/cpu/mce/core.c +++ b/arch/x86/kernel/cpu/mce/core.c @@ -453,35 +453,22 @@ static void mce_irq_work_cb(struct irq_work *entry) mce_schedule_work(); } -/* - * Check if the address reported by the CPU is in a format we can parse. - * It would be possible to add code for most other cases, but all would - * be somewhat complicated (e.g. segment offset would require an instruction - * parser). So only support physical addresses up to page granularity for now. - */ -int mce_usable_address(struct mce *m) +bool mce_usable_address(struct mce *m) { if (!(m->status & MCI_STATUS_ADDRV)) - return 0; + return false; - if (m->cpuvendor == X86_VENDOR_AMD) + switch (m->cpuvendor) { + case X86_VENDOR_AMD: return amd_mce_usable_address(m); - /* Checks after this one are Intel/Zhaoxin-specific: */ - if (boot_cpu_data.x86_vendor != X86_VENDOR_INTEL && - boot_cpu_data.x86_vendor != X86_VENDOR_ZHAOXIN) - return 1; - - if (!(m->status & MCI_STATUS_MISCV)) - return 0; - - if (MCI_MISC_ADDR_LSB(m->misc) > PAGE_SHIFT) - return 0; - - if (MCI_MISC_ADDR_MODE(m->misc) != MCI_MISC_ADDR_PHYS) - return 0; + case X86_VENDOR_INTEL: + case X86_VENDOR_ZHAOXIN: + return intel_mce_usable_address(m); - return 1; + default: + return true; + } } EXPORT_SYMBOL_GPL(mce_usable_address); diff --git a/arch/x86/kernel/cpu/mce/intel.c b/arch/x86/kernel/cpu/mce/intel.c index f532355..52bce53 100644 --- a/arch/x86/kernel/cpu/mce/intel.c +++ b/arch/x86/kernel/cpu/mce/intel.c @@ -536,3 +536,23 @@ bool intel_filter_mce(struct mce *m) return false; } + +/* + * Check if the address reported by the CPU is in a format we can parse. + * It would be possible to add code for most other cases, but all would + * be somewhat complicated (e.g. segment offset would require an instruction + * parser). So only support physical addresses up to page granularity for now. + */ +bool intel_mce_usable_address(struct mce *m) +{ + if (!(m->status & MCI_STATUS_MISCV)) + return false; + + if (MCI_MISC_ADDR_LSB(m->misc) > PAGE_SHIFT) + return false; + + if (MCI_MISC_ADDR_MODE(m->misc) != MCI_MISC_ADDR_PHYS) + return false; + + return true; +} diff --git a/arch/x86/kernel/cpu/mce/internal.h b/arch/x86/kernel/cpu/mce/internal.h index a191554..e13a26c 100644 --- a/arch/x86/kernel/cpu/mce/internal.h +++ b/arch/x86/kernel/cpu/mce/internal.h @@ -49,6 +49,7 @@ void intel_init_cmci(void); void intel_init_lmce(void); void intel_clear_lmce(void); bool intel_filter_mce(struct mce *m); +bool intel_mce_usable_address(struct mce *m); #else # define cmci_intel_adjust_timer mce_adjust_timer_default static inline bool mce_intel_cmci_poll(void) { return false; } @@ -58,6 +59,7 @@ static inline void intel_init_cmci(void) { } static inline void intel_init_lmce(void) { } static inline void intel_clear_lmce(void) { } static inline bool intel_filter_mce(struct mce *m) { return false; } +static inline bool intel_mce_usable_address(struct mce *m) { return false; } #endif void mce_timer_kick(unsigned long interval);