On Tuesday 20 May 2014, Ruediger Meier wrote: > From: Ruediger Meier <ruediger.meier@xxxxxxxxxxx> > > This patch comes from openSUSE / SLE. Original author was probably > Petr Uzel. > Internal SUSE references: fate310255, sr226509 > > CC: Stanislav Brabec <sbrabec@xxxxxxx> > CC: Petr Uzel <petr.uzel@xxxxxxx> > Signed-off-by: Ruediger Meier <ruediger.meier@xxxxxxxxxxx> > --- > sys-utils/lscpu.c | 50 +++++++++++++++++++++++++++++++++++++++++++++++++- > sys-utils/lscpu.h | 4 +++- > 2 files changed, 52 insertions(+), 2 deletions(-) > > diff --git a/sys-utils/lscpu.c b/sys-utils/lscpu.c > index 0203916..b9e07e6 100644 > --- a/sys-utils/lscpu.c > +++ b/sys-utils/lscpu.c > @@ -60,6 +60,7 @@ > #define _PATH_PROC_STATUS "/proc/self/status" > #define _PATH_PROC_VZ "/proc/vz" > #define _PATH_PROC_BC "/proc/bc" > +#define _PATH_PROC_DEVICETREE "/proc/device-tree" > #define _PATH_DEV_MEM "/dev/mem" > > /* virtualization types */ > @@ -88,7 +89,9 @@ const char *hv_vendors[] = { > [HYPER_INNOTEK] = "Innotek GmbH", > [HYPER_HITACHI] = "Hitachi", > [HYPER_PARALLELS] = "Parallels", > - [HYPER_VBOX] = "Oracle" > + [HYPER_VBOX] = "Oracle", > + [HYPER_OS400] = "OS/400", > + [HYPER_PHYP] = "pHyp" > }; > > const int hv_vendor_pci[] = { > @@ -574,6 +577,51 @@ read_hypervisor_cpuid(struct lscpu_desc *desc) > static void > read_hypervisor_cpuid(struct lscpu_desc *desc __attribute__((__unused__))) > { > +#ifdef __powerpc__ > + /* powerpc: > + * IBM iSeries: legacy, if /proc/iSeries exists, its para-virtualized on top of OS/400 According to this comment ... > + * IBM pSeries: always has a hypervisor > + * if partition-name is "full", its kind of "bare-metal": full-system-partition > + * otherwise its some partition created by Hardware Management Console > + * in any case, its always some sort of HVM > + * KVM: "linux,kvm" in /hypervisor/compatible indicates a KVM guest > + * Xen: not in use, not detected > + */ > + if (path_exist("/proc/iSeries")) { > + desc->hyper = HYPER_OS400; > + desc->virtype = VIRT_FULL; ... shouldn't this be VIRT_PARA? Somebody who knows this may correct this. > + } else if (path_exist(_PATH_PROC_DEVICETREE "/ibm,partition-name")) { > + FILE *fd; > + desc->hyper = HYPER_PHYP; > + desc->virtype = VIRT_FULL; Maybe more obvious here for pSeries where p seems to stand for para http://www.ibm.com/developerworks/aix/library/au-syspvirtualization/index.html?S_TACT=105AGX99&S_CMP=CP > + fd = fopen(_PATH_PROC_DEVICETREE "/ibm,partition-name", "r"); > + if (fd) { > + char buf[256]; > + if (fscanf(fd, "%s", buf) == 1 && !strcmp(buf, "full")) > + desc->virtype = VIRT_NONE; > + fclose(fd); > + } > + } else if (path_exist(_PATH_PROC_DEVICETREE "/hypervisor/compatible")) { > + FILE *fd; > + fd = fopen(_PATH_PROC_DEVICETREE "/hypervisor/compatible", "r"); > + if (fd) { > + char buf[256]; > + int i; > + memset(buf, 0, sizeof(buf)); > + fread(buf, sizeof(buf) - 1, 1, fd); > + fclose(fd); > + for (i = 0; i < sizeof(buf);) { > + if (!strcmp(&buf[i], "linux,kvm")) { > + desc->hyper = HYPER_KVM; > + desc->virtype = VIRT_FULL; > + break; > + } > + i += strlen(&buf[i]); > + i++; > + } > + } > + } > +#endif > } > #endif > > diff --git a/sys-utils/lscpu.h b/sys-utils/lscpu.h > index 7bb538d..6c25c4f 100644 > --- a/sys-utils/lscpu.h > +++ b/sys-utils/lscpu.h > @@ -14,7 +14,9 @@ enum { > HYPER_INNOTEK, /* VBOX */ > HYPER_HITACHI, > HYPER_PARALLELS, /* OpenVZ/VIrtuozzo */ > - HYPER_VBOX > + HYPER_VBOX, > + HYPER_OS400, > + HYPER_PHYP > }; > > extern int read_hypervisor_dmi(void); -- To unsubscribe from this list: send the line "unsubscribe util-linux" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html