Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp5633441imm; Sat, 19 May 2018 06:22:40 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrWYVFzP5MI1RJ9Hf2vlp5HnAarNh8R1Uque7WGtRtXaKhu7fWy5IXzT44boAsAkHwv1DXw X-Received: by 2002:a17:902:2924:: with SMTP id g33-v6mr13689235plb.26.1526736160133; Sat, 19 May 2018 06:22:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526736160; cv=none; d=google.com; s=arc-20160816; b=zE3ceIc25QG5LyuzIbGNbpeZOtT/nxH91v9aQA6l9s9Rea1nb3DC/78gonRp5hkKnx cpmbP5MRFHYtALro9aVZqBrvrvGpRIlMuo48u/i87TTWYdYVGjvBqAipm8dPOeRH9xnS HGndT1Nihh+5tm7cNUxHgkA1exFpJqhjmfxMnsAQT7qNHrsaVCnd9Py0gScTzCDt9rLN ol12vEHZP4pgm6r4x8gUqGjBWzmBxbe/b3CC54os3twvIusG+W4P2gLfF05u3R+x5hW0 Z+J9iRfE8ixJI6AR6nESnaGm+zOSVoZYk77tjl0P/3dOo8P2GDuq687CwTozIDVADeQO wJJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-disposition :content-transfer-encoding:mime-version:robot-unsubscribe:robot-id :git-commit-id:subject:to:references:in-reply-to:reply-to:cc :message-id:from:date:arc-authentication-results; bh=3mhsNaPNNtzbqw+bY7lXVB8ZLcFg4idPfd2HnAiWmCQ=; b=WhLBywuj0P7IiuNzjjA+gf//N3aIJYk8i89tdsQ+WF+8+vSSVbItHvs7FmTtJiQVqZ v4UwRLU8LIKZuASa7RupiTBv9spljq8fGiCn9LDcZ6FajkHwo/z7Rm1UP5tvNPgfPuvt VXTJOmkU1V7esV7mFmETGSHb142xAnl83XijpM8mwSffUMxmJybXjr3Ytc5FUb6g2KeA nqY6AQYKYSEY4dmGgcvegV490jlhj3qfrtJVDEYxtZWo3vRl/DJcxG4P1GPhRzpoXWVd eguae5n1l4gboT5bN2M+G3dNWEfzB0pMgn3EjbmDCCgqHgnaM5stj3ASGqw/JODE70Qd hwRg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id z19-v6si9452133plo.174.2018.05.19.06.22.25; Sat, 19 May 2018 06:22:40 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752317AbeESNWL (ORCPT + 99 others); Sat, 19 May 2018 09:22:11 -0400 Received: from terminus.zytor.com ([198.137.202.136]:43585 "EHLO terminus.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752201AbeESNWH (ORCPT ); Sat, 19 May 2018 09:22:07 -0400 Received: from terminus.zytor.com (localhost [127.0.0.1]) by terminus.zytor.com (8.15.2/8.15.2) with ESMTPS id w4JDLlX52825692 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Sat, 19 May 2018 06:21:47 -0700 Received: (from tipbot@localhost) by terminus.zytor.com (8.15.2/8.15.2/Submit) id w4JDLl662825689; Sat, 19 May 2018 06:21:47 -0700 Date: Sat, 19 May 2018 06:21:47 -0700 X-Authentication-Warning: terminus.zytor.com: tipbot set sender to tipbot@zytor.com using -f From: tip-bot for Borislav Petkov Message-ID: Cc: mingo@kernel.org, hpa@zytor.com, linux-kernel@vger.kernel.org, yazen.ghannam@amd.com, bp@suse.de, johannes.hirte@datenkhaos.de, tglx@linutronix.de Reply-To: yazen.ghannam@amd.com, bp@suse.de, johannes.hirte@datenkhaos.de, tglx@linutronix.de, mingo@kernel.org, hpa@zytor.com, linux-kernel@vger.kernel.org In-Reply-To: <20180414004230.GA2033@probook> References: <20180414004230.GA2033@probook> To: linux-tip-commits@vger.kernel.org Subject: [tip:ras/urgent] x86/MCE/AMD: Cache SMCA MISC block addresses Git-Commit-ID: 78ce241099bb363b19dbd0245442e66c8de8f567 X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain; charset=UTF-8 Content-Disposition: inline X-Spam-Status: No, score=-2.9 required=5.0 tests=ALL_TRUSTED,BAYES_00, T_DATE_IN_FUTURE_96_Q autolearn=ham autolearn_force=no version=3.4.1 X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on terminus.zytor.com Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit-ID: 78ce241099bb363b19dbd0245442e66c8de8f567 Gitweb: https://git.kernel.org/tip/78ce241099bb363b19dbd0245442e66c8de8f567 Author: Borislav Petkov AuthorDate: Thu, 17 May 2018 10:46:26 +0200 Committer: Thomas Gleixner CommitDate: Sat, 19 May 2018 15:19:30 +0200 x86/MCE/AMD: Cache SMCA MISC block addresses ... into a global, two-dimensional array and service subsequent reads from that cache to avoid rdmsr_on_cpu() calls during CPU hotplug (IPIs with IRQs disabled). In addition, this fixes a KASAN slab-out-of-bounds read due to wrong usage of the bank->blocks pointer. Fixes: 27bd59502702 ("x86/mce/AMD: Get address from already initialized block") Reported-by: Johannes Hirte Tested-by: Johannes Hirte Signed-off-by: Borislav Petkov Signed-off-by: Thomas Gleixner Cc: Yazen Ghannam Link: http://lkml.kernel.org/r/20180414004230.GA2033@probook --- arch/x86/kernel/cpu/mcheck/mce_amd.c | 29 ++++++++++++++--------------- 1 file changed, 14 insertions(+), 15 deletions(-) diff --git a/arch/x86/kernel/cpu/mcheck/mce_amd.c b/arch/x86/kernel/cpu/mcheck/mce_amd.c index f7666eef4a87..c8e038800591 100644 --- a/arch/x86/kernel/cpu/mcheck/mce_amd.c +++ b/arch/x86/kernel/cpu/mcheck/mce_amd.c @@ -94,6 +94,11 @@ static struct smca_bank_name smca_names[] = { [SMCA_SMU] = { "smu", "System Management Unit" }, }; +static u32 smca_bank_addrs[MAX_NR_BANKS][NR_BLOCKS] __ro_after_init = +{ + [0 ... MAX_NR_BANKS - 1] = { [0 ... NR_BLOCKS - 1] = -1 } +}; + const char *smca_get_name(enum smca_bank_types t) { if (t >= N_SMCA_BANK_TYPES) @@ -443,20 +448,26 @@ static u32 smca_get_block_address(unsigned int cpu, unsigned int bank, if (!block) return MSR_AMD64_SMCA_MCx_MISC(bank); + /* Check our cache first: */ + if (smca_bank_addrs[bank][block] != -1) + return smca_bank_addrs[bank][block]; + /* * For SMCA enabled processors, BLKPTR field of the first MISC register * (MCx_MISC0) indicates presence of additional MISC regs set (MISC1-4). */ if (rdmsr_safe_on_cpu(cpu, MSR_AMD64_SMCA_MCx_CONFIG(bank), &low, &high)) - return addr; + goto out; if (!(low & MCI_CONFIG_MCAX)) - return addr; + goto out; if (!rdmsr_safe_on_cpu(cpu, MSR_AMD64_SMCA_MCx_MISC(bank), &low, &high) && (low & MASK_BLKPTR_LO)) - return MSR_AMD64_SMCA_MCx_MISCy(bank, block - 1); + addr = MSR_AMD64_SMCA_MCx_MISCy(bank, block - 1); +out: + smca_bank_addrs[bank][block] = addr; return addr; } @@ -468,18 +479,6 @@ static u32 get_block_address(unsigned int cpu, u32 current_addr, u32 low, u32 hi if ((bank >= mca_cfg.banks) || (block >= NR_BLOCKS)) return addr; - /* Get address from already initialized block. */ - if (per_cpu(threshold_banks, cpu)) { - struct threshold_bank *bankp = per_cpu(threshold_banks, cpu)[bank]; - - if (bankp && bankp->blocks) { - struct threshold_block *blockp = &bankp->blocks[block]; - - if (blockp) - return blockp->address; - } - } - if (mce_flags.smca) return smca_get_block_address(cpu, bank, block);