[PATCH] iSeries legacy model emulation of PURR

Jeff Scheel scheel at vnet.ibm.com
Fri Nov 12 01:58:03 EST 2004


Andrew,

Here's a patch to extend the current Linux on Power support for PURR to 
legacy IBM iSeries servers (pre-Power5 processor models).  This patch 
enables the reporting of timebase metrics to reflect physical processor 
utilization in a system running multiple logical partitions which share 
the same physical processors.

The patch simply uses existing user interfaces for Linux IBM Power5 
based servers to report data already collected by the hypervisor.  The 
values reported with each call are running values in units of the system 
timebase.  The calculation of physical processor utilization results 
from two samples (purr1 and purr2) differing by a know interval (time) 
such that:
    physical utilization = (purr2 - purr1) / (time * number of procs * 
timebase)
where the number of procs and timebase can be obtained from /proc/cpuinfo.

Applications have been written to the interface already defined and 
these applications have value back on the legacy iSeries models.

Please consider this patch for inclusion.  It has been reviewed by Stephen.
-Jeff

Signed-off by: Jeff Scheel (scheel at vnet.ibm.com)

--- linuxppc-2.6.10_rc1.orig/arch/ppc64/kernel/lparcfg.c	2004-11-09 07:03:43.354383000 -0600
+++ linuxppc-2.6.10_rc1/arch/ppc64/kernel/lparcfg.c	2004-11-10 10:38:47.904484533 -0600
@@ -34,7 +34,7 @@
 #include <asm/rtas.h>
 #include <asm/system.h>
 
-#define MODULE_VERS "1.4"
+#define MODULE_VERS "1.5"
 #define MODULE_NAME "lparcfg"
 
 /* #define LPARCFG_DEBUG */
@@ -70,6 +70,28 @@
 
 #ifdef CONFIG_PPC_ISERIES
 
+/*
+ * For iSeries legacy systems, the PPA purr function is available from the
+ * xEmulatedTimeBase field in the paca.
+ */
+static unsigned long get_purr(void)
+{
+	unsigned long sum_purr = 0;
+	int cpu;
+	struct paca_struct *lpaca;
+
+	for_each_cpu(cpu) {
+		lpaca = paca + cpu;
+		sum_purr += lpaca->xLpPaca.xEmulatedTimeBase;
+
+#ifdef PURR_DEBUG
+		printk(KERN_INFO "get_purr for cpu (%d) has value (%ld) \n",
+			cpu, lpaca->xLpPaca.xEmulatedTimeBase);
+#endif
+	}
+	return sum_purr;
+}
+
 #define lparcfg_write NULL
 
 /* 
@@ -81,6 +103,9 @@
 	int shared, entitled_capacity, max_entitled_capacity;
 	int processors, max_processors;
 	struct paca_struct *lpaca = get_paca();
+	unsigned long purr = get_purr();
+
+	seq_printf(m, "%s %s \n", MODULE_NAME, MODULE_VERS);
 
 	shared = (int)(lpaca->lppaca_ptr->xSharedProc);
 	seq_printf(m, "serial_number=%c%c%c%c%c%c%c\n",
@@ -131,6 +156,7 @@
 		seq_printf(m, "pool_capacity=%d\n",
 			   (int)(HvLpConfig_getNumProcsInSharedPool(pool_id) *
 				 100));
+		seq_printf(m, "purr=%ld\n", purr);
 	}
 
 	seq_printf(m, "shared_processor_mode=%d\n", shared);




More information about the Linuxppc64-dev mailing list