]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/blame - releases/4.19.53/x86-resctrl-prevent-null-pointer-dereference-when-local-mbm-is-disabled.patch
4.9-stable patches
[thirdparty/kernel/stable-queue.git] / releases / 4.19.53 / x86-resctrl-prevent-null-pointer-dereference-when-local-mbm-is-disabled.patch
CommitLineData
6a18e85b
GKH
1From c7563e62a6d720aa3b068e26ddffab5f0df29263 Mon Sep 17 00:00:00 2001
2From: Prarit Bhargava <prarit@redhat.com>
3Date: Mon, 10 Jun 2019 13:15:44 -0400
4Subject: x86/resctrl: Prevent NULL pointer dereference when local MBM is disabled
5
6From: Prarit Bhargava <prarit@redhat.com>
7
8commit c7563e62a6d720aa3b068e26ddffab5f0df29263 upstream.
9
10Booting with kernel parameter "rdt=cmt,mbmtotal,memlocal,l3cat,mba" and
11executing "mount -t resctrl resctrl -o mba_MBps /sys/fs/resctrl" results in
12a NULL pointer dereference on systems which do not have local MBM support
13enabled..
14
15BUG: kernel NULL pointer dereference, address: 0000000000000020
16PGD 0 P4D 0
17Oops: 0000 [#1] SMP PTI
18CPU: 0 PID: 722 Comm: kworker/0:3 Not tainted 5.2.0-0.rc3.git0.1.el7_UNSUPPORTED.x86_64 #2
19Workqueue: events mbm_handle_overflow
20RIP: 0010:mbm_handle_overflow+0x150/0x2b0
21
22Only enter the bandwith update loop if the system has local MBM enabled.
23
24Fixes: de73f38f7680 ("x86/intel_rdt/mba_sc: Feedback loop to dynamically update mem bandwidth")
25Signed-off-by: Prarit Bhargava <prarit@redhat.com>
26Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
27Cc: Fenghua Yu <fenghua.yu@intel.com>
28Cc: Reinette Chatre <reinette.chatre@intel.com>
29Cc: Borislav Petkov <bp@alien8.de>
30Cc: "H. Peter Anvin" <hpa@zytor.com>
31Cc: stable@vger.kernel.org
32Link: https://lkml.kernel.org/r/20190610171544.13474-1-prarit@redhat.com
33Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
34
35---
36 arch/x86/kernel/cpu/intel_rdt_monitor.c | 3 +++
37 1 file changed, 3 insertions(+)
38
39--- a/arch/x86/kernel/cpu/intel_rdt_monitor.c
40+++ b/arch/x86/kernel/cpu/intel_rdt_monitor.c
41@@ -371,6 +371,9 @@ static void update_mba_bw(struct rdtgrou
42 struct list_head *head;
43 struct rdtgroup *entry;
44
45+ if (!is_mbm_local_enabled())
46+ return;
47+
48 r_mba = &rdt_resources_all[RDT_RESOURCE_MBA];
49 closid = rgrp->closid;
50 rmid = rgrp->mon.rmid;