|
|
79b470 |
From b5aa3a33bc770714f8a68954c05ea362fcfd4d47 Mon Sep 17 00:00:00 2001
|
|
|
79b470 |
Message-Id: <b5aa3a33bc770714f8a68954c05ea362fcfd4d47@dist-git>
|
|
|
79b470 |
From: Daniel Henrique Barboza <danielhb413@gmail.com>
|
|
|
79b470 |
Date: Mon, 5 Oct 2020 10:25:30 -0400
|
|
|
79b470 |
Subject: [PATCH] virhostcpu.c: fix 'die_id' parsing for Power hosts
|
|
|
79b470 |
|
|
|
79b470 |
Commit 7b79ee2f78 makes assumptions about die_id parsing in
|
|
|
79b470 |
the sysfs that aren't true for Power hosts. In both Power8
|
|
|
79b470 |
and Power9, running 5.6 and 4.18 kernel respectively,
|
|
|
79b470 |
'die_id' is set to -1:
|
|
|
79b470 |
|
|
|
79b470 |
$ cat /sys/devices/system/cpu/cpu0/topology/die_id
|
|
|
79b470 |
-1
|
|
|
79b470 |
|
|
|
79b470 |
This breaks virHostCPUGetDie() parsing because it is trying to
|
|
|
79b470 |
retrieve an unsigned integer, causing problems during VM start:
|
|
|
79b470 |
|
|
|
79b470 |
virFileReadValueUint:4128 : internal error: Invalid unsigned integer
|
|
|
79b470 |
value '-1' in file '/sys/devices/system/cpu/cpu0/topology/die_id'
|
|
|
79b470 |
|
|
|
79b470 |
This isn't necessarily a PowerPC only behavior. Linux kernel commit
|
|
|
79b470 |
0e344d8c70 added in the former Documentation/cputopology.txt, now
|
|
|
79b470 |
Documentation/admin-guide/cputopology.rst, that:
|
|
|
79b470 |
|
|
|
79b470 |
To be consistent on all architectures, include/linux/topology.h
|
|
|
79b470 |
provides default definitions for any of the above macros that are
|
|
|
79b470 |
not defined by include/asm-XXX/topology.h:
|
|
|
79b470 |
|
|
|
79b470 |
1) topology_physical_package_id: -1
|
|
|
79b470 |
2) topology_die_id: -1
|
|
|
79b470 |
(...)
|
|
|
79b470 |
|
|
|
79b470 |
This means that it might be expected that an architecture that
|
|
|
79b470 |
does not implement the die_id element will mark it as -1 in
|
|
|
79b470 |
sysfs.
|
|
|
79b470 |
|
|
|
79b470 |
It is not required to change die_id implementation from uInt to
|
|
|
79b470 |
Int because of that. Instead, let's change the parsing of the
|
|
|
79b470 |
die_id in virHostCPUGetDie() to read an integer value and, in
|
|
|
79b470 |
case it's -1, default it to zero like in case of file not found.
|
|
|
79b470 |
This is enough to solve the issue Power hosts are experiencing.
|
|
|
79b470 |
|
|
|
79b470 |
Fixes: 7b79ee2f78bbf2af76df2f6466919e19ae05aeeb
|
|
|
79b470 |
Signed-off-by: Daniel Henrique Barboza <danielhb413@gmail.com>
|
|
|
79b470 |
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
|
|
|
79b470 |
(cherry picked from commit 0137bf0dab2738d5443e2f407239856e2aa25bb3)
|
|
|
79b470 |
|
|
|
79b470 |
https://bugzilla.redhat.com/show_bug.cgi?id=1876742
|
|
|
79b470 |
|
|
|
79b470 |
Signed-off-by: Daniel Henrique Barboza <dbarboza@redhat.com>
|
|
|
79b470 |
Message-Id: <20201005142530.3961036-1-dbarboza@redhat.com>
|
|
|
79b470 |
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
|
|
|
79b470 |
---
|
|
|
79b470 |
src/util/virhostcpu.c | 21 ++++++++++++++-------
|
|
|
79b470 |
1 file changed, 14 insertions(+), 7 deletions(-)
|
|
|
79b470 |
|
|
|
79b470 |
diff --git a/src/util/virhostcpu.c b/src/util/virhostcpu.c
|
|
|
79b470 |
index 09c959cd25..218272d7ec 100644
|
|
|
79b470 |
--- a/src/util/virhostcpu.c
|
|
|
79b470 |
+++ b/src/util/virhostcpu.c
|
|
|
79b470 |
@@ -221,16 +221,23 @@ virHostCPUGetSocket(unsigned int cpu, unsigned int *socket)
|
|
|
79b470 |
int
|
|
|
79b470 |
virHostCPUGetDie(unsigned int cpu, unsigned int *die)
|
|
|
79b470 |
{
|
|
|
79b470 |
- int ret = virFileReadValueUint(die,
|
|
|
79b470 |
- "%s/cpu/cpu%u/topology/die_id",
|
|
|
79b470 |
- SYSFS_SYSTEM_PATH, cpu);
|
|
|
79b470 |
+ int die_id;
|
|
|
79b470 |
+ int ret = virFileReadValueInt(&die_id,
|
|
|
79b470 |
+ "%s/cpu/cpu%u/topology/die_id",
|
|
|
79b470 |
+ SYSFS_SYSTEM_PATH, cpu);
|
|
|
79b470 |
|
|
|
79b470 |
- /* If the file is not there, it's 0 */
|
|
|
79b470 |
- if (ret == -2)
|
|
|
79b470 |
- *die = 0;
|
|
|
79b470 |
- else if (ret < 0)
|
|
|
79b470 |
+ if (ret == -1)
|
|
|
79b470 |
return -1;
|
|
|
79b470 |
|
|
|
79b470 |
+ /* If the file is not there, it's 0.
|
|
|
79b470 |
+ * Another alternative is die_id set to -1, meaning that
|
|
|
79b470 |
+ * the arch does not have die_id support. Set @die to
|
|
|
79b470 |
+ * 0 in this case too. */
|
|
|
79b470 |
+ if (ret == -2 || die_id < 0)
|
|
|
79b470 |
+ *die = 0;
|
|
|
79b470 |
+ else
|
|
|
79b470 |
+ *die = die_id;
|
|
|
79b470 |
+
|
|
|
79b470 |
return 0;
|
|
|
79b470 |
}
|
|
|
79b470 |
|
|
|
79b470 |
--
|
|
|
79b470 |
2.28.0
|
|
|
79b470 |
|