-
Notifications
You must be signed in to change notification settings - Fork 174
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
hugepage_reset: Test compatible with different NUMA topologies #4237
base: master
Are you sure you want to change the base?
Conversation
Please @JinLiul could you test this PR whenever you have a 8 NUMA nodes system again? Thanks! |
Hi @mcasquer, tested with 8 NUMA nodes system. |
5e1c2c5
to
b1013a9
Compare
Tests results on a 8 NUMA nodes host (with test loop a bit tuned 😁)
|
Please @JinLiul could you test again this PR? Thanks ! |
Also passed in 2 NUMA nodes host
|
huge_page_1G test loop passed |
b1013a9
to
d77d567
Compare
@@ -107,9 +125,9 @@ def heavyload_install(): | |||
"No node on your host has sufficient free memory for " "this test." | |||
) | |||
hp_config = test_setup.HugePageConfig(params) | |||
if params.get("on_numa_node"): | |||
allocate_largepages_per_node() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@mcasquer , code LGTM, I just want to confirm with you that if the node mem is not enough, still setup or better to raise error or skip the test.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Mmmm @PaulYuuu good point, I think that situation should be handled, perhaps with a try block, I'll send an update of this
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@PaulYuuu added a try block that will cancel the case ig there's no enough memory, faked example:
(2/2) Host_RHEL.m9.u6.ovmf.qcow2.virtio_scsi.up.virtio_net.Guest.RHEL.9.6.0.x86_64.io-github-autotest-qemu.hugepage_reset.on_numa_node.q35: STARTED
(2/2) Host_RHEL.m9.u6.ovmf.qcow2.virtio_scsi.up.virtio_net.Guest.RHEL.9.6.0.x86_64.io-github-autotest-qemu.hugepage_reset.on_numa_node.q35: CANCEL: 18 (expecting 400) hugepages is set on the node 0, please check if the node has enough memory (12.51 s)
d77d567
to
3b3e2de
Compare
qemu/tests/hugepage_reset.py
Outdated
mem_kb = mem * 1024 | ||
if node_mem_free > mem_kb: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
mem_kb = mem * 1024 | |
if node_mem_free > mem_kb: | |
if node_mem_free > (mem * 1024): |
except ValueError as e: | ||
test.cancel(e) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not sure when we will meet ValueError
, read_from_node_meminfo
?
When all nodes do not match the enough memory we want, the current loop will continue the test, but we should skip the test as well.
As the test will set 8 hugepages, this works fine for systems with 2 NUMA nodes, having e.g. 8 nodes is going to lead the on_numa_node variant to fail since the binded node doesn't have enough hugepages. As the cfg already suggests to allocate 1G hugepages on boot time, let's make user decision how many hugepages allocate, adding an informative comment in the cfg as well. Finally, if system hugepage_size is 1GB, allocates at runtime enough hugepages in all valid nodes. Signed-off-by: mcasquer <[email protected]>
3b3e2de
to
b870b91
Compare
hugepage_reset: Test compatible with different NUMA topologies
As the test will set 8 hugepages, this works fine
for systems with 2 NUMA nodes, having e.g. 8 nodes
is going to lead the on_numa_node variant to fail
since the binded node doesn't have enough hugepages.
As the cfg already suggests to allocate 1G hugepages
on boot time, let's make user decision how many hugepages
allocate, adding an informative comment in the cfg as well.
Finally, if system hugepage_size is 1GB, allocates at
runtime enough hugepages in all valid nodes.
Signed-off-by: mcasquer [email protected]
ID: 3254