Blame examples/timings.c

Packit Service 407539
/* Copyright (C) 1998-99 Martin Baulig
Packit Service 407539
   This file is part of LibGTop 1.0.
Packit Service 407539
Packit Service 407539
   Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
Packit Service 407539
Packit Service 407539
   LibGTop is free software; you can redistribute it and/or modify it
Packit Service 407539
   under the terms of the GNU General Public License as published by
Packit Service 407539
   the Free Software Foundation; either version 2 of the License,
Packit Service 407539
   or (at your option) any later version.
Packit Service 407539
Packit Service 407539
   LibGTop is distributed in the hope that it will be useful, but WITHOUT
Packit Service 407539
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
Packit Service 407539
   FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit Service 407539
   for more details.
Packit Service 407539
Packit Service 407539
   You should have received a copy of the GNU General Public License
Packit Service 407539
   along with LibGTop; see the file COPYING. If not, write to the
Packit Service 407539
   Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Packit Service 407539
   Boston, MA 02110-1301, USA.
Packit Service 407539
*/
Packit Service 407539
Packit Service 407539
#ifdef HAVE_CONFIG_H
Packit Service 407539
#  include <config.h>
Packit Service 407539
#endif
Packit Service 407539
Packit Service 407539
#include <locale.h>
Packit Service 407539
#include <stdio.h>
Packit Service 407539
#include <libintl.h>
Packit Service 407539
Packit Service 407539
#include <glibtop.h>
Packit Service 407539
#include <glibtop/open.h>
Packit Service 407539
#include <glibtop/close.h>
Packit Service 407539
Packit Service 407539
#include <glibtop/parameter.h>
Packit Service 407539
Packit Service 407539
#include <glibtop/union.h>
Packit Service 407539
#include <glibtop/sysdeps.h>
Packit Service 407539
Packit Service 407539
#include <sys/times.h>
Packit Service 407539
#include <sys/resource.h>
Packit Service 407539
Packit Service 407539
#ifndef PROFILE_COUNT
Packit Service 407539
#define PROFILE_COUNT			100000L
Packit Service 407539
#endif
Packit Service 407539
Packit Service 407539
#ifndef PROFILE_COUNT_EXPENSIVE
Packit Service 407539
#define PROFILE_COUNT_EXPENSIVE		(PROFILE_COUNT / 10)
Packit Service 407539
#endif
Packit Service 407539
Packit Service 407539
#define ELAPSED_UTIME ((unsigned long) elapsed_utime.tv_sec * 1000000 +	(unsigned long) elapsed_utime.tv_usec)
Packit Service 407539
#define ELAPSED_STIME ((unsigned long) elapsed_stime.tv_sec * 1000000 + (unsigned long) elapsed_stime.tv_usec)
Packit Service 407539
Packit Service 407539
#define libgtop_timeradd(tvp, uvp, vvp)						\
Packit Service 407539
	do {								\
Packit Service 407539
		(vvp)->tv_sec = (tvp)->tv_sec + (uvp)->tv_sec;		\
Packit Service 407539
		(vvp)->tv_usec = (tvp)->tv_usec + (uvp)->tv_usec;	\
Packit Service 407539
		if ((vvp)->tv_usec >= 1000000) {			\
Packit Service 407539
			(vvp)->tv_sec++;				\
Packit Service 407539
			(vvp)->tv_usec -= 1000000;			\
Packit Service 407539
		}							\
Packit Service 407539
	} while (0)
Packit Service 407539
#define libgtop_timersub(tvp, uvp, vvp)						\
Packit Service 407539
	do {								\
Packit Service 407539
		(vvp)->tv_sec = (tvp)->tv_sec - (uvp)->tv_sec;		\
Packit Service 407539
		(vvp)->tv_usec = (tvp)->tv_usec - (uvp)->tv_usec;	\
Packit Service 407539
		if ((vvp)->tv_usec < 0) {				\
Packit Service 407539
			(vvp)->tv_sec--;				\
Packit Service 407539
			(vvp)->tv_usec += 1000000;			\
Packit Service 407539
		}							\
Packit Service 407539
	} while (0)
