Blame examples/timings.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 <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/parameter.h>
Packit d37888
Packit d37888
#include <glibtop/union.h>
Packit d37888
#include <glibtop/sysdeps.h>
Packit d37888
Packit d37888
#include <sys/times.h>
Packit d37888
#include <sys/resource.h>
Packit d37888
Packit d37888
#ifndef PROFILE_COUNT
Packit d37888
#define PROFILE_COUNT			100000L
Packit d37888
#endif
Packit d37888
Packit d37888
#ifndef PROFILE_COUNT_EXPENSIVE
Packit d37888
#define PROFILE_COUNT_EXPENSIVE		(PROFILE_COUNT / 10)
Packit d37888
#endif
Packit d37888
Packit d37888
#define ELAPSED_UTIME ((unsigned long) elapsed_utime.tv_sec * 1000000 +	(unsigned long) elapsed_utime.tv_usec)
Packit d37888
#define ELAPSED_STIME ((unsigned long) elapsed_stime.tv_sec * 1000000 + (unsigned long) elapsed_stime.tv_usec)
Packit d37888
Packit d37888
#define libgtop_timeradd(tvp, uvp, vvp)						\
Packit d37888
	do {								\
Packit d37888
		(vvp)->tv_sec = (tvp)->tv_sec + (uvp)->tv_sec;		\
Packit d37888
		(vvp)->tv_usec = (tvp)->tv_usec + (uvp)->tv_usec;	\
Packit d37888
		if ((vvp)->tv_usec >= 1000000) {			\
Packit d37888
			(vvp)->tv_sec++;				\
Packit d37888
			(vvp)->tv_usec -= 1000000;			\
Packit d37888
		}							\
Packit d37888
	} while (0)
Packit d37888
#define libgtop_timersub(tvp, uvp, vvp)						\
Packit d37888
	do {								\
Packit d37888
		(vvp)->tv_sec = (tvp)->tv_sec - (uvp)->tv_sec;		\
Packit d37888
		(vvp)->tv_usec = (tvp)->tv_usec - (uvp)->tv_usec;	\
Packit d37888
		if ((vvp)->tv_usec < 0) {				\
Packit d37888
			(vvp)->tv_sec--;				\
Packit d37888
			(vvp)->tv_usec += 1000000;			\
Packit d37888
		}							\
Packit d37888
	} while (0)
