Options for system resources.
-Hsize |
allocate a heap of specified size |
-Vsize |
allocate a stack of specified size |
-isize |
set the profiling interval to size |
Memory sizes can be given in bytes or words, and may use symbols
for Mega- and kilo-. Both upper and lower case are acceptable.
For example, 2mw (2 Megawords), 4KB (4 kilobytes). If no units are
specified, the default is bytes. A profiling interval may be given as
the number of heap allocations, or in Mega-, kilo-, or milli- seconds.
For example, 1Ms (1 Megasecond), 2ms (2 milliseconds), 1M (1 megabyte).
If no units are specified, the default is allocations.
|
Miscellaneous options.
-s | garbage collect statics |
-B | print progress info at every garbage
collection (repeating the flag increases amount of info) |
-I | turn on instruction counts
(Only if runtime system was compiled with -DINSCOUNT=1) |
-X | turn on Xlib debugging |
-t | turn on time profiling (see below) |
|
Heap profiling options.
-p |
build a producer heap profile |
-c |
build a construction heap profile |
-m |
build a module heap profile |
-r[num] |
build a retainer heap profile, with
a maximum retainer set size of num (default=1). |
-b |
build a biographical heap profile |
-l |
build a lifetime heap profile |
-pnames |
restrict profile to named producers |
-cnames |
restrict profile to named constructions |
-mnames |
restrict profile to named modules |
-rnames |
restrict profile to named retainers |
-bname |
restrict profile to named biographical phase
(lag, drag, void, or use) |
-lnums |
restrict profile to numbered lifetimes
(min-, -max, or min-max) |
-@ |
count application nodes during profiling |
-u |
print usage during profiling |
-1 |
first run (for biography/lifetime) |
-2 |
second run (for biography/lifetime) |
These options are only meaningful if the program has been compiled
for heap profiling - otherwise they are ignored. The first occurrence of
any of the options pcmrbl determines the primary form of the
profile. Subsequent pcmrbl options introduce restrictions on
the profile, for instance -p -c: asks for a producer profile
restricted to producers of the `:' (list) construction. Restrictions
are almost all orthogonal to each other, and you may have as many as
you like. Except for biography and lifetime restrictions, the format
is of a list of names, separated by commas. (In general, you may need to
use quotes around the list to protect special characters from the shell.)
The heap profile results are produced in a file named program.hp.
Use the hp2graph tool to convert this to a Postscript or FrameMaker
picture of the graph.
|
Time profiling options.
-t | turn on time profiling |
-tt |
order results by time consumed per function |
-tc |
order results by number of calls per function |
-tm |
group results by module |
-txp |
give percentage of calls as well as percentage of time consumed |
-txs |
count sub-function entries separately |
-t-Module |
show only the total for all functions in named module |
-t+Module |
show all functions separately in named module |
-t+all |
show all functions separately in all modules |
-t-all |
show only total-per-module for all modules |
These options are only meaningful if the program has been compiled for
time profiling - otherwise they are ignored. The various single-letter
flags can be aggregated together, e.g. -tmt.
You can give a list of module names separated by spaces using the
shell quoting mechanism e.g. -t"+Prelude -Main
+IO". The default is to show all functions written
by the user separately, but only show the total for library modules
(Prelude, IO, etc.).
The time profile results are produced in a file named
program.tp.
|