[Xfce4-commits] <xfce4-cpugraph-plugin:master> Add support for multicore on FreeBSD (bug #6531)
Landry Breuil
noreply at xfce.org
Wed Apr 18 23:30:05 CEST 2012
Updating branch refs/heads/master
to d04d9b15a97df645286cfb6be2a2d8987b0167f7 (commit)
from eb6a0246c9c8f23f5f3a6144b0ddc13d2b68894f (commit)
commit d04d9b15a97df645286cfb6be2a2d8987b0167f7
Author: Landry Breuil <landry at xfce.org>
Date: Wed Apr 18 23:27:54 2012 +0200
Add support for multicore on FreeBSD (bug #6531)
panel-plugin/os.c | 50 ++++++++++++++++++++++++++++++++++++++------------
1 files changed, 38 insertions(+), 12 deletions(-)
diff --git a/panel-plugin/os.c b/panel-plugin/os.c
index 83967c4..87e0322 100644
--- a/panel-plugin/os.c
+++ b/panel-plugin/os.c
@@ -134,28 +134,54 @@ gboolean read_cpu_data( CpuData *data, guint nb_cpu )
#elif defined (__FreeBSD__)
guint detect_cpu_number()
{
- return 1;
+ static gint mib[] = {CTL_HW, HW_NCPU};
+ gint ncpu;
+ gsize len = sizeof( gint );
+ if( sysctl( mib, 2, &ncpu, &len, NULL, 0 ) < 0 )
+ return 0;
+ else
+ return ncpu;
}
gboolean read_cpu_data( CpuData *data, guint nb_cpu)
{
glong used, total;
- glong cp_time[CPUSTATES];
- gsize len = sizeof( cp_time );
+ glong *cp_time;
+ glong *cp_time1;
+ gint i;
+ unsigned int max_cpu;
+ gsize len = sizeof(max_cpu);
- if( sysctlbyname( "kern.cp_time", &cp_time, &len, NULL, 0 ) < 0 )
+ data[0].load = 0;
+ if (sysctlbyname("kern.smp.maxid", &max_cpu, &len, NULL, 0) < 0)
return FALSE;
- used = cp_time[CP_USER] + cp_time[CP_NICE] + cp_time[CP_SYS] + cp_time[CP_INTR];
- total = used + cp_time[CP_IDLE];
- if( (total - data[0].previous_total) != 0 )
- data[0].load = (CPU_SCALE * (used - data[0].previous_used))/(total - data[0].previous_total);
- else
- data[0].load = 0;
+ max_cpu++; /* max_cpu is 0-based */
+ if (max_cpu < nb_cpu)
+ return FALSE; /* should not happen */
+ len = sizeof(glong) * max_cpu * CPUSTATES;
+ cp_time = (glong *) g_malloc(len);
- data[0].previous_used = used;
- data[0].previous_total = total;
+ if (sysctlbyname( "kern.cp_times", cp_time, &len, NULL, 0 ) < 0) {
+ g_free(cp_time);
+ return FALSE;
+ }
+ for (i = 1; i <= nb_cpu; i++ )
+ {
+ cp_time1 = &cp_time[CPUSTATES * (i - 1)];
+ used = cp_time1[CP_USER] + cp_time1[CP_NICE] + cp_time1[CP_SYS] + cp_time1[CP_INTR];
+ total = used + cp_time1[CP_IDLE];
+ if( (total - data[i].previous_total) != 0 )
+ data[i].load = (CPU_SCALE * (used - data[i].previous_used))/(total - data[i].previous_total);
+ else
+ data[i].load = 0;
+ data[i].previous_used = used;
+ data[i].previous_total = total;
+ data[0].load += data[i].load;
+ }
+ data[0].load /= nb_cpu;
+ g_free(cp_time);
return TRUE;
}
More information about the Xfce4-commits
mailing list