Packit d37888
Packit d37888
Packit d37888
static void display_self_times(void)
Packit d37888
{
Packit d37888
	printf("-- Overview using `ps` --------------------"
Packit d37888
	       "---------------\n");
Packit d37888
	printf("-- this client is %8u ----------------"
Packit d37888
	       "---------------\n", (unsigned)getpid());
Packit d37888
	printf("-- this server is %8u ----------------"
Packit d37888
	       "---------------\n", (unsigned)glibtop_global_server->pid);
Packit d37888
	system("ps xjf | egrep 'timings|libgtop_server'");
Packit d37888
	printf("-------------------------------------------"
Packit d37888
	       "---------------\n");
Packit d37888
}
Packit d37888
Packit d37888
Packit d37888
int
Packit d37888
main (int argc, char *argv [])
Packit d37888
{
Packit d37888
	glibtop_union data;
Packit d37888
	unsigned c;
Packit d37888
	struct rusage total_start, total_end;
Packit d37888
	struct rusage rusage_start, rusage_end;
Packit d37888
	struct timeval elapsed_utime, elapsed_stime;
Packit d37888
	pid_t pid;
Packit d37888
Packit d37888
	pid = getpid ();
Packit d37888
Packit d37888
	setlocale (LC_ALL, "");
Packit d37888
	bindtextdomain (GETTEXT_PACKAGE, GTOPLOCALEDIR);
Packit d37888
	textdomain (GETTEXT_PACKAGE);
Packit d37888
Packit d37888
Packit d37888
	glibtop_init_r (&glibtop_global_server, 0, 0);
Packit d37888
Packit d37888
	display_self_times();
Packit d37888
Packit d37888
	printf ("%-12s (%-10s): %7s - %9s - %9s\n",
Packit d37888
		"Feature", "Flags", "Count", "utime", "stime");
Packit d37888
	printf ("-------------------------------------------"
Packit d37888
		"---------------\n");
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &total_start);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_cpu (&data.cpu);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("CPU          (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.cpu.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++)
Packit d37888
		glibtop_get_mem (&data.mem);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Memory       (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.mem.flags, PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++)
Packit d37888
		glibtop_get_swap (&data.swap);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Swap         (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.swap.flags, PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_uptime (&data.uptime);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Uptime       (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.uptime.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_loadavg (&data.loadavg);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Loadavg      (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.loadavg.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++) {
Packit d37888
		pid_t* ptr = glibtop_get_proclist (&data.proclist, 0, 0);
Packit d37888
		g_free (ptr);
Packit d37888
	}
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proclist     (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proclist.flags,
Packit d37888
		PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++) {
Packit d37888
		char** ptr = glibtop_get_netlist (&data.netlist);
Packit d37888
		g_strfreev (ptr);
Packit d37888
	}
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Netlist      (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proclist.flags,
Packit d37888
		PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_proc_state (&data.proc_state, pid);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_State   (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_state.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_proc_uid (&data.proc_uid, pid);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Uid     (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_uid.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_proc_mem (&data.proc_mem, pid);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Mem     (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_mem.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT_EXPENSIVE; c++) {
Packit d37888
		glibtop_map_entry* entries;
Packit d37888
		entries = glibtop_get_proc_map (&data.proc_map, pid);
Packit d37888
		g_free (entries);
Packit d37888
	}
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Map     (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_map.flags, PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT_EXPENSIVE,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT_EXPENSIVE);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_proc_segment (&data.proc_segment, pid);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Segment (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_segment.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++) {
Packit d37888
		char** argv;
Packit d37888
		argv = glibtop_get_proc_argv (&data.proc_args, pid, 0);
Packit d37888
		g_strfreev(argv);
Packit d37888
	}
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Args    (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_args.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_proc_time (&data.proc_time, pid);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Time    (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_time.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_proc_signal (&data.proc_signal, pid);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Signal  (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_signal.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_proc_kernel (&data.proc_kernel, pid);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Kernel  (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_kernel.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_start);
Packit d37888
Packit d37888
	for (c = 0; c < PROFILE_COUNT; c++)
Packit d37888
		glibtop_get_proc_io (&data.proc_io, pid);
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &rusage_end);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_utime, &rusage_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&rusage_end.ru_stime, &rusage_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("Proc_Io  (0x%08lx): %7lu - %9.2Lf - %9.2Lf\n",
Packit d37888
		(unsigned long) data.proc_io.flags, PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_UTIME / PROFILE_COUNT,
Packit d37888
		(long double) ELAPSED_STIME / PROFILE_COUNT);
Packit d37888
Packit d37888
Packit d37888
	getrusage (RUSAGE_SELF, &total_end);
Packit d37888
Packit d37888
	libgtop_timersub (&total_end.ru_utime, &total_start.ru_utime,
Packit d37888
			  &elapsed_utime);
Packit d37888
Packit d37888
	libgtop_timersub (&total_end.ru_stime, &total_start.ru_stime,
Packit d37888
			  &elapsed_stime);
Packit d37888
Packit d37888
	printf ("-------------------------------------------"
Packit d37888
		"---------------\n");
Packit d37888
Packit d37888
	printf ("%-36s %9lu - %9lu\n\n", "TOTAL",
Packit d37888
		ELAPSED_UTIME, ELAPSED_STIME);
Packit d37888
Packit d37888
	printf ("All timings are in clock ticks "
Packit d37888
		"(1000000 ticks per second).\n\n");
Packit d37888
Packit d37888
	display_self_times();
Packit d37888
Packit d37888
	glibtop_close ();
Packit d37888
Packit d37888
	exit (0);
Packit d37888
}