]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/commit
Improved non-statistical (GUPROF) profiling:
authorBruce Evans <bde@FreeBSD.org>
Thu, 17 Oct 1996 19:32:31 +0000 (19:32 +0000)
committerBruce Evans <bde@FreeBSD.org>
Thu, 17 Oct 1996 19:32:31 +0000 (19:32 +0000)
commitd6b9e17eb5a1ed2922bd5264a1afd046c0038d6b
tree2f3c01bb1684b82e42c63c0a17d658ba5ded662b
parentcf3c4df72dbd3a64cccf5064b546f0116502ff57
Improved non-statistical (GUPROF) profiling:
- use a more accurate and more efficient method of compensating for
  overheads.  The old method counted too much time against leaf
  functions.
- normally use the Pentium timestamp counter if available.
  On Pentiums, the times are now accurate to within a couple of cpu
  clock cycles per function call in the (unlikely) event that there
  are no cache misses in or caused by the profiling code.
- optionally use an arbitrary Pentium event counter if available.
- optionally regress to using the i8254 counter.
- scaled the i8254 counter by a factor of 128.  Now the i8254 counters
  overflow slightly faster than the TSC counters for a 150MHz Pentium :-)
  (after about 16 seconds).  This is to avoid fractional overheads.

files.i386:
permon.c temporarily has to be classified as a profiling-routine
because a couple of functions in it may be called from profiling code.

options.i386:
- I586_CTR_GUPROF is currently unused (oops).
- I586_PMC_GUPROF should be something like 0x70000 to enable (but not
  use unless prof_machdep.c is changed) support for Pentium event
  counters.  7 is a control mode and the counter number 0 is somewhere
  in the 0000 bits (see perfmon.h for the encoding).

profile.h:
- added declarations.
- cleaned up separation of user mode declarations.

prof_machdep.c:
Mostly clock-select changes.  The default clock can be changed by
editing kmem.  There should be a sysctl for this.

subr_prof.c:
- added copyright.
- calibrate overheads for the new method.
- documented new method.
- fixed races and and machine dependencies in start/stop code.

mcount.c:
Use the new overhead compensation method.

gmon.h:
- changed GPROF4 counter type from unsigned to int.  Oops, this should
  be machine-dependent and/or int32_t.
- reorganized overhead counters.

Submitted by: Pentium event counter changes mostly by wollman
sys/amd64/amd64/prof_machdep.c
sys/amd64/include/profile.h
sys/conf/files.i386
sys/conf/options.i386
sys/i386/conf/files.i386
sys/i386/conf/options.i386
sys/i386/include/profile.h
sys/i386/isa/prof_machdep.c
sys/kern/subr_prof.c
sys/libkern/mcount.c
sys/sys/gmon.h