Date: Thu, 27 May 2004 14:20:40 -0400 From: Charles Swiger <cswiger@mac.com> To: Michael Sig Birkmose <michael@gisp.dk> Cc: freebsd-questions@freebsd.org Subject: Re: Measuring the stack usage of a program Message-ID: <8EF1411C-B00A-11D8-AA39-003065ABFD92@mac.com> In-Reply-To: <20040527010804.M72742@server.gisp.dk> References: <20040527010804.M72742@server.gisp.dk>
index | next in thread | previous in thread | raw e-mail
On May 26, 2004, at 7:09 PM, Michael Sig Birkmose wrote:
> Does anyone know, if it is possible to meassure the maximum stack
> usage of
> a C program throughout it's entire execution?
Sure. See "man getrusage", specificly:
long ru_isrss; /* integral unshared stack size */
...which tends to give you the maximum usage on most systems (because
they don't shrink the stack if it becomes smaller). You can also
compare the addresses of automatic variables within the code of the
program itself to see how the stack grows:
/* Test program to measure stack usage... */
void *
test_function(int count)
{
int foo = 1;
#if 0 /* make the local frame much bigger */
char buf[1000];
sprintf(buf, "%d\n", count);
#endif
if (count > 0) {
return test_function(count - 1);
} else
return &foo;
}
int
main(int argc, char *argv[])
{
int depth = 100;
unsigned long delta;
if (argc > 1) depth = atoi(argv[1]);
delta = (unsigned long)&depth - (unsigned long)test_function(depth);
printf("\nchange in stack size: %lu bytes.\n", delta);
return 0;
}
[ Yeah, yeah, I should use ptrdiff_t, but you get the idea... ]
--
-Chuck
help
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?8EF1411C-B00A-11D8-AA39-003065ABFD92>
