531551
From cd0d8ef86151d72a246d565844d4c0470feb6b20 Mon Sep 17 00:00:00 2001
531551
From: Ruediger Meier <ruediger.meier@ga-group.nl>
531551
Date: Wed, 16 Mar 2016 13:18:18 +0100
531551
Subject: [PATCH 68/84] lscpu: use cpu and revision tag if available
531551
531551
Avoid ifdef which does not work with --sysroot. Our existing test
531551
dumps produce even better output now for ppc and sparc.
531551
531551
The logic moved to the printing section.
531551
531551
Upstream: http://github.com/karelzak/util-linux/commit/641350fe822e7f1ac10873dad9a364bdeaba8083
531551
Upstream: http://github.com/karelzak/util-linux/commit/86c4817e0ea02656ddb62fe27757a9fd4f13b2d3
531551
Upstream: http://github.com/karelzak/util-linux/commit/c95e3889725389e9d7e24d29c2a71b015959575f
531551
Addresses: http://bugzilla.redhat.com/show_bug.cgi?id=1326615
531551
CC: Vasant Hegde <hegdevasant@linux.vnet.ibm.com>
531551
Signed-off-by: Ruediger Meier <ruediger.meier@ga-group.nl>
531551
Signed-off-by: Karel Zak <kzak@redhat.com>
531551
---
531551
 sys-utils/lscpu.c                             | 17 ++++++++---------
531551
 tests/expected/lscpu/lscpu-ppc64-POWER7       |  3 ++-
531551
 tests/expected/lscpu/lscpu-ppc64-POWER7-64cpu |  3 ++-
531551
 3 files changed, 12 insertions(+), 11 deletions(-)
531551
531551
diff --git a/sys-utils/lscpu.c b/sys-utils/lscpu.c
531551
index 68b15af..7a00636 100644
531551
--- a/sys-utils/lscpu.c
531551
+++ b/sys-utils/lscpu.c
531551
@@ -141,6 +141,8 @@ struct lscpu_desc {
531551
 	char	*family;
531551
 	char	*model;
531551
 	char	*modelname;
531551
+	char	*revision;  /* alternative for model (ppc) */
531551
+	char	*cpu;       /* alternative for modelname (ppc, sparc) */
531551
 	char	*virtflag;	/* virtualization flag (vmx, svm) */
531551
 	char	*hypervisor;	/* hypervisor software */
531551
 	int	hyper;		/* hypervisor vendor ID */
531551
@@ -355,13 +357,8 @@ read_basicinfo(struct lscpu_desc *desc, struct lscpu_modifier *mod)
531551
 		else if (lookup(buf, "vendor_id", &desc->vendor)) ;
531551
 		else if (lookup(buf, "family", &desc->family)) ;
531551
 		else if (lookup(buf, "cpu family", &desc->family)) ;
531551
-#if defined(__powerpc__) || defined(__powerpc64__)
531551
-		else if (lookup(buf, "revision", &desc->model)) ;
531551
-		else if (lookup(buf, "cpu", &desc->modelname)) ;
531551
-#else
531551
 		else if (lookup(buf, "model", &desc->model)) ;
531551
 		else if (lookup(buf, "model name", &desc->modelname)) ;
531551
-#endif
531551
 		else if (lookup(buf, "stepping", &desc->stepping)) ;
531551
 		else if (lookup(buf, "cpu MHz", &desc->mhz)) ;
531551
 		else if (lookup(buf, "flags", &desc->flags)) ;		/* x86 */
531551
@@ -369,6 +366,8 @@ read_basicinfo(struct lscpu_desc *desc, struct lscpu_modifier *mod)
531551
 		else if (lookup(buf, "type", &desc->flags)) ;		/* sparc64 */
531551
 		else if (lookup(buf, "bogomips", &desc->bogomips)) ;
531551
 		else if (lookup(buf, "bogomips per cpu", &desc->bogomips)) ; /* s390 */
531551
+		else if (lookup(buf, "cpu", &desc->cpu)) ;
531551
+		else if (lookup(buf, "revision", &desc->revision)) ;
531551
 		else
531551
 			continue;
531551
 	}
531551
@@ -1264,10 +1263,10 @@ print_summary(struct lscpu_desc *desc, struct lscpu_modifier *mod)
531551
 		print_s(_("Vendor ID:"), desc->vendor);
531551
 	if (desc->family)
531551
 		print_s(_("CPU family:"), desc->family);
531551
-	if (desc->model)
531551
-		print_s(_("Model:"), desc->model);
531551
-	if (desc->modelname)
531551
-		print_s(_("Model name:"), desc->modelname);
531551
+	if (desc->model || desc->revision)
531551
+		print_s(_("Model:"), desc->revision ? desc->revision : desc->model);
531551
+	if (desc->modelname || desc->cpu)
531551
+		print_s(_("Model name:"), desc->cpu ? desc->cpu : desc->modelname);
531551
 	if (desc->stepping)
531551
 		print_s(_("Stepping:"), desc->stepping);
531551
 	if (desc->mhz)
531551
diff --git a/tests/expected/lscpu/lscpu-ppc64-POWER7 b/tests/expected/lscpu/lscpu-ppc64-POWER7
531551
index 0d6c5ba..9a3c0c9 100644
531551
--- a/tests/expected/lscpu/lscpu-ppc64-POWER7
531551
+++ b/tests/expected/lscpu/lscpu-ppc64-POWER7
531551
@@ -4,7 +4,8 @@ Thread(s) per core:    4
531551
 Core(s) per socket:    1
531551
 Socket(s):             4
531551
 NUMA node(s):          1
531551
-Model:                 IBM,8233-E8B
531551
+Model:                 2.1 (pvr 003f 0201)
531551
+Model name:            POWER7 (architected), altivec supported
531551
 L1d cache:             32K
531551
 L1i cache:             32K
531551
 NUMA node0 CPU(s):     0-15
531551
diff --git a/tests/expected/lscpu/lscpu-ppc64-POWER7-64cpu b/tests/expected/lscpu/lscpu-ppc64-POWER7-64cpu
531551
index 40e2736..d4ae6c1 100644
531551
--- a/tests/expected/lscpu/lscpu-ppc64-POWER7-64cpu
531551
+++ b/tests/expected/lscpu/lscpu-ppc64-POWER7-64cpu
531551
@@ -4,7 +4,8 @@ Thread(s) per core:    4
531551
 Core(s) per socket:    1
531551
 Socket(s):             16
531551
 NUMA node(s):          2
531551
-Model:                 IBM,8231-E2B
531551
+Model:                 2.1 (pvr 003f 0201)
531551
+Model name:            POWER7 (architected), altivec supported
531551
 L1d cache:             32K
531551
 L1i cache:             32K
531551
 NUMA node0 CPU(s):     0-63
531551
-- 
531551
2.7.4
531551