[RFC] prototype of top(1)'s CPU current frequency display

Norikatsu Shigemura nork at FreeBSD.org
Sat Aug 26 08:56:52 UTC 2006


On Sun, 20 Aug 2006 17:24:35 +0900
Norikatsu Shigemura <nork at freebsd.org> wrote:
> 	1. assume only 1 CPU.
> 	2. assume dev.cpu.0.freq is always exists.
> 	3. display position is good?

	I modified 1 and 2.  Please check attached diff.
	I couldn't fix 3 issue.  So I assumed support max 2CPUs.

	I confirmed following environments.

- - PentiumIII-S dual - - - - - - - - - - - - -
dev.cpu.0.%desc: ACPI CPU
dev.cpu.0.%driver: cpu
dev.cpu.0.%location: handle=\_PR_.CPU0
dev.cpu.0.%pnpinfo: _HID=none _UID=0
dev.cpu.0.%parent: acpi0
dev.cpu.1.%desc: ACPI CPU
dev.cpu.1.%driver: cpu
dev.cpu.1.%location: handle=\_PR_.CPU1
dev.cpu.1.%pnpinfo: _HID=none _UID=0
dev.cpu.1.%parent: acpi0
- - PentiumIII-S dual - - - - - - - - - - - - -

- - Pentium-M Dothan - - - - - - - - - - - - - -
dev.cpu.0.%desc: ACPI CPU
dev.cpu.0.%driver: cpu
dev.cpu.0.%location: handle=\_PR_.CPU0
dev.cpu.0.%pnpinfo: _HID=none _UID=0
dev.cpu.0.%parent: acpi0
dev.cpu.0.freq: 1200
dev.cpu.0.freq_levels: 1200/-1 1100/-1 1000/-1 900/-1 800/-1 700/-1 600/-1 525/-1 450/-1 375/-1 300/-1 225/-1 150/-1 75/-1
- - Pentium-M Dothan - - - - - - - - - - - - - -

- - Xeon 2.8GHz - - - - - - - - - - - - - - - -
dev.cpu.0.%desc: ACPI CPU
dev.cpu.0.%driver: cpu
dev.cpu.0.%location: handle=\_PR_.CPU0
dev.cpu.0.%pnpinfo: _HID=none _UID=0
dev.cpu.0.%parent: acpi0
dev.cpu.0.freq: 2807
dev.cpu.0.freq_levels: 2807/-1 2456/-1 2105/-1 1754/-1 1403/-1 1052/-1 701/-1 350/-1
- - Xeon 2.8GHz - - - - - - - - - - - - - - - -
-------------- next part --------------
Index: machine.c
===================================================================
RCS file: /home/ncvs/src/usr.bin/top/machine.c,v
retrieving revision 1.74
diff -u -r1.74 machine.c
--- machine.c	18 May 2005 13:42:51 -0000	1.74
+++ machine.c	26 Aug 2006 08:41:50 -0000
@@ -61,6 +61,8 @@
 extern char* printable(char *);
 int swapmode(int *retavail, int *retfree);
 static int smpmode;
+static int ncpu;
+#define	NCPU	2		/* support max 2cpu to display frequency */
 enum displaymodes displaymode;
 static int namelength = 8;
 static int cmdlengthdelta;
@@ -153,10 +155,10 @@
 
 /* these are for detailing the process states */
 
-int process_states[8];
+int process_states[8+NCPU];
 char *procstatenames[] = {
 	"", " starting, ", " running, ", " sleeping, ", " stopped, ",
-	" zombie, ", " waiting, ", " lock, ",
+	" zombie, ", " waiting, ", " lock, ", " MHz, ", " MHz, ",
 	NULL
 };
 
@@ -235,6 +237,13 @@
 	    modelen != sizeof(smpmode))
 		smpmode = 0;
 
+	for (ncpu = -1; ncpu < NCPU; ncpu++) {
+		char buf[32];
+		snprintf(buf, sizeof buf-1, "dev.cpu.%d.freq", ncpu+1);
+		if (sysctlbyname(buf, NULL, NULL, NULL, 0) < 0)
+			break;
+	}
+
 	while ((pw = getpwent()) != NULL) {
 		if (strlen(pw->pw_name) > namelength)
 			namelength = strlen(pw->pw_name);
@@ -629,6 +638,16 @@
 		}
 	}
 
+	/* CPU current frequency */
+	if (ncpu != -1) {
+		int j;
+		for(j = 0; j <= ncpu; j++) {
+			char buf[32];
+			snprintf(buf, sizeof buf-1, "dev.cpu.%d.freq", j);
+			GETSYSCTL(buf, process_states[j+8]);
+		}
+	}
+
 	/* if requested, sort the "interesting" processes */
 	if (compare != NULL)
 		qsort(pref, active_procs, sizeof(*pref), compare);
-------------- next part --------------
Index: machine.c
===================================================================
RCS file: /home/ncvs/src/usr.bin/top/machine.c,v
retrieving revision 1.77
diff -u -r1.77 machine.c
--- machine.c	11 Jun 2006 19:18:39 -0000	1.77
+++ machine.c	26 Aug 2006 08:41:29 -0000
@@ -58,6 +58,8 @@
 extern struct process_select ps;
 extern char* printable(char *);
 static int smpmode;
+static int ncpu;
+#define	NCPU	2		/* support max 2cpu to display frequency */
 enum displaymodes displaymode;
 static int namelength = 8;
 static int cmdlengthdelta;
@@ -147,10 +149,10 @@
 
 /* these are for detailing the process states */
 
-int process_states[8];
+int process_states[8+NCPU];
 char *procstatenames[] = {
 	"", " starting, ", " running, ", " sleeping, ", " stopped, ",
-	" zombie, ", " waiting, ", " lock, ",
+	" zombie, ", " waiting, ", " lock, ", " MHz, ", " MHz, ",
 	NULL
 };
 
@@ -234,6 +236,13 @@
 	    modelen != sizeof(smpmode))
 		smpmode = 0;
 
+	for (ncpu = -1; ncpu < NCPU; ncpu++) {
+		char buf[32];
+		snprintf(buf, sizeof buf-1, "dev.cpu.%d.freq", ncpu+1);
+		if (sysctlbyname(buf, NULL, NULL, NULL, 0) < 0)
+			break;
+	}
+
 	while ((pw = getpwent()) != NULL) {
 		if (strlen(pw->pw_name) > namelength)
 			namelength = strlen(pw->pw_name);
@@ -632,6 +641,16 @@
 		}
 	}
 
+	/* CPU current frequency */
+	if (ncpu != -1) {
+		int j;
+		for(j = 0; j <= ncpu; j++) {
+			char buf[32];
+			snprintf(buf, sizeof buf-1, "dev.cpu.%d.freq", j);
+			GETSYSCTL(buf, process_states[j+8]);
+		}
+	}
+
 	/* if requested, sort the "interesting" processes */
 	if (compare != NULL)
 		qsort(pref, active_procs, sizeof(*pref), compare);


More information about the freebsd-current mailing list