2001-09-16 06:29:00 +04:00
|
|
|
.\" $NetBSD: moncontrol.3,v 1.7 2001/09/16 02:29:00 wiz Exp $
|
1995-02-27 15:54:33 +03:00
|
|
|
.\"
|
1994-05-14 10:02:57 +04:00
|
|
|
.\" Copyright (c) 1980, 1991, 1992, 1993
|
|
|
|
.\" The Regents of the University of California. All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\" 3. All advertising materials mentioning features or use of this software
|
|
|
|
.\" must display the following acknowledgement:
|
|
|
|
.\" This product includes software developed by the University of
|
|
|
|
.\" California, Berkeley and its contributors.
|
|
|
|
.\" 4. Neither the name of the University nor the names of its contributors
|
|
|
|
.\" may be used to endorse or promote products derived from this software
|
|
|
|
.\" without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
1995-02-27 15:54:33 +03:00
|
|
|
.\" @(#)moncontrol.3 8.1 (Berkeley) 6/4/93
|
1994-05-14 10:02:57 +04:00
|
|
|
.\"
|
|
|
|
.Dd June 4, 1993
|
|
|
|
.Dt MONCONTROL 3
|
1999-03-22 22:44:33 +03:00
|
|
|
.Os
|
1994-05-14 10:02:57 +04:00
|
|
|
.Sh NAME
|
|
|
|
.Nm moncontrol ,
|
|
|
|
.Nm monstartup
|
|
|
|
.Nd control execution profile
|
1998-02-05 21:45:17 +03:00
|
|
|
.Sh LIBRARY
|
|
|
|
.Lb libc
|
1994-05-14 10:02:57 +04:00
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Fn moncontrol "int mode"
|
|
|
|
.Fn monstartup "u_long *lowpc" "u_long *highpc"
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
An executable program compiled using the
|
|
|
|
.Fl pg
|
|
|
|
option to
|
|
|
|
.Xr cc 1
|
|
|
|
automatically includes calls to collect statistics for the
|
|
|
|
.Xr gprof 1
|
|
|
|
call-graph execution profiler.
|
|
|
|
In typical operation, profiling begins at program startup
|
|
|
|
and ends when the program calls exit.
|
|
|
|
When the program exits, the profiling data are written to the file
|
|
|
|
.Em gmon.out ,
|
|
|
|
then
|
|
|
|
.Xr gprof 1
|
|
|
|
can be used to examine the results.
|
|
|
|
.Pp
|
|
|
|
.Fn moncontrol
|
|
|
|
selectively controls profiling within a program.
|
|
|
|
When the program starts, profiling begins.
|
|
|
|
To stop the collection of histogram ticks and call counts use
|
|
|
|
.Fn moncontrol 0 ;
|
|
|
|
to resume the collection of histogram ticks and call counts use
|
|
|
|
.Fn moncontrol 1 .
|
|
|
|
This feature allows the cost of particular operations to be measured.
|
|
|
|
Note that an output file will be produced on program exit
|
2001-09-16 06:29:00 +04:00
|
|
|
regardless of the state of
|
1994-05-14 10:02:57 +04:00
|
|
|
.Fn moncontrol .
|
|
|
|
.Pp
|
|
|
|
Programs that are not loaded with
|
|
|
|
.Fl pg
|
|
|
|
may selectively collect profiling statistics by calling
|
|
|
|
.Fn monstartup
|
|
|
|
with the range of addresses to be profiled.
|
|
|
|
.Fa lowpc
|
|
|
|
and
|
|
|
|
.Fa highpc
|
|
|
|
specify the address range that is to be sampled;
|
|
|
|
the lowest address sampled is that of
|
|
|
|
.Fa lowpc
|
|
|
|
and the highest is just below
|
|
|
|
.Fa highpc .
|
2001-09-16 06:29:00 +04:00
|
|
|
Only functions in that range that have been compiled with the
|
1994-05-14 10:02:57 +04:00
|
|
|
.Fl pg
|
|
|
|
option to
|
|
|
|
.Xr cc 1
|
|
|
|
will appear in the call graph part of the output;
|
|
|
|
however, all functions in that address range will
|
|
|
|
have their execution time measured.
|
|
|
|
Profiling begins on return from
|
|
|
|
.Fn monstartup .
|
2000-10-24 23:31:59 +04:00
|
|
|
.Sh ENVIRONMENT
|
|
|
|
.Bl -tag -width "PROFDIR"
|
|
|
|
.It Ev PROFDIR
|
|
|
|
Directory to place the output file(s) in. When this is set, instead of
|
|
|
|
writing the profiling output to gmon.out, a filename is generated from
|
|
|
|
the process id and name of the program. (e.g. 123.a.out) If you are
|
|
|
|
profiling a program that forks, or otherwise creates multiple copies,
|
|
|
|
setting this is the only reasonable way to get all profiling data.
|
|
|
|
.El
|
2001-09-16 06:29:00 +04:00
|
|
|
.Sh FILES
|
|
|
|
.Bl -tag -width Pa -compact
|
|
|
|
.It Pa gmon.out execution data file
|
|
|
|
.El
|
1994-05-14 10:02:57 +04:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr cc 1 ,
|
|
|
|
.Xr gprof 1 ,
|
|
|
|
.Xr profil 2
|