Function entry/exit profiling instrumentation:
authorKen Raeburn <raeburn@cygnus.com>
Thu, 30 Jul 1998 10:38:22 +0000 (10:38 +0000)
committerKen Raeburn <raeburn@gcc.gnu.org>
Thu, 30 Jul 1998 10:38:22 +0000 (10:38 +0000)
commit07417085a14349cde788c5cc10663815da40c26f
tree026e48c190a03450b58622639d6f3e00ed5ec047
parent6bcf8e5a040d2ce78eba4b4a143a216e2cea4ab5
Function entry/exit profiling instrumentation:

* expr.h (profile_function_entry_libfunc, profile_function_exit_libfunc):
Declare new variables.
* optabs.c: Define them here.
(init_optabs): Initialize them.
* tree.h (struct tree_decl): New flag no_instrument_function_entry_exit.
(DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT): New accessor macro.
* c-decl.c (duplicate_decls): Merge it.
* c-common.c (enum attrs): New value A_NO_INSTRUMENT_FUNCTION.
(init_attributes): Use it for "no_instrument_function".
(decl_attributes): Handle it, for functions that have not yet been compiled.
Set decl flag.
* flags.h (flag_instrument_function_entry_exit): Declare new variable.
* toplev.c (flag_instrument_function_entry_exit): Define it here.
(f_options): New option "instrument-functions".
* function.h (struct function): New field instrument_entry_exit.
* function.c (current_function_instrument_entry_exit): New variable.
(push_function_context_to, pop_function_context_from): Save and restore.
(expand_function_start): Set current_ variable, maybe emit return label and
entry profile call.
(expand_function_end): Maybe emit exit profile call.
Testsuite:
* gcc.c-torture/special/eeprof-1.c: New test, for -finstrument-functions.
* gcc.c-torture/special/special.exp: Run it.

From-SVN: r21495
15 files changed:
gcc/ChangeLog
gcc/c-common.c
gcc/c-decl.c
gcc/expr.h
gcc/extend.texi
gcc/flags.h
gcc/function.c
gcc/function.h
gcc/invoke.texi
gcc/optabs.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/special/eeprof-1.c [new file with mode: 0644]
gcc/testsuite/gcc.c-torture/special/special.exp
gcc/toplev.c
gcc/tree.h