diff options
author | Chris Lattner <sabre@nondot.org> | 2003-10-28 18:56:51 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2003-10-28 18:56:51 +0000 |
commit | fa5846a33f773772eb13fae692c82acf64156de3 (patch) | |
tree | 7959369dcc9e64b6dbef37f12600d73e6330af4e /llvm/runtime/libprofile/BlockProfiling.c | |
parent | 11d1f015afb49359cfa37bfb26f1ab723170c1d7 (diff) | |
download | bcm5719-llvm-fa5846a33f773772eb13fae692c82acf64156de3.tar.gz bcm5719-llvm-fa5846a33f773772eb13fae692c82acf64156de3.zip |
Initial checkin of function and block profiling runtime library
llvm-svn: 9546
Diffstat (limited to 'llvm/runtime/libprofile/BlockProfiling.c')
-rw-r--r-- | llvm/runtime/libprofile/BlockProfiling.c | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/llvm/runtime/libprofile/BlockProfiling.c b/llvm/runtime/libprofile/BlockProfiling.c new file mode 100644 index 00000000000..01b80a88e01 --- /dev/null +++ b/llvm/runtime/libprofile/BlockProfiling.c @@ -0,0 +1,43 @@ +/*===-- BlockProfiling.c - Support library for block profiling ------------===*\ +|* +|* The LLVM Compiler Infrastructure +|* +|* This file was developed by the LLVM research group and is distributed under +|* the University of Illinois Open Source License. See LICENSE.TXT for details. +|* +|*===----------------------------------------------------------------------===*| +|* +|* This file implements the call back routines for the block profiling +|* instrumentation pass. This should be used with the -insert-block-profiling +|* LLVM pass. +|* +\*===----------------------------------------------------------------------===*/ + +#include "Profiling.h" +#include <stdlib.h> + +static unsigned *ArrayStart; +static unsigned NumElements; + +/* BlockProfAtExitHandler - When the program exits, just write out the profiling + * data. + */ +static void BlockProfAtExitHandler() { + /* Note that if this were doing something more intellegent with the + instrumentation, that we could do some computation here to expand what we + collected into simple block profiles. Since we directly count each block, + */ + write_profiling_data(Block, ArrayStart, NumElements); +} + + +/* llvm_start_block_profiling - This is the main entry point of the block + * profiling library. It is responsible for setting up the atexit handler. + */ +void llvm_start_block_profiling(int argc, const char **argv, + unsigned *arrayStart, unsigned numElements) { + save_arguments(argc, argv); + ArrayStart = arrayStart; + NumElements = numElements; + atexit(BlockProfAtExitHandler); +} |