[Bug tree-optimization/56982] [4.8 Regression] Bad optimization with setjmp()

rguenth at gcc dot gnu.org gcc-bugzilla@gcc.gnu.org
Fri Apr 19 13:40:00 GMT 2013


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=56982

Richard Biener <rguenth at gcc dot gnu.org> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
      Known to work|                            |4.9.0
            Summary|[4.8/4.9 Regression] Bad    |[4.8 Regression] Bad
                   |optimization with setjmp()  |optimization with setjmp()

--- Comment #11 from Richard Biener <rguenth at gcc dot gnu.org> 2013-04-19 13:40:05 UTC ---
Author: rguenth
Date: Fri Apr 19 13:39:16 2013
New Revision: 198096

URL: http://gcc.gnu.org/viewcvs?rev=198096&root=gcc&view=rev
Log:
2013-04-19  Richard Biener  <rguenther@suse.de>

    PR tree-optimization/56982
    * builtins.def (BUILT_IN_LONGJMP): longjmp is not a leaf
    function.
    * gimplify.c (gimplify_call_expr): Notice special calls.
    (gimplify_modify_expr): Likewise.
    * tree-cfg.c (make_abnormal_goto_edges): Handle setjmp-like
    abnormal control flow receivers.
    (call_can_make_abnormal_goto): Handle cfun->calls_setjmp
    in the same way as cfun->has_nonlocal_labels.
    (gimple_purge_dead_abnormal_call_edges): Likewise.
    (stmt_starts_bb_p): Make setjmp-like abnormal control flow
    receivers start a basic-block.

    * gcc.c-torture/execute/pr56982.c: New testcase.

Added:
    trunk/gcc/testsuite/gcc.c-torture/execute/pr56982.c
Modified:
    trunk/gcc/ChangeLog
    trunk/gcc/builtins.def
    trunk/gcc/gimplify.c
    trunk/gcc/testsuite/ChangeLog
    trunk/gcc/tree-cfg.c



More information about the Gcc-bugs mailing list