Packit Service 407539
Packit Service 407539
Packit Service 407539
static void display_self_times(void)
Packit Service 407539
{
Packit Service 407539
	printf("-- Overview using `ps` --------------------"
Packit Service 407539
	       "---------------\n");
Packit Service 407539
	printf("-- this client is %8u ----------------"
Packit Service 407539
	       "---------------\n", (unsigned)getpid());
Packit Service 407539
	printf("-- this server is %8u ----------------"
Packit Service 407539
	       "---------------\n", (unsigned)glibtop_global_server->pid);
Packit Service 407539
	system("ps xjf | egrep 'timings|libgtop_server'");
Packit Service 407539
	printf("-------------------------------------------"
Packit Service 407539
	       "---------------\n");
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
Packit Service 407539
int
Packit Service 407539
main (int argc, char *argv [])
Packit Service 407539
{
Packit Service 407539
	glibtop_union data;
Packit Service 407539
	unsigned c;
Packit Service 407539
	struct rusage total_start, total_end;
Packit Service 407539
	struct rusage rusage_start, rusage_end;
Packit Service 407539
	struct timeval elapsed_utime, elapsed_stime;
Packit Service 407539
	pid_t pid;
Packit Service 407539
Packit Service 407539
	pid = getpid ();
Packit Service 407539
Packit Service 407539
	setlocale (LC_ALL, "");
Packit Service 407539
	bindtextdomain (GETTEXT_PACKAGE, GTOPLOCALEDIR);
Packit Service 407539
	textdomain (GETTEXT_PACKAGE);
Packit Service 407539
Packit Service 407539
Packit Service 407539
	glibtop_init_r (&glibtop_global_server, 0, 0);
Packit Service 407539
Packit Service 407539
	display_self_times();
Packit Service 407539
Packit Service 407539
	printf ("%-12s (%-10s): %7s - %9s - %9s\n",
Packit Service 407539
		"Feature", "Flags", "Count", "utime", "stime");
Packit Service 407539
	printf ("-------------------------------------------"
Packit Service 407539
		"---------------\n");
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &total_start);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_cpu (&data.cpu);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("CPU          (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.cpu.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++)
Packit Service 407539
		glibtop_get_mem (&data.mem);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Memory       (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.mem.flags, PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++)
Packit Service 407539
		glibtop_get_swap (&data.swap);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Swap         (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.swap.flags, PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_uptime (&data.uptime);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Uptime       (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.uptime.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_loadavg (&data.loadavg);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Loadavg      (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.loadavg.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++) {
Packit Service 407539
		pid_t* ptr = glibtop_get_proclist (&data.proclist, 0, 0);
Packit Service 407539
		g_free (ptr);
Packit Service 407539
	}
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proclist     (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proclist.flags,
Packit Service 407539
		PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++) {
Packit Service 407539
		char** ptr = glibtop_get_netlist (&data.netlist);
Packit Service 407539
		g_strfreev (ptr);
Packit Service 407539
	}
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Netlist      (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proclist.flags,
Packit Service 407539
		PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_proc_state (&data.proc_state, pid);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_State   (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_state.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_proc_uid (&data.proc_uid, pid);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Uid     (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_uid.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_proc_mem (&data.proc_mem, pid);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Mem     (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_mem.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++) {
Packit Service 407539
		glibtop_map_entry* entries;
Packit Service 407539
		entries = glibtop_get_proc_map (&data.proc_map, pid);
Packit Service 407539
		g_free (entries);
Packit Service 407539
	}
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Map     (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_map.flags, PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_proc_segment (&data.proc_segment, pid);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Segment (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_segment.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++) {
Packit Service 407539
		char** argv;
Packit Service 407539
		argv = glibtop_get_proc_argv (&data.proc_args, pid, 0);
Packit Service 407539
		g_strfreev(argv);
Packit Service 407539
	}
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Args    (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_args.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_proc_time (&data.proc_time, pid);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Time    (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_time.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_proc_signal (&data.proc_signal, pid);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Signal  (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_signal.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_proc_kernel (&data.proc_kernel, pid);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Kernel  (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_kernel.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_start);
Packit Service 407539
Packit Service 407539
	for (c = 0; c < PROFILE_COUNT; c++)
Packit Service 407539
		glibtop_get_proc_io (&data.proc_io, pid);
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &rusage_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("Proc_Io  (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit Service 407539
		(unsigned long) data.proc_io.flags, PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit Service 407539
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit Service 407539
Packit Service 407539
Packit Service 407539
	getrusage (RUSAGE_SELF, &total_end);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&total_end.ru_utime, &total_start.ru_utime,
Packit Service 407539
			  &elapsed_utime);
Packit Service 407539
Packit Service 407539
	libgtop_timersub (&total_end.ru_stime, &total_start.ru_stime,
Packit Service 407539
			  &elapsed_stime);
Packit Service 407539
Packit Service 407539
	printf ("-------------------------------------------"
Packit Service 407539
		"---------------\n");
Packit Service 407539
Packit Service 407539
	printf ("%-36s %9lu - %9lu\n\n", "TOTAL",
Packit Service 407539
		ELAPSED_UTIME, ELAPSED_STIME);
Packit Service 407539
Packit Service 407539
	printf ("All timings are in clock ticks "
Packit Service 407539
		"(1000000 ticks per second).\n\n");
Packit Service 407539
Packit Service 407539
	display_self_times();
Packit Service 407539
Packit Service 407539
	glibtop_close ();
Packit Service 407539
Packit Service 407539
	exit (0);
Packit Service 407539
}