This is the mail archive of the
libc-alpha@sourceware.org
mailing list for the glibc project.
Re: For review: memusage(1) man page
- From: "Michael Kerrisk (man-pages)" <mtk dot manpages at gmail dot com>
- To: Jan Chaloupka <jchaloup at redhat dot com>
- Cc: mtk dot manpages at gmail dot com, linux-man at vger dot kernel dot org, libc-alpha at sourceware dot org, myllynen at redhat dot com, drepper at gmail dot com, Peter Schiffer <pschiffe at redhat dot com>
- Date: Sat, 30 Aug 2014 15:57:16 +0200
- Subject: Re: For review: memusage(1) man page
- Authentication-results: sourceware.org; auth=none
- References: <53C8E244 dot 2080901 at redhat dot com> <53CE0144 dot 7050405 at gmail dot com> <53CE0517 dot 2040005 at redhat dot com> <53CE1BC4 dot 6040707 at redhat dot com>
Hi Jan,
You resubmitted this page in the meusage(1) thread, but
it's a page for memusagestat(1). I'm getting a little
confused as I try to review these threads.
Could I ask you to create two new threads that submit
the current memusage.1 and memusagestat.1 pages.
Along the way, could you convert the keywords in the
command lines to lowercase+italic (\fI). (See for example
the current mtrace.1 in Git.)
My apologies for being so slow to follow up on this.
Thanks,
Michael
On 07/22/2014 10:07 AM, Jan Chaloupka wrote:
> Adding example with small C code to demonstrate progress of memory usage
>
> .\" Copyright (c) 2013, Peter Schiffer (pschiffe@redhat.com)
> .\"
> .\" %%%LICENSE_START(GPLv2+_DOC_FULL)
> .\" This is free documentation; 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.
> .\"
> .\" The GNU General Public License's references to "object code"
> .\" and "executables" are to be interpreted as the output of any
> .\" document formatting or typesetting system, including
> .\" intermediate and printed output.
> .\"
> .\" This manual 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 this manual; if not, see
> .\" <http://www.gnu.org/licenses/>.
> .\" %%%LICENSE_END
> .TH MEMUSAGESTAT 1 2013-04-10 "GNU glibc 2.18" "Memory diagnostic tools"
> .SH NAME
> memusagestat \- generate graphic from memory profiling data
> .SH SYNOPSIS
> .BR memusagestat " [\fIOPTION\fR]... \fIDATAFILE\fR [\fIOUTFILE\fR]"
> .SH DESCRIPTION
> .B memusagestat
> can create a PNG file with graphical representation of memory profiling
> data.
> Red line in the graph shows the heap usage (allocated memory),
> green line shows the stack usage,
> x-scale number of memory handling functions calls or time (\fB-t\fR option).
> .I DATAFILE
> is a binary data file generated by
> .BR memusage (1)
> utility with
> .B -d
> option.
> .SH OPTIONS
> .TP
> .BI \-o\ file \fR,\ \fB\-\-output= file
> Name of the output file.
> .TP
> .BI \-s\ string \fR,\ \fB\-\-string= string
> Title string used in the output graphic.
> .TP
> .BI \-t\fR,\ \fB\-\-time
> Generate output linear to time
> (default is linear to number of function calls).
> .TP
> .BI \-T\fR,\ \fB\-\-total
> Also draw graph for total memory consumption.
> .TP
> .BI \-x\ size \fR,\ \fB\-\-x-size= size
> Make graphic size pixels wide.
> .TP
> .BI \-y\ size \fR,\ \fB\-\-y\-size= size
> Make graphic size pixels high.
> .TP
> .BI \-?\fR,\ \fB\-\-help
> Print help and exit.
> .TP
> .BI \fB\-\-usage
> Print a short usage message and exit.
> .TP
> .BI \-V\fR,\ \fB\-\-version
> Print version information and exit.
> .SH EXAMPLES
> Here is a simple program \fImemusagestatexample.c\fR simulating increase
> and decrease of memory usage:
>
> .RS 4
> #include <stdio.h>
> .RS 0
> #include <stdlib.h>
> .RE
> .RS 0
> #define CYCLES 20
> .RE
>
> int main(int argc, char ** argv) {
> int i, j;
> int *p = NULL;
> printf("malloc: %d\\n", sizeof(int)*100);
> p = malloc(sizeof(int)*100);
>
> for (i = 0; i < CYCLES; i++) {
> if (i < CYCLES/2) j = i; else j--;
> printf("realloc: %d\\n", sizeof(int)*((j)*50 + 110));
> p = realloc(p, sizeof(int)*(j*50 + 100));
> printf("realloc: %d\\n", sizeof(int)*((j+1)*150 + 110));
> p = realloc(p, sizeof(int)*((j+1)*150 + 110));
> }
> free(p);
> return 0;
> .RS 0
> }
> .RE
> .RE
>
> After compiling and running the following, you can see progress of
> memory usage (memusagestatexample.png):
>
> memusage --data=memusagestatexample.dat ./memusagestatexample
> .RS 0
> memusagestat memusagestatexample.dat memusagestatexample.png
> .RE
>
> .SH BUGS
> For bug reporting instructions, please see:
> <http://www.gnu.org/software/libc/bugs.html>.
> .SH SEE ALSO
> .BR memusage (1)
>
--
Michael Kerrisk
Linux man-pages maintainer; http://www.kernel.org/doc/man-pages/
Linux/UNIX System Programming Training: http://man7.org/training/