[PATCH] powerpc/pseries: Export VPA related data

Aravinda Prasad aravinda at linux.vnet.ibm.com
Tue Sep 4 19:30:55 AEST 2018


This patch exports VPA related data such as stolen and
donated CPU cycles through /proc/powerpc/lparcfg file.

Signed-off-by: Aravinda Prasad <aravinda at linux.vnet.ibm.com>
---
 arch/powerpc/include/asm/lppaca.h        |   10 ++++++-
 arch/powerpc/platforms/pseries/lparcfg.c |   45 ++++++++++++++++++++++++++++++
 2 files changed, 54 insertions(+), 1 deletion(-)

diff --git a/arch/powerpc/include/asm/lppaca.h b/arch/powerpc/include/asm/lppaca.h
index 7c23ce8..87e22f6 100644
--- a/arch/powerpc/include/asm/lppaca.h
+++ b/arch/powerpc/include/asm/lppaca.h
@@ -94,7 +94,15 @@ struct lppaca {
 	volatile __be32 dispersion_count; /* dispatch changed physical cpu */
 	volatile __be64 cmo_faults;	/* CMO page fault count */
 	volatile __be64 cmo_fault_time;	/* CMO page fault time */
-	u8	reserved10[104];
+	volatile __be64 idle_stolen_purr;
+	volatile __be64 idle_stolen_spurr;
+	volatile __be64 busy_stolen_purr;
+	volatile __be64 busy_stolen_spurr;
+	volatile __be64 idle_donated_purr;
+	volatile __be64 idle_donated_spurr;
+	volatile __be64 busy_donated_purr;
+	volatile __be64 busy_donated_spurr;
+	u8  reserved10[40];
 
 	/* cacheline 4-5 */
 
diff --git a/arch/powerpc/platforms/pseries/lparcfg.c b/arch/powerpc/platforms/pseries/lparcfg.c
index 7c872dc..b986551 100644
--- a/arch/powerpc/platforms/pseries/lparcfg.c
+++ b/arch/powerpc/platforms/pseries/lparcfg.c
@@ -433,6 +433,50 @@ static void parse_em_data(struct seq_file *m)
 		seq_printf(m, "power_mode_data=%016lx\n", retbuf[0]);
 }
 
+static void pseries_vpa_data(struct seq_file *m)
+{
+	int cpu;
+	unsigned long idle_stolen_purr = 0;
+	unsigned long idle_stolen_spurr = 0;
+	unsigned long busy_stolen_purr = 0;
+	unsigned long busy_stolen_spurr = 0;
+	unsigned long idle_donated_purr = 0;
+	unsigned long idle_donated_spurr = 0;
+	unsigned long busy_donated_purr = 0;
+	unsigned long busy_donated_spurr = 0;
+
+	if (!firmware_has_feature(FW_FEATURE_SPLPAR))
+		return;
+
+	for_each_possible_cpu(cpu) {
+		idle_stolen_purr +=
+			be64_to_cpu(lppaca_of(cpu).idle_stolen_purr);
+		idle_stolen_spurr +=
+			be64_to_cpu(lppaca_of(cpu).idle_stolen_spurr);
+		busy_stolen_purr +=
+			be64_to_cpu(lppaca_of(cpu).busy_stolen_purr);
+		busy_stolen_spurr +=
+			be64_to_cpu(lppaca_of(cpu).busy_stolen_spurr);
+		idle_donated_purr +=
+			be64_to_cpu(lppaca_of(cpu).idle_donated_purr);
+		idle_donated_spurr +=
+			be64_to_cpu(lppaca_of(cpu).idle_donated_spurr);
+		busy_donated_purr +=
+			be64_to_cpu(lppaca_of(cpu).busy_donated_purr);
+		busy_donated_spurr +=
+			be64_to_cpu(lppaca_of(cpu).busy_donated_spurr);
+	}
+
+	seq_printf(m, "idle_stolen_purr=%lu\n", idle_stolen_purr);
+	seq_printf(m, "idle_stolen_spurr=%lu\n", idle_stolen_spurr);
+	seq_printf(m, "busy_stolen_purr=%lu\n", busy_stolen_purr);
+	seq_printf(m, "busy_stolen_spurr=%lu\n", busy_stolen_spurr);
+	seq_printf(m, "idle_donated_purr=%lu\n", idle_donated_purr);
+	seq_printf(m, "idle_donated_spurr=%lu\n", idle_donated_spurr);
+	seq_printf(m, "busy_donated_purr=%lu\n", busy_donated_purr);
+	seq_printf(m, "busy_donated_spurr=%lu\n", busy_donated_spurr);
+}
+
 static int pseries_lparcfg_data(struct seq_file *m, void *v)
 {
 	int partition_potential_processors;
@@ -491,6 +535,7 @@ static int pseries_lparcfg_data(struct seq_file *m, void *v)
 	seq_printf(m, "slb_size=%d\n", mmu_slb_size);
 #endif
 	parse_em_data(m);
+	pseries_vpa_data(m);
 
 	return 0;
 }



More information about the Linuxppc-dev mailing list