mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 12:35:17 +00:00
On systems with dmidecode version 2.10 or older,
dmidecode displays processor information, followed by BIOS, system and memory-DIMM details. Calls to virSysinfoParseBIOS(), virSysinfoParseSystem() would update the buffer pointer 'base', so the processor information would be lost before virSysinfoParseProcessor() was called. Sysinfo would therefore not be able to display processor details -- It only described <bios>, <system> and <memory_device> details. This patch attempts to insulate sysinfo from ordering of dmidecode output. Before the fix: --------------- virsh # sysinfo <sysinfo type='smbios'> <bios> .... </bios> <system> .... </system> <memory_device> .... </memory_device> After the fix: ------------- virsh # sysinfo <sysinfo type='smbios'> <bios> .... </bios> <system> .... </system> <processor> .... </processor> <memory_device> .... </memory_device>
This commit is contained in:
parent
0ed86cfb51
commit
a76530c9c7
@ -453,7 +453,7 @@ no_memory:
|
|||||||
|
|
||||||
virSysinfoDefPtr
|
virSysinfoDefPtr
|
||||||
virSysinfoRead(void) {
|
virSysinfoRead(void) {
|
||||||
char *path, *base;
|
char *path;
|
||||||
virSysinfoDefPtr ret = NULL;
|
virSysinfoDefPtr ret = NULL;
|
||||||
char *outbuf = NULL;
|
char *outbuf = NULL;
|
||||||
virCommandPtr cmd;
|
virCommandPtr cmd;
|
||||||
@ -481,22 +481,20 @@ virSysinfoRead(void) {
|
|||||||
|
|
||||||
ret->type = VIR_SYSINFO_SMBIOS;
|
ret->type = VIR_SYSINFO_SMBIOS;
|
||||||
|
|
||||||
base = outbuf;
|
if ((virSysinfoParseBIOS(outbuf, ret)) == NULL)
|
||||||
|
|
||||||
if ((base = virSysinfoParseBIOS(base, ret)) == NULL)
|
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
if ((base = virSysinfoParseSystem(base, ret)) == NULL)
|
if ((virSysinfoParseSystem(outbuf, ret)) == NULL)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
ret->nprocessor = 0;
|
ret->nprocessor = 0;
|
||||||
ret->processor = NULL;
|
ret->processor = NULL;
|
||||||
if ((base = virSysinfoParseProcessor(base, ret)) == NULL)
|
if ((virSysinfoParseProcessor(outbuf, ret)) == NULL)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
ret->nmemory = 0;
|
ret->nmemory = 0;
|
||||||
ret->memory = NULL;
|
ret->memory = NULL;
|
||||||
if (virSysinfoParseMemory(base, ret) == NULL)
|
if (virSysinfoParseMemory(outbuf, ret) == NULL)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user