diff options
author | Mathias Krause <minipli@googlemail.com> | 2015-11-09 14:00:27 -0500 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2015-11-24 13:33:13 -0500 |
commit | 3dcc8d39cf15fa3ceabedcffcbd3958fe953555a (patch) | |
tree | e364b95e20c8d093f0220c4545aff9d3fbe8868f | |
parent | 1ec218373b8ebda821aec00bb156a9c94fad9cd4 (diff) |
PCI: Prevent out of bounds access in numa_node override
Commit 1266963170f5 ("PCI: Prevent out of bounds access in numa_node
override") missed that the user-provided node could also be negative.
Handle this case as well to avoid out-of-bounds accesses to the
node_states[] array. However, allow the special value -1, i.e.
NUMA_NO_NODE, to be able to set the 'no specific node' configuration.
Fixes: 1266963170f5 ("PCI: Prevent out of bounds access in numa_node override")
Fixes: 63692df103e9 ("PCI: Allow numa_node override via sysfs")
Signed-off-by: Mathias Krause <minipli@googlemail.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
CC: Sasha Levin <sasha.levin@oracle.com>
CC: Prarit Bhargava <prarit@redhat.com>
CC: stable@vger.kernel.org # v3.19+
-rw-r--r-- | drivers/pci/pci-sysfs.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/pci/pci-sysfs.c b/drivers/pci/pci-sysfs.c index 92618686604c..eead54cd01b2 100644 --- a/drivers/pci/pci-sysfs.c +++ b/drivers/pci/pci-sysfs.c | |||
@@ -216,7 +216,10 @@ static ssize_t numa_node_store(struct device *dev, | |||
216 | if (ret) | 216 | if (ret) |
217 | return ret; | 217 | return ret; |
218 | 218 | ||
219 | if (node >= MAX_NUMNODES || !node_online(node)) | 219 | if ((node < 0 && node != NUMA_NO_NODE) || node >= MAX_NUMNODES) |
220 | return -EINVAL; | ||
221 | |||
222 | if (node != NUMA_NO_NODE && !node_online(node)) | ||
220 | return -EINVAL; | 223 | return -EINVAL; |
221 | 224 | ||
222 | add_taint(TAINT_FIRMWARE_WORKAROUND, LOCKDEP_STILL_OK); | 225 | add_taint(TAINT_FIRMWARE_WORKAROUND, LOCKDEP_STILL_OK); |