|
|
|
|
|
|
|
|
|
|
xen-changelog
[Xen-changelog] [xen-unstable] tools: avoid cpu over-commitment if numa=
# HG changeset patch
# User Keir Fraser <keir.fraser@xxxxxxxxxx>
# Date 1259674528 0
# Node ID d84edda40cb346463e370dce2d893a599aa44286
# Parent c0ceddd46bb0efb0714efb44eed1cfa4a9dd9205
tools: avoid cpu over-commitment if numa=on
Signed-off-by: Andre Przywara <andre.przywara@xxxxxxx>
---
tools/python/xen/xend/XendDomainInfo.py | 14 ++++++++++----
1 files changed, 10 insertions(+), 4 deletions(-)
diff -r c0ceddd46bb0 -r d84edda40cb3 tools/python/xen/xend/XendDomainInfo.py
--- a/tools/python/xen/xend/XendDomainInfo.py Tue Dec 01 13:34:38 2009 +0000
+++ b/tools/python/xen/xend/XendDomainInfo.py Tue Dec 01 13:35:28 2009 +0000
@@ -2637,8 +2637,7 @@ class XendDomainInfo:
nodeload[i] = int(nodeload[i] * 16 /
len(info['node_to_cpu'][i]))
else:
nodeload[i] = sys.maxint
- index = nodeload.index( min(nodeload) )
- return index
+ return map(lambda x: x[0], sorted(enumerate(nodeload),
key=lambda x:x[1]))
info = xc.physinfo()
if info['nr_nodes'] > 1:
@@ -2648,8 +2647,15 @@ class XendDomainInfo:
for i in range(0, info['nr_nodes']):
if node_memory_list[i] >= needmem and
len(info['node_to_cpu'][i]) > 0:
candidate_node_list.append(i)
- index = find_relaxed_node(candidate_node_list)
- cpumask = info['node_to_cpu'][index]
+ best_node = find_relaxed_node(candidate_node_list)[0]
+ cpumask = info['node_to_cpu'][best_node]
+ cores_per_node = info['nr_cpus'] / info['nr_nodes']
+ nodes_required = (self.info['VCPUs_max'] + cores_per_node - 1)
/ cores_per_node
+ if nodes_required > 1:
+ log.debug("allocating %d NUMA nodes", nodes_required)
+ best_nodes = find_relaxed_node(filter(lambda x: x !=
best_node, range(0,info['nr_nodes'])))
+ for i in best_nodes[:nodes_required - 1]:
+ cpumask = cpumask + info['node_to_cpu'][i]
for v in range(0, self.info['VCPUs_max']):
xc.vcpu_setaffinity(self.domid, v, cpumask)
return index
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog
|
<Prev in Thread] |
Current Thread |
[Next in Thread> |
- [Xen-changelog] [xen-unstable] tools: avoid cpu over-commitment if numa=on,
Xen patchbot-unstable <=
|
|
|
|
|