[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v6 6/6] spapr: Don't allow memory hotplug to memory
From: |
Bharata B Rao |
Subject: |
[Qemu-devel] [PATCH v6 6/6] spapr: Don't allow memory hotplug to memory less nodes |
Date: |
Mon, 29 Jun 2015 14:14:32 +0530 |
Currently PowerPC kernel doesn't allow hot-adding memory to memory-less
node, but instead will silently add the memory to the first node that has
some memory. This causes two unexpected behaviours for the user.
- Memory gets hotplugged to a different node than what the user specified.
- Since pc-dimm subsystem in QEMU still thinks that memory belongs to
memory-less node, a reboot will set things accordingly and the previously
hotplugged memory now ends in the right node. This appears as if some
memory moved from one node to another.
So until kernel starts supporting memory hotplug to memory-less
nodes, just prevent such attempts upfront in QEMU.
Signed-off-by: Bharata B Rao <address@hidden>
Reviewed-by: David Gibson <address@hidden>
---
hw/ppc/spapr.c | 22 ++++++++++++++++++++++
1 file changed, 22 insertions(+)
diff --git a/hw/ppc/spapr.c b/hw/ppc/spapr.c
index 77c2060..4c3eeed 100644
--- a/hw/ppc/spapr.c
+++ b/hw/ppc/spapr.c
@@ -2137,6 +2137,28 @@ static void spapr_machine_device_plug(HotplugHandler
*hotplug_dev,
return;
}
+ /*
+ * Currently PowerPC kernel doesn't allow hot-adding memory to
+ * memory-less node, but instead will silently add the memory
+ * to the first node that has some memory. This causes two
+ * unexpected behaviours for the user.
+ *
+ * - Memory gets hotplugged to a different node than what the user
+ * specified.
+ * - Since pc-dimm subsystem in QEMU still thinks that memory belongs
+ * to memory-less node, a reboot will set things accordingly
+ * and the previously hotplugged memory now ends in the right node.
+ * This appears as if some memory moved from one node to another.
+ *
+ * So until kernel starts supporting memory hotplug to memory-less
+ * nodes, just prevent such attempts upfront in QEMU.
+ */
+ if (nb_numa_nodes && !numa_info[node].node_mem) {
+ error_setg(errp, "Can't hotplug memory to memory-less node %d",
+ node);
+ return;
+ }
+
spapr_memory_plug(hotplug_dev, dev, node, errp);
}
}
--
2.1.0
- [Qemu-devel] [PATCH v6 0/6] Memory hotplug for PowerPC sPAPR guests, Bharata B Rao, 2015/06/29
- [Qemu-devel] [PATCH v6 2/6] spapr: Add LMB DR connectors, Bharata B Rao, 2015/06/29
- [Qemu-devel] [PATCH v6 1/6] spapr: Initialize hotplug memory address space, Bharata B Rao, 2015/06/29
- [Qemu-devel] [PATCH v6 3/6] spapr: Support ibm, dynamic-reconfiguration-memory, Bharata B Rao, 2015/06/29
- [Qemu-devel] [PATCH v6 4/6] spapr: Make hash table size a factor of maxram_size, Bharata B Rao, 2015/06/29
- [Qemu-devel] [PATCH v6 5/6] spapr: Memory hotplug support, Bharata B Rao, 2015/06/29
- [Qemu-devel] [PATCH v6 6/6] spapr: Don't allow memory hotplug to memory less nodes,
Bharata B Rao <=
- Re: [Qemu-devel] [PATCH v6 0/6] Memory hotplug for PowerPC sPAPR guests, David Gibson, 2015/06/29