aboutsummaryrefslogtreecommitdiff
path: root/gcc/function.c
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2002-10-11 22:26:50 +0200
committerJan Hubicka <hubicka@gcc.gnu.org>2002-10-11 20:26:50 +0000
commitdb6556348d92709dfaa930251b5aa0fd5cb740c3 (patch)
treefbcbac53dc98b47f9f2b0b115a5d2f2bb473c34d /gcc/function.c
parentca91148bcd4fd17dea7dbd0407e491e0cfd5ee3d (diff)
downloadgcc-db6556348d92709dfaa930251b5aa0fd5cb740c3.zip
gcc-db6556348d92709dfaa930251b5aa0fd5cb740c3.tar.gz
gcc-db6556348d92709dfaa930251b5aa0fd5cb740c3.tar.bz2
re PR c/7344 (performance regression on huge case statements)
* calls.c (expand_call): Simplify noreturn call. PR c/7344 * cfgbuild.c (make_edges): Create edge cache when we do have large jumptable. (do_tablejump): Note size of maximal jumptable. * function.c (prepare_function_start): Zero out size. * function.h (function): Add max_jumptable_ents. * cfgcleanup.c (insn_match_p): Verify sibcall flag for calls to. From-SVN: r58063
Diffstat (limited to 'gcc/function.c')
-rw-r--r--gcc/function.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/gcc/function.c b/gcc/function.c
index d39fca3..479ecef 100644
--- a/gcc/function.c
+++ b/gcc/function.c
@@ -6295,6 +6295,8 @@ prepare_function_start ()
cfun->function_frequency = FUNCTION_FREQUENCY_NORMAL;
+ cfun->max_jumptable_ents = 0;
+
(*lang_hooks.function.init) (cfun);
if (init_machine_status)
cfun->machine = (*init_machine_status) ();