Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp1231116imm; Fri, 14 Sep 2018 13:36:48 -0700 (PDT) X-Google-Smtp-Source: ANB0VdY4RGJ1ANn3BBHyCFYHDO26AVEv3VYMXNL+GwTowzudP/m1I77IJqvPZAYVoYZBlbbeP6T/ X-Received: by 2002:a17:902:4601:: with SMTP id o1-v6mr13960067pld.202.1536957408180; Fri, 14 Sep 2018 13:36:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536957408; cv=none; d=google.com; s=arc-20160816; b=Cyv5kvDBHd/4sv2kEM17Or/vcBsCn0A4YCuBI8ea63UimPPMRG+Pj4KjJT6xOo6/Jf wilLrFQbBoLxd8438iVR0X0fcbWxJqqiNkUQsjQT2TwoyyiRmdkqRFciAI3lMtr+hNhI uPAdTb2jAU3zLJWOGKcvxq5t4Y+d8XaDkXyBIxc5ru+mM2alO45wH6grvsNKYeS5WfD3 mDMleFp5sLJ/e0umvjPjzisl+j/laRkEq6cr5npIWIOGz+Ey9mZkAtSgD/wNamsWKStb kPapG8nRJ2s4q4tbs6rnyiPpFg5IrDrQ/t6/90mSln3P1561OjS/Nh2t3HHWPYrdYPUZ vTng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=fu2OxPDLUkbGkDKngmhmhs/ywwZoWBU5igxmQxyYgvU=; b=p2G3doN1u034zNYP5DJ3KOWXqRiA+94t3gAHHy6gQIfHSL6Yj1C7nj2SgfumUAdPJr gcd0ObcsxeIlY+qLPvBi6iMdw0MvjLsr0gyTNXqU2cehToEG+Cpp1Xt47chr2uCSWhw4 B1U4HBmNU3gUfBAKMuQkE5QERAKmWLOn7s//EGHzzAf2GGBRUNw4eay0JYN2J2W8SUnz zQHs3HdV19ehuWiFJmF6q15EJLTT2wESLih0+2Wb9FsiELk48wT/Exr0Rj7HdFVQUIgP eoB/RWhVUsCD+zksKL0afLMhqIptWvDKavu2uK/IGb1j09kCpQcph+TjA2Vk1w3jlQyA t2Ug== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f4-v6si7735403plt.346.2018.09.14.13.36.33; Fri, 14 Sep 2018 13:36:48 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728460AbeIOBvz (ORCPT + 99 others); Fri, 14 Sep 2018 21:51:55 -0400 Received: from mga05.intel.com ([192.55.52.43]:60388 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728362AbeIOBvx (ORCPT ); Fri, 14 Sep 2018 21:51:53 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga105.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 14 Sep 2018 13:35:47 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.53,374,1531810800"; d="scan'208";a="263593815" Received: from romley-ivt3.sc.intel.com ([172.25.110.60]) by fmsmga006.fm.intel.com with ESMTP; 14 Sep 2018 13:35:44 -0700 From: Fenghua Yu To: "Thomas Gleixner" , "Ingo Molnar" , "H Peter Anvin" , "Tony Luck" Cc: "Chatre, Reinette" , "Xiaochen Shen" , "Chen Yu" , "linux-kernel" , "x86" , "Fenghua Yu" Subject: [PATCH 5/9] x86/intel_rdt: Fix unchecked MSR access Date: Fri, 14 Sep 2018 13:32:05 -0700 Message-Id: <1536957129-70380-6-git-send-email-fenghua.yu@intel.com> X-Mailer: git-send-email 2.5.0 In-Reply-To: <1536957129-70380-1-git-send-email-fenghua.yu@intel.com> References: <1536957129-70380-1-git-send-email-fenghua.yu@intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Reinette Chatre When a new resource group is created, it is initialized with sane defaults that currently assume the resource being initialized is a CAT resource. This code path is also followed by a MBA resource that is not allocated the same as a CAT resource and as a result we encounter the following unchecked MSR access error: [ 6944.864724] unchecked MSR access error: WRMSR to 0xd51 (tried to write 0x0000 000000000064) at rIP: 0xffffffffae059994 (native_write_msr+0x4/0x20) [ 6944.877967] Call Trace: [ 6944.880472] mba_wrmsr+0x41/0x80 [ 6944.883762] update_domains+0x125/0x130 [ 6944.887667] rdtgroup_mkdir+0x270/0x500 [ 6944.891572] kernfs_iop_mkdir+0x5d/0x80 [ 6944.895475] vfs_mkdir+0x101/0x1b0 [ 6944.898934] do_mkdirat+0x7b/0xf0 [ 6944.902308] do_syscall_64+0x5b/0x180 [ 6944.906036] entry_SYSCALL_64_after_hwframe+0x44/0xa9 [ 6944.911171] RIP: 0033:0x7f5a452b5377 [ 6944.914803] Code: 00 b8 ff ff ff ff c3 0f 1f 40 00 48 8b 05 21 9b 2c 00 64 c7 00 5f 00 00 00 b8 ff ff ff ff c3 0f 1f 40 00 b8 53 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d f9 9a 2c 00 f7 d8 64 89 01 48 [ 6944.933942] RSP: 002b:00007ffe18172f78 EFLAGS: 00000246 ORIG_RAX: 00000000000 00053 [ 6944.941628] RAX: ffffffffffffffda RBX: 00007ffe18174cff RCX: 00007f5a452b5377 [ 6944.948929] RDX: 0000000000000001 RSI: 00000000000001ff RDI: 00007ffe18174cff [ 6944.956168] RBP: 00007ffe18174cff R08: 00000000000001ff R09: 000056126dad8d30 [ 6944.963407] R10: 0000000000000000 R11: 0000000000000246 R12: 00000000000001ff [ 6944.970651] R13: 00007ffe181730f0 R14: 0000000000000000 R15: 00007ffe18173140 Fix the above by ensuring the initial allocation is only attempted on a CAT resource. Fixes: 95f0b77ef ("x86/intel_rdt: Initialize new resource group with sane defaults") Signed-off-by: Reinette Chatre Signed-off-by: Fenghua Yu --- arch/x86/kernel/cpu/intel_rdt_rdtgroup.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/arch/x86/kernel/cpu/intel_rdt_rdtgroup.c b/arch/x86/kernel/cpu/intel_rdt_rdtgroup.c index ea91750ba27f..74821bc457c0 100644 --- a/arch/x86/kernel/cpu/intel_rdt_rdtgroup.c +++ b/arch/x86/kernel/cpu/intel_rdt_rdtgroup.c @@ -2349,6 +2349,12 @@ static int rdtgroup_init_alloc(struct rdtgroup *rdtgrp) u32 *ctrl; for_each_alloc_enabled_rdt_resource(r) { + /* + * Only initialize default allocations for CBM cache + * resources + */ + if (r->rid == RDT_RESOURCE_MBA) + continue; list_for_each_entry(d, &r->domains, list) { d->have_new_ctrl = false; d->new_ctrl = r->cache.shareable_bits; @@ -2386,6 +2392,12 @@ static int rdtgroup_init_alloc(struct rdtgroup *rdtgrp) } for_each_alloc_enabled_rdt_resource(r) { + /* + * Only initialize default allocations for CBM cache + * resources + */ + if (r->rid == RDT_RESOURCE_MBA) + continue; ret = update_domains(r, rdtgrp->closid); if (ret < 0) { rdt_last_cmd_puts("failed to initialize allocations\n"); -- 2.19.0