diff options
author | Carlos Perelló Marín <carlos@gnome.org> | 2003-10-19 16:55:56 +0000 |
---|---|---|
committer | Carlos Perelló Marín <carlos@src.gnome.org> | 2003-10-19 16:55:56 +0000 |
commit | 4c8ae9e25c1940d8876ca3f2330426863cae4737 (patch) | |
tree | c43f97bc0647546b0ed87022db0749c137f24edc /examples/second.c | |
parent | bae16b467f90df94d80feae41dceb7e816f16c61 (diff) | |
download | libgtop-4c8ae9e25c1940d8876ca3f2330426863cae4737.tar.gz |
Reverted libgtop changes. It's a common module and I should not modify it.
2003-10-19 Carlos Perelló Marín <carlos@gnome.org>
* support/*: Reverted libgtop changes. It's a common module
and I should not modify it.
* Added/removed files. Now the move should be done.
Diffstat (limited to 'examples/second.c')
-rw-r--r-- | examples/second.c | 300 |
1 files changed, 300 insertions, 0 deletions
diff --git a/examples/second.c b/examples/second.c new file mode 100644 index 00000000..b65bf86f --- /dev/null +++ b/examples/second.c @@ -0,0 +1,300 @@ +/* $Id$ */ + +/* Copyright (C) 1998-99 Martin Baulig + This file is part of LibGTop 1.0. + + Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998. + + LibGTop is free software; you can redistribute it and/or modify it + under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, + or (at your option) any later version. + + LibGTop is distributed in the hope that it will be useful, but WITHOUT + ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + for more details. + + You should have received a copy of the GNU General Public License + along with LibGTop; see the file COPYING. If not, write to the + Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. +*/ + +#include <locale.h> +#include <math.h> + +#include <glibtop.h> +#include <glibtop/open.h> +#include <glibtop/close.h> +#include <glibtop/xmalloc.h> + +#include <glibtop/union.h> +#include <glibtop/sysdeps.h> + +static void +output (pid_t pid) +{ + glibtop_union data; + char *args; + unsigned i; + +#if HAVE_LIBGTOP_SMP + unsigned long total; + double p_total, p_utime, p_stime; + double b_total, b_utime, b_stime; + double s_total, s_utime, s_stime; + double my_utime, my_stime; + int ncpu; +#endif + + printf ("\n"); + + glibtop_get_proc_state (&data.proc_state, pid); + + printf ("Proc_State PID %5d (0x%08lx): " + "'%s', %c, %lu, %lu\n", (int) pid, + (unsigned long) data.proc_state.flags, + data.proc_state.cmd, data.proc_state.state, + (unsigned long) data.proc_state.uid, + (unsigned long) data.proc_state.gid); + + glibtop_get_proc_uid (&data.proc_uid, pid); + + printf ("Proc_Uid PID %5d (0x%08lx): " + "%d %d %d %d %d %d %d %d %d %d %d %d\n", (int) pid, + (unsigned long) data.proc_uid.flags, + data.proc_uid.uid, data.proc_uid.euid, + data.proc_uid.gid, data.proc_uid.egid, + data.proc_uid.pid, data.proc_uid.ppid, + data.proc_uid.pgrp, data.proc_uid.session, + data.proc_uid.tty, data.proc_uid.tpgid, + data.proc_uid.priority, data.proc_uid.nice); + + glibtop_get_proc_mem (&data.proc_mem, pid); + + printf ("Proc_Mem PID %5d (0x%08lx): " + "%lu %lu %lu %lu %lu %lu\n", (int) pid, + (unsigned long) data.proc_mem.flags, + (unsigned long) data.proc_mem.size, + (unsigned long) data.proc_mem.vsize, + (unsigned long) data.proc_mem.resident, + (unsigned long) data.proc_mem.share, + (unsigned long) data.proc_mem.rss, + (unsigned long) data.proc_mem.rss_rlim); + + glibtop_get_proc_segment (&data.proc_segment, pid); + + printf ("Proc_Segment PID %5d (0x%08lx): " + "%lu %lu %lu %lu %lu %lu %lu %lu\n", (int) pid, + (unsigned long) data.proc_segment.flags, + (unsigned long) data.proc_segment.text_rss, + (unsigned long) data.proc_segment.shlib_rss, + (unsigned long) data.proc_segment.data_rss, + (unsigned long) data.proc_segment.stack_rss, + (unsigned long) data.proc_segment.dirty_size, + (unsigned long) data.proc_segment.start_code, + (unsigned long) data.proc_segment.end_code, + (unsigned long) data.proc_segment.start_stack); + + glibtop_get_proc_time (&data.proc_time, pid); + + printf ("Proc_Time PID %5d (0x%08lx): " + "%lu %lu %lu %lu %lu %lu %lu %lu %lu\n", (int) pid, + (unsigned long) data.proc_time.flags, + (unsigned long) data.proc_time.start_time, + (unsigned long) data.proc_time.rtime, + (unsigned long) data.proc_time.utime, + (unsigned long) data.proc_time.stime, + (unsigned long) data.proc_time.cutime, + (unsigned long) data.proc_time.cstime, + (unsigned long) data.proc_time.timeout, + (unsigned long) data.proc_time.it_real_value, + (unsigned long) data.proc_time.frequency); + + glibtop_get_proc_signal (&data.proc_signal, pid); + + printf ("Proc_Signal PID %5d (0x%08lx): " + "%lu %lu %lu %lu\n", (int) pid, + (unsigned long) data.proc_signal.flags, + (unsigned long) data.proc_signal.signal, + (unsigned long) data.proc_signal.blocked, + (unsigned long) data.proc_signal.sigignore, + (unsigned long) data.proc_signal.sigcatch); + + glibtop_get_proc_kernel (&data.proc_kernel, pid); + + printf ("Proc_Kernel PID %5d (0x%08lx): " + "%lu %lu %lu %lu %lu 0x%lx 0x%lx 0x%lx (%s)\n", (int) pid, + (unsigned long) data.proc_kernel.flags, + (unsigned long) data.proc_kernel.k_flags, + (unsigned long) data.proc_kernel.min_flt, + (unsigned long) data.proc_kernel.maj_flt, + (unsigned long) data.proc_kernel.cmin_flt, + (unsigned long) data.proc_kernel.cmaj_flt, + (unsigned long) data.proc_kernel.kstk_esp, + (unsigned long) data.proc_kernel.kstk_eip, + (unsigned long) data.proc_kernel.nwchan, + data.proc_kernel.wchan); + + printf ("\n"); + + args = glibtop_get_proc_args (&data.proc_args, pid, 0); + + for (i = 0; i < data.proc_args.size; i++) { + if (args [i]) continue; + args [i] = '|'; + } + + printf ("Proc_Args PID %5d (0x%08lx): %lu - '%s'\n", (int) pid, + (unsigned long) data.proc_args.flags, + (unsigned long) data.proc_args.size, + args ? args : ""); + + glibtop_free (args); + + printf ("\n"); + +#if HAVE_LIBGTOP_SMP + ncpu = glibtop_global_server->ncpu; + + glibtop_get_proc_time (&data.proc_time, pid); + + total = (unsigned long) data.proc_time.utime + + (unsigned long) data.proc_time.stime; + + p_total = total ? (double) total : 1.0; + + p_utime = (double) data.proc_time.utime * 100.0 / p_total; + p_stime = (double) data.proc_time.stime * 100.0 / p_total; + + b_total = p_total / ncpu; + b_utime = (double) data.proc_time.utime / ncpu; + b_stime = (double) data.proc_time.stime / ncpu; + + s_total = 0.0; s_utime = 0.0; s_stime = 0.0; + + printf ("Proc_Time PID %5d (0x%08lx): %12lu %12lu %12lu\n", (int) pid, + (unsigned long) data.proc_time.flags, total, + (unsigned long) data.proc_time.utime, + (unsigned long) data.proc_time.stime); + + for (i = 0; i < ncpu; i++) { + unsigned long this_total; + + this_total = (unsigned long) data.proc_time.xcpu_utime [i] + + (unsigned long) data.proc_time.xcpu_stime [i]; + + printf ("CPU %3d PID %5d (0x%08lx): %12lu %12lu %12lu\n", i, + (int) pid, (unsigned long) data.proc_time.flags, this_total, + (unsigned long) data.proc_time.xcpu_utime [i], + (unsigned long) data.proc_time.xcpu_stime [i]); + + s_total += fabs (((double) this_total) - b_total); + s_utime += fabs (((double) data.proc_time.xcpu_utime [i]) - b_utime); + s_stime += fabs (((double) data.proc_time.xcpu_stime [i]) - b_stime); + } + + printf ("\n"); + + printf ("Proc_Time PID %5d (0x%08lx): %12.3f %12.3f %12.3f\n", (int) pid, + (unsigned long) data.proc_time.flags, 100.0, p_utime, p_stime); + + for (i = 0; i < ncpu; i++) { + double this_p_total, this_p_utime, this_p_stime; + unsigned long this_total; + + this_total = (unsigned long) data.proc_time.xcpu_utime [i] + + (unsigned long) data.proc_time.xcpu_stime [i]; + + this_p_total = (double) this_total * 100.0 / p_total; + + this_p_utime = (double) data.proc_time.xcpu_utime [i] * 100.0 / p_total; + this_p_stime = (double) data.proc_time.xcpu_stime [i] * 100.0 / p_total; + + printf ("CPU %3d PID %5d (0x%08lx): %12.3f %12.3f %12.3f\n", i, + (int) pid, (unsigned long) data.proc_time.flags, + this_p_total, this_p_utime, this_p_stime); + } + + printf ("\n"); + + my_utime = (unsigned long) data.proc_time.utime ? + (double) data.proc_time.utime : 1.0; + my_stime = (unsigned long) data.proc_time.stime ? + (double) data.proc_time.stime : 1.0; + + printf ("SPIN: %31s %12.3f %12.3f %12.3f\n", "", s_total * 100.0 / p_total, + s_utime * 100.0 / my_utime, s_stime * 100.0 / my_stime); + + printf ("\n"); +#endif +} + +int +main (int argc, char *argv []) +{ + glibtop_proclist proclist; + glibtop_sysdeps sysdeps; + unsigned *ptr, pid, i; + + setlocale (LC_ALL, ""); + bindtextdomain (GETTEXT_PACKAGE, GTOPLOCALEDIR); + textdomain (GETTEXT_PACKAGE); + + glibtop_init (); + + glibtop_get_sysdeps (&sysdeps); + + printf ("Sysdeps (0x%08lx): %lu, %lu, %lu, %lu, %lu, " + "%lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu\n", + (unsigned long) sysdeps.flags, + (unsigned long) sysdeps.cpu, + (unsigned long) sysdeps.mem, + (unsigned long) sysdeps.swap, + (unsigned long) sysdeps.uptime, + (unsigned long) sysdeps.loadavg, + (unsigned long) sysdeps.shm_limits, + (unsigned long) sysdeps.msg_limits, + (unsigned long) sysdeps.sem_limits, + (unsigned long) sysdeps.proclist, + (unsigned long) sysdeps.proc_state, + (unsigned long) sysdeps.proc_uid, + (unsigned long) sysdeps.proc_mem, + (unsigned long) sysdeps.proc_time, + (unsigned long) sysdeps.proc_signal, + (unsigned long) sysdeps.proc_kernel, + (unsigned long) sysdeps.proc_segment); + + if ((argc == 2) && (sscanf (argv [1], "%d", &pid) == 1)) { + output (pid); + + exit (0); + } + + printf ("\n"); + + ptr = glibtop_get_proclist (&proclist, 0, 0); + + printf ("Proclist (0x%08lx): %lu, %lu, %lu\n", + (unsigned long) proclist.flags, + (unsigned long) proclist.number, + (unsigned long) proclist.size, + (unsigned long) proclist.total); + + if (!ptr) exit (1); + + for (i = 0; i < proclist.number; i++) { + + pid = ptr [i]; + + output (pid); + } + + glibtop_free (ptr); + + exit (0); +} + + + |