Blame examples/second.c

Packit d37888
/* Copyright (C) 1998-99 Martin Baulig
Packit d37888
   This file is part of LibGTop 1.0.
Packit d37888
Packit d37888
   Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
Packit d37888
Packit d37888
   LibGTop is free software; you can redistribute it and/or modify it
Packit d37888
   under the terms of the GNU General Public License as published by
Packit d37888
   the Free Software Foundation; either version 2 of the License,
Packit d37888
   or (at your option) any later version.
Packit d37888
Packit d37888
   LibGTop is distributed in the hope that it will be useful, but WITHOUT
Packit d37888
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
Packit d37888
   FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit d37888
   for more details.
Packit d37888
Packit d37888
   You should have received a copy of the GNU General Public License
Packit d37888
   along with LibGTop; see the file COPYING. If not, write to the
Packit d37888
   Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Packit d37888
   Boston, MA 02110-1301, USA.
Packit d37888
*/
Packit d37888
Packit d37888
#ifdef HAVE_CONFIG_H
Packit d37888
#  include <config.h>
Packit d37888
#endif
Packit d37888
Packit d37888
#include <locale.h>
Packit d37888
#include <math.h>
Packit d37888
#include <stdio.h>
Packit d37888
#include <libintl.h>
Packit d37888
Packit d37888
#include <glibtop.h>
Packit d37888
#include <glibtop/open.h>
Packit d37888
#include <glibtop/close.h>
Packit d37888
Packit d37888
#include <glibtop/union.h>
Packit d37888
#include <glibtop/sysdeps.h>
Packit d37888
Packit d37888
static void
Packit d37888
output (pid_t pid)
Packit d37888
{
Packit d37888
	glibtop_union data;
Packit d37888
	char *args;
Packit d37888
	unsigned i;
Packit d37888
Packit d37888
	unsigned long total;
Packit d37888
	double p_total, p_utime, p_stime;
Packit d37888
	double b_total, b_utime, b_stime;
Packit d37888
	double s_total, s_utime, s_stime;
Packit d37888
	double my_utime, my_stime;
Packit d37888
	unsigned int ncpu;
Packit d37888
Packit d37888
	printf ("\n");
Packit d37888
Packit d37888
	glibtop_get_proc_state (&data.proc_state, pid);
Packit d37888
Packit d37888
	printf ("Proc_State   PID  %5d (0x%08lx): "
Packit d37888
		"'%s', %c, %lu, %lu\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_state.flags,
Packit d37888
		data.proc_state.cmd, data.proc_state.state,
Packit d37888
		(unsigned long) data.proc_state.uid,
Packit d37888
		(unsigned long) data.proc_state.gid);
Packit d37888
Packit d37888
	glibtop_get_proc_uid (&data.proc_uid, pid);
Packit d37888
Packit d37888
	printf ("Proc_Uid     PID  %5d (0x%08lx): "
Packit d37888
		"%d %d %d %d %d %d %d %d %d %d %d %d\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_uid.flags,
Packit d37888
		data.proc_uid.uid, data.proc_uid.euid,
Packit d37888
		data.proc_uid.gid, data.proc_uid.egid,
Packit d37888
		data.proc_uid.pid, data.proc_uid.ppid,
Packit d37888
		data.proc_uid.pgrp, data.proc_uid.session,
Packit d37888
		data.proc_uid.tty, data.proc_uid.tpgid,
Packit d37888
		data.proc_uid.priority, data.proc_uid.nice);
Packit d37888
Packit d37888
	glibtop_get_proc_mem (&data.proc_mem, pid);
Packit d37888
Packit d37888
	printf ("Proc_Mem     PID  %5d (0x%08lx): "
Packit d37888
		"%lu %lu %lu %lu %lu %lu\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_mem.flags,
Packit d37888
		(unsigned long) data.proc_mem.size,
Packit d37888
		(unsigned long) data.proc_mem.vsize,
Packit d37888
		(unsigned long) data.proc_mem.resident,
Packit d37888
		(unsigned long) data.proc_mem.share,
Packit d37888
		(unsigned long) data.proc_mem.rss,
Packit d37888
		(unsigned long) data.proc_mem.rss_rlim);
Packit d37888
Packit d37888
	glibtop_get_proc_segment (&data.proc_segment, pid);
Packit d37888
Packit d37888
	printf ("Proc_Segment PID  %5d (0x%08lx): "
Packit d37888
		"%lu %lu %lu %lu %lu %lu %lu %lu\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_segment.flags,
Packit d37888
		(unsigned long) data.proc_segment.text_rss,
Packit d37888
		(unsigned long) data.proc_segment.shlib_rss,
Packit d37888
		(unsigned long) data.proc_segment.data_rss,
Packit d37888
		(unsigned long) data.proc_segment.stack_rss,
Packit d37888
		(unsigned long) data.proc_segment.dirty_size,
Packit d37888
		(unsigned long) data.proc_segment.start_code,
Packit d37888
		(unsigned long) data.proc_segment.end_code,
Packit d37888
		(unsigned long) data.proc_segment.start_stack);
Packit d37888
Packit d37888
	glibtop_get_proc_time (&data.proc_time, pid);
Packit d37888
Packit d37888
	printf ("Proc_Time    PID  %5d (0x%08lx): "
Packit d37888
		"%lu %lu %lu %lu %lu %lu %lu %lu %lu\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_time.flags,
Packit d37888
		(unsigned long) data.proc_time.start_time,
Packit d37888
		(unsigned long) data.proc_time.rtime,
Packit d37888
		(unsigned long) data.proc_time.utime,
Packit d37888
		(unsigned long) data.proc_time.stime,
Packit d37888
		(unsigned long) data.proc_time.cutime,
Packit d37888
		(unsigned long) data.proc_time.cstime,
Packit d37888
		(unsigned long) data.proc_time.timeout,
Packit d37888
		(unsigned long) data.proc_time.it_real_value,
Packit d37888
		(unsigned long) data.proc_time.frequency);
Packit d37888
Packit d37888
	glibtop_get_proc_signal (&data.proc_signal, pid);
Packit d37888
Packit d37888
	printf ("Proc_Signal  PID  %5d (0x%08lx): "
Packit d37888
		"%lu %lu %lu %lu\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_signal.flags,
Packit d37888
		(unsigned long) data.proc_signal.signal,
Packit d37888
		(unsigned long) data.proc_signal.blocked,
Packit d37888
		(unsigned long) data.proc_signal.sigignore,
Packit d37888
		(unsigned long) data.proc_signal.sigcatch);
Packit d37888
Packit d37888
	glibtop_get_proc_kernel (&data.proc_kernel, pid);
Packit d37888
Packit d37888
	printf ("Proc_Kernel  PID  %5d (0x%08lx): "
Packit d37888
		"%lu %lu %lu %lu %lu 0x%lx 0x%lx 0x%lx (%s)\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_kernel.flags,
Packit d37888
		(unsigned long) data.proc_kernel.k_flags,
Packit d37888
		(unsigned long) data.proc_kernel.min_flt,
Packit d37888
		(unsigned long) data.proc_kernel.maj_flt,
Packit d37888
		(unsigned long) data.proc_kernel.cmin_flt,
Packit d37888
		(unsigned long) data.proc_kernel.cmaj_flt,
Packit d37888
		(unsigned long) data.proc_kernel.kstk_esp,
Packit d37888
		(unsigned long) data.proc_kernel.kstk_eip,
Packit d37888
		(unsigned long) data.proc_kernel.nwchan,
Packit d37888
		data.proc_kernel.wchan);
Packit d37888
Packit d37888
	printf ("\n");
Packit d37888
Packit d37888
	args = glibtop_get_proc_args (&data.proc_args, pid, 0);
Packit d37888
Packit d37888
	for (i = 0; i < data.proc_args.size; i++) {
Packit d37888
		if (args [i]) continue;
Packit d37888
		args [i] = '|';
Packit d37888
	}
Packit d37888
Packit d37888
	printf ("Proc_Args    PID  %5d (0x%08lx): %lu - '%s'\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_args.flags,
Packit d37888
		(unsigned long) data.proc_args.size,
Packit d37888
		args ? args : "");
Packit d37888
Packit d37888
	g_free (args);
Packit d37888
Packit d37888
	printf ("\n");
Packit d37888
Packit d37888
	ncpu = glibtop_global_server->ncpu;
Packit d37888
Packit d37888
	glibtop_get_proc_time (&data.proc_time, pid);
Packit d37888
Packit d37888
	total = (unsigned long) data.proc_time.utime +
Packit d37888
		(unsigned long) data.proc_time.stime;
Packit d37888
Packit d37888
	p_total = total ? (double) total : 1.0;
Packit d37888
Packit d37888
	p_utime = (double) data.proc_time.utime * 100.0 / p_total;
Packit d37888
	p_stime = (double) data.proc_time.stime * 100.0 / p_total;
Packit d37888
Packit d37888
	b_total = p_total / ncpu;
Packit d37888
	b_utime = (double) data.proc_time.utime / ncpu;
Packit d37888
	b_stime = (double) data.proc_time.stime / ncpu;
Packit d37888
Packit d37888
	s_total = 0.0; s_utime = 0.0; s_stime = 0.0;
Packit d37888
Packit d37888
	printf ("Proc_Time    PID  %5d (0x%08lx): %12lu   %12lu   %12lu\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_time.flags, total,
Packit d37888
		(unsigned long) data.proc_time.utime,
Packit d37888
		(unsigned long) data.proc_time.stime);
Packit d37888
Packit d37888
	for (i = 0; i < ncpu; i++) {
Packit d37888
		unsigned long this_total;
Packit d37888
Packit d37888
		this_total = (unsigned long) data.proc_time.xcpu_utime [i] +
Packit d37888
			(unsigned long) data.proc_time.xcpu_stime [i];
Packit d37888
Packit d37888
		printf ("CPU %3d      PID  %5d (0x%08lx): %12lu   %12lu   %12lu\n", i,
Packit d37888
			(int) pid, (unsigned long) data.proc_time.flags, this_total,
Packit d37888
			(unsigned long) data.proc_time.xcpu_utime [i],
Packit d37888
			(unsigned long) data.proc_time.xcpu_stime [i]);
Packit d37888
Packit d37888
		s_total += fabs (((double) this_total) - b_total);
Packit d37888
		s_utime += fabs (((double) data.proc_time.xcpu_utime [i]) - b_utime);
Packit d37888
		s_stime += fabs (((double) data.proc_time.xcpu_stime [i]) - b_stime);
Packit d37888
	}
Packit d37888
Packit d37888
	printf ("\n");
Packit d37888
Packit d37888
	printf ("Proc_Time    PID  %5d (0x%08lx): %12.3f   %12.3f   %12.3f\n", (int) pid,
Packit d37888
		(unsigned long) data.proc_time.flags, 100.0, p_utime, p_stime);
Packit d37888
Packit d37888
	for (i = 0; i < ncpu; i++) {
Packit d37888
		double this_p_total, this_p_utime, this_p_stime;
Packit d37888
		unsigned long this_total;
Packit d37888
Packit d37888
		this_total = (unsigned long) data.proc_time.xcpu_utime [i] +
Packit d37888
			(unsigned long) data.proc_time.xcpu_stime [i];
Packit d37888
Packit d37888
		this_p_total = (double) this_total * 100.0 / p_total;
Packit d37888
Packit d37888
		this_p_utime = (double) data.proc_time.xcpu_utime [i] * 100.0 / p_total;
Packit d37888
		this_p_stime = (double) data.proc_time.xcpu_stime [i] * 100.0 / p_total;
Packit d37888
Packit d37888
		printf ("CPU %3d      PID  %5d (0x%08lx): %12.3f   %12.3f   %12.3f\n", i,
Packit d37888
			(int) pid, (unsigned long) data.proc_time.flags,
Packit d37888
			this_p_total, this_p_utime, this_p_stime);
Packit d37888
	}
Packit d37888
Packit d37888
	printf ("\n");
Packit d37888
Packit d37888
	my_utime = (unsigned long) data.proc_time.utime ?
Packit d37888
		(double) data.proc_time.utime : 1.0;
Packit d37888
	my_stime = (unsigned long) data.proc_time.stime ?
Packit d37888
		(double) data.proc_time.stime : 1.0;
Packit d37888
Packit d37888
	printf ("SPIN: %31s %12.3f   %12.3f   %12.3f\n", "", s_total * 100.0 / p_total,
Packit d37888
		s_utime * 100.0 / my_utime, s_stime * 100.0 / my_stime);
Packit d37888
Packit d37888
	printf ("\n");
Packit d37888
}
Packit d37888
Packit d37888
int
Packit d37888
main (int argc, char *argv [])
Packit d37888
{
Packit d37888
	glibtop_proclist proclist;
Packit d37888
	glibtop_sysdeps sysdeps;
Packit d37888
	unsigned i;
Packit d37888
	pid_t *ptr, pid;
Packit d37888
Packit d37888
	setlocale (LC_ALL, "");
Packit d37888
	bindtextdomain (GETTEXT_PACKAGE, GTOPLOCALEDIR);
Packit d37888
	textdomain (GETTEXT_PACKAGE);
Packit d37888
Packit d37888
	glibtop_init ();
Packit d37888
Packit d37888
	glibtop_get_sysdeps (&sysdeps);
Packit d37888
Packit d37888
	printf ("Sysdeps      (0x%08lx): %lu, %lu, %lu, %lu, %lu, "
Packit d37888
		"%lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu, %lu\n",
Packit d37888
		(unsigned long) sysdeps.flags,
Packit d37888
		(unsigned long) sysdeps.cpu,
Packit d37888
		(unsigned long) sysdeps.mem,
Packit d37888
		(unsigned long) sysdeps.swap,
Packit d37888
		(unsigned long) sysdeps.uptime,
Packit d37888
		(unsigned long) sysdeps.loadavg,
Packit d37888
		(unsigned long) sysdeps.shm_limits,
Packit d37888
		(unsigned long) sysdeps.msg_limits,
Packit d37888
		(unsigned long) sysdeps.sem_limits,
Packit d37888
		(unsigned long) sysdeps.proclist,
Packit d37888
		(unsigned long) sysdeps.proc_state,
Packit d37888
		(unsigned long) sysdeps.proc_uid,
Packit d37888
		(unsigned long) sysdeps.proc_mem,
Packit d37888
		(unsigned long) sysdeps.proc_time,
Packit d37888
		(unsigned long) sysdeps.proc_signal,
Packit d37888
		(unsigned long) sysdeps.proc_kernel,
Packit d37888
		(unsigned long) sysdeps.proc_segment);
Packit d37888
Packit d37888
	if ((argc == 2) && (sscanf (argv [1], "%d", &pid) == 1)) {
Packit d37888
		output (pid);
Packit d37888
Packit d37888
		exit (0);
Packit d37888
	}
Packit d37888
Packit d37888
	printf ("\n");
Packit d37888
Packit d37888
	ptr = glibtop_get_proclist (&proclist, 0, 0);
Packit d37888
Packit d37888
	printf ("Proclist     (0x%08lx): %lu, %lu, %lu\n",
Packit d37888
		(unsigned long) proclist.flags,
Packit d37888
		(unsigned long) proclist.number,
Packit d37888
		(unsigned long) proclist.size,
Packit d37888
		(unsigned long) proclist.total);
Packit d37888
Packit d37888
	if (!ptr) exit (1);
Packit d37888
Packit d37888
	for (i = 0; i < proclist.number; i++) {
Packit d37888
Packit d37888
		pid = ptr [i];
Packit d37888
Packit d37888
		output (pid);
Packit d37888
	}
Packit d37888
Packit d37888
	g_free (ptr);
Packit d37888
Packit d37888
	exit (0);
Packit d37888
}
Packit d37888
Packit d37888
Packit d37888