public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug middle-end/40401]  New: ICE: verify_gimple failed
@ 2009-06-10 13:33 rmansfield at qnx dot com
  2009-06-10 14:04 ` [Bug middle-end/40401] [4.5 Regression] " rguenth at gcc dot gnu dot org
                   ` (6 more replies)
  0 siblings, 7 replies; 8+ messages in thread
From: rmansfield at qnx dot com @ 2009-06-10 13:33 UTC (permalink / raw)
  To: gcc-bugs

[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #1: Type: text/plain, Size: 1922 bytes --]

$ cat /home/ryan/ice.i
typedef void (*malloc_error_fptr_t)(const char * const __file, unsigned int
__lineno, const char * const __msg);
extern void (*_malloc_error)(const char *file, unsigned int lineno, const char
*msg);

void _malloc_error_internal(const char * const fn);
malloc_error_fptr_t _malloc_error = _malloc_error_internal;

void malloc_abort(int status) {
        (*_malloc_error)("mprobe", 1, mcheck_error(status));
}


$ ./xgcc -B. ~/ice.i
/home/ryan/ice.i:5:1: warning: initialization from incompatible pointer type
/home/ryan/ice.i: In function âmalloc_abortâ:
/home/ryan/ice.i:8:2: warning: passing argument 3 of â_malloc_errorâ makes
pointer from integer without a cast
/home/ryan/ice.i:8:2: note: expected âconst char * constâ but argument is of
type âintâ
/home/ryan/ice.i:9:1: error: non-trivial conversion at assignment
void (*<T47e>) (const char * const, unsigned int, const char * const)
void (*<T481>) (const char *, unsigned int, const char *)
_malloc_error.0 = _malloc_error;

/home/ryan/ice.i:9:1: internal compiler error: verify_gimple failed
Please submit a full bug report,
with preprocessed source if appropriate.
See <http://gcc.gnu.org/bugs.html> for instructions.

$ ./xgcc -B. -v
Reading specs from ./specs
Target: i686-pc-linux-gnu
Configured with: ../configure --enable-languages=c --disable-bootstrap
Thread model: posix
gcc version 4.5.0 20090610 (experimental) [trunk revision 148341] (GCC)


-- 
           Summary: ICE: verify_gimple failed
           Product: gcc
           Version: 4.5.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: middle-end
        AssignedTo: unassigned at gcc dot gnu dot org
        ReportedBy: rmansfield at qnx dot com
 GCC build triplet: i686-pc-linux-gnu
  GCC host triplet: i686-pc-linux-gnu
GCC target triplet: i686-pc-linux-gnu


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


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [Bug middle-end/40401] [4.5 Regression] ICE: verify_gimple failed
  2009-06-10 13:33 [Bug middle-end/40401] New: ICE: verify_gimple failed rmansfield at qnx dot com
@ 2009-06-10 14:04 ` rguenth at gcc dot gnu dot org
  2009-06-10 21:35 ` reichelt at gcc dot gnu dot org
                   ` (5 subsequent siblings)
  6 siblings, 0 replies; 8+ messages in thread
From: rguenth at gcc dot gnu dot org @ 2009-06-10 14:04 UTC (permalink / raw)
  To: gcc-bugs



-- 

rguenth at gcc dot gnu dot org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |rguenth at gcc dot gnu dot
                   |                            |org
            Summary|ICE: verify_gimple failed   |[4.5 Regression] ICE:
                   |                            |verify_gimple failed
   Target Milestone|---                         |4.5.0


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


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [Bug middle-end/40401] [4.5 Regression] ICE: verify_gimple failed
  2009-06-10 13:33 [Bug middle-end/40401] New: ICE: verify_gimple failed rmansfield at qnx dot com
  2009-06-10 14:04 ` [Bug middle-end/40401] [4.5 Regression] " rguenth at gcc dot gnu dot org
@ 2009-06-10 21:35 ` reichelt at gcc dot gnu dot org
  2009-06-13 13:57 ` rguenth at gcc dot gnu dot org
                   ` (4 subsequent siblings)
  6 siblings, 0 replies; 8+ messages in thread
From: reichelt at gcc dot gnu dot org @ 2009-06-10 21:35 UTC (permalink / raw)
  To: gcc-bugs



------- Comment #1 from reichelt at gcc dot gnu dot org  2009-06-10 21:35 -------
Confirmed. Even shorter testcase:

============================
void (*fp)(const int i);
void (*fp)(int i);

void foo()
{
  (*fp)(0);
}
============================

The regression appeared between 2009-04-24 and 2009-05-04.


-- 

reichelt at gcc dot gnu dot org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |reichelt at gcc dot gnu dot
                   |                            |org
             Status|UNCONFIRMED                 |NEW
     Ever Confirmed|0                           |1
           Keywords|                            |ice-on-valid-code, monitored
   Last reconfirmed|0000-00-00 00:00:00         |2009-06-10 21:35:35
               date|                            |


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


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [Bug middle-end/40401] [4.5 Regression] ICE: verify_gimple failed
  2009-06-10 13:33 [Bug middle-end/40401] New: ICE: verify_gimple failed rmansfield at qnx dot com
  2009-06-10 14:04 ` [Bug middle-end/40401] [4.5 Regression] " rguenth at gcc dot gnu dot org
  2009-06-10 21:35 ` reichelt at gcc dot gnu dot org
@ 2009-06-13 13:57 ` rguenth at gcc dot gnu dot org
  2009-06-17 12:52 ` [Bug c/40401] " rguenth at gcc dot gnu dot org
                   ` (3 subsequent siblings)
  6 siblings, 0 replies; 8+ messages in thread
From: rguenth at gcc dot gnu dot org @ 2009-06-13 13:57 UTC (permalink / raw)
  To: gcc-bugs



------- Comment #2 from rguenth at gcc dot gnu dot org  2009-06-13 13:57 -------
Mine.


-- 

rguenth at gcc dot gnu dot org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
         AssignedTo|unassigned at gcc dot gnu   |rguenth at gcc dot gnu dot
                   |dot org                     |org
             Status|NEW                         |ASSIGNED
   Last reconfirmed|2009-06-10 21:35:35         |2009-06-13 13:57:18
               date|                            |


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


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [Bug c/40401] [4.5 Regression] ICE: verify_gimple failed
  2009-06-10 13:33 [Bug middle-end/40401] New: ICE: verify_gimple failed rmansfield at qnx dot com
                   ` (2 preceding siblings ...)
  2009-06-13 13:57 ` rguenth at gcc dot gnu dot org
@ 2009-06-17 12:52 ` rguenth at gcc dot gnu dot org
  2009-07-09 15:38 ` rguenth at gcc dot gnu dot org
                   ` (2 subsequent siblings)
  6 siblings, 0 replies; 8+ messages in thread
From: rguenth at gcc dot gnu dot org @ 2009-06-17 12:52 UTC (permalink / raw)
  To: gcc-bugs



------- Comment #3 from rguenth at gcc dot gnu dot org  2009-06-17 12:51 -------
C frontend issue.

The gimplfier is fed (*fp)(0) with fp of type void (*) (const int) but then,
after gimplifying foo we do patch fps type to void (*) (int):

Hardware watchpoint 4: *$2

Old value = (tree) 0xb7d4e230
New value = (tree) 0xb7d4e310
0x080c80c6 in pop_scope () at /home/richard/src/trunk/gcc/c-decl.c:1225
1225                    TREE_TYPE (b->shadowed->decl) = b->shadowed->u.type;
(gdb) bt
#0  0x080c80c6 in pop_scope () at /home/richard/src/trunk/gcc/c-decl.c:1225
#1  0x080c8501 in pop_file_scope ()
    at /home/richard/src/trunk/gcc/c-decl.c:1306
#2  0x08166df6 in c_common_parse_file (set_yydebug=0)
    at /home/richard/src/trunk/gcc/c-opts.c:1281
#3  0x08599792 in compile_file () at /home/richard/src/trunk/gcc/toplev.c:1025
#4  0x0859b61f in do_compile () at /home/richard/src/trunk/gcc/toplev.c:2345
#5  0x0859b6f8 in toplev_main (argc=3, argv=0xbffff534)
    at /home/richard/src/trunk/gcc/toplev.c:2390
#6  0x0819d96a in main (argc=153092128, argv=0x0)
    at /home/richard/src/trunk/gcc/main.c:35

that's not going to fly.

Maybe fixed with gimplification unit-at-a-time.


-- 

rguenth at gcc dot gnu dot org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
         AssignedTo|rguenth at gcc dot gnu dot  |unassigned at gcc dot gnu
                   |org                         |dot org
             Status|ASSIGNED                    |NEW
          Component|middle-end                  |c


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


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [Bug c/40401] [4.5 Regression] ICE: verify_gimple failed
  2009-06-10 13:33 [Bug middle-end/40401] New: ICE: verify_gimple failed rmansfield at qnx dot com
                   ` (3 preceding siblings ...)
  2009-06-17 12:52 ` [Bug c/40401] " rguenth at gcc dot gnu dot org
@ 2009-07-09 15:38 ` rguenth at gcc dot gnu dot org
  2009-07-17 15:50 ` rguenth at gcc dot gnu dot org
  2009-07-17 16:07 ` rguenth at gcc dot gnu dot org
  6 siblings, 0 replies; 8+ messages in thread
From: rguenth at gcc dot gnu dot org @ 2009-07-09 15:38 UTC (permalink / raw)
  To: gcc-bugs



------- Comment #4 from rguenth at gcc dot gnu dot org  2009-07-09 15:38 -------
Indeed fixed by gimplifying unit-at-a-time.  Mine.


-- 

rguenth at gcc dot gnu dot org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
         AssignedTo|unassigned at gcc dot gnu   |rguenth at gcc dot gnu dot
                   |dot org                     |org
             Status|NEW                         |ASSIGNED
           Keywords|                            |ice-checking
           Priority|P3                          |P2
   Last reconfirmed|2009-06-13 13:57:18         |2009-07-09 15:38:32
               date|                            |


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


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [Bug c/40401] [4.5 Regression] ICE: verify_gimple failed
  2009-06-10 13:33 [Bug middle-end/40401] New: ICE: verify_gimple failed rmansfield at qnx dot com
                   ` (4 preceding siblings ...)
  2009-07-09 15:38 ` rguenth at gcc dot gnu dot org
@ 2009-07-17 15:50 ` rguenth at gcc dot gnu dot org
  2009-07-17 16:07 ` rguenth at gcc dot gnu dot org
  6 siblings, 0 replies; 8+ messages in thread
From: rguenth at gcc dot gnu dot org @ 2009-07-17 15:50 UTC (permalink / raw)
  To: gcc-bugs



------- Comment #5 from rguenth at gcc dot gnu dot org  2009-07-17 15:50 -------
Subject: Bug 40401

Author: rguenth
Date: Fri Jul 17 15:49:34 2009
New Revision: 149750

URL: http://gcc.gnu.org/viewcvs?root=gcc&view=rev&rev=149750
Log:
2009-07-17  Richard Guenther  <rguenther@suse.de>

        PR c/40401
        * tree-pass.h (pass_diagnose_omp_blocks): Declare.
        (pass_warn_unused_result): Likewise.
        (TODO_set_props): Remove.
        * omp-low.c (diagnose_omp_structured_block_errors): Change to
        run as a pass.
        (pass_diagnose_omp_blocks): Define.
        * c-decl.c (pop_file_scope): Do not finalize the CU here.
        (c_gimple_diagnostics_recursively): Remove.
        (finish_function): Do not call it.
        (c_write_global_declarations): Continue after errors.
        Finalize the CU here.
        * c-gimplify.c (c_genericize): Do not gimplify here.
        * c-common.c (c_warn_unused_result): Move ...
        * tree-cfg.c (do_warn_unused_result): ... here.
        (run_warn_unused_result): New function.
        (gate_warn_unused_result): New function.
        (pass_warn_unused_result): New pass.
        * c-common.h (c_warn_unused_result): Remove.
        * flags.h (flag_warn_unused_result): Declare.
        * c-opts.c (c_common_init_options): Enable flag_warn_unused_result.
        * opts.c (flag_warn_unused_result): Initialize to false.

        * toplev.c (compile_file): Add comment.
        * omp-low.c (create_omp_child_function): Do not register
        the function with the frontend.
        (diagnose_omp_structured_block_errors): Prepare to be
        called as optimization pass.
        (gate_diagnose_omp_blocks): New function.
        (pass_diagnose_omp_blocks): New pass.
        * cgraph.h (cgraph_optimize): Remove.
        (cgraph_analyze_function): Likewise.
        * cgraph.c (cgraph_add_new_function): Gimplify C++ thunks.
        * cgraphunit.c (cgraph_lower_function): Lower nested functions
        before their parents here.
        (cgraph_finalize_function): Not here.
        (cgraph_analyze_function): Gimplify functions here.
        (cgraph_finalize_compilation_unit): Continue after errors.
        Optimize the callgraph from here.
        (cgraph_optimize): Make static.
        * langhooks.c (write_global_declarations): Finalize the CU.
        * gimplify.c (gimplify_asm_expr): Do not emit ASMs with errors.
        (gimplify_function_tree): Assert we gimplify only once.
        Set PROP_gimple_any property.
        * tree-nested.c (gimplify_all_functions): New function.
        (lower_nested_functions): Gimplify all nested functions.
        * gimple.h (diagnose_omp_structured_block_errors): Remove.
        * passes.c (init_optimization_passes): Add pass_warn_unused_result
        and pass_diagnose_omp_blocks after gimplification.  Do not
        set TODO_set_props on all_lowering_passes.
        (execute_one_pass): Do not handle TODO_set_props.
        * Makefile.in (cgraphunit.o): Add $(TREE_DUMP_H) dependency.
        (gimplify.o): Add tree-pass.h dependency.
        * tree-inline.c (copy_statement_list): Properly copy STATEMENT_LIST.
        (copy_tree_body_r): Properly handle TARGET_EXPR like SAVE_EXPR.
        (unsave_r): Likewise.
        * c-omp.c (c_finish_omp_atomic): Set DECL_CONTEXT on the
        temporary variable.

        cp/
        * decl.c (finish_function): Do not emit unused result warnings
        from here.
        * cp-objcp-common.h (LANG_HOOKS_POST_GIMPLIFY_PASS): Use
        c_warn_unused_result_pass.
        * semantics.c (expand_or_defer_fn): Adjust assertion about IL status.
        * optimize.c (clone_body): Clone in GENERIC.
        (maybe_clone_body): Do not clear DECL_SAVED_TREE.
        * decl2.c (cp_write_global_declarations): Fix body test.
        Do not call cgraph_optimize.
        * Make-lang.in (optimize.o): Add tree-iterator.h dependency.
        * method.c (use_thunk): Register thunk with
        cgraph_finalize_function.
        * error.c (function_category): Guard access of DECL_LANG_SPECIFIC.

        java/
        * java-gimplify.c (java_genericize): Do not gimplify here.
        But replace all local references.
        (java_gimplify_expr): Do not replace local references here.
        (java_gimplify_modify_expr): Likewise.
        * jcf-parse.c (java_parse_file): Do not finalize the CU or
        optimize the cgraph here.
        * decl.c (java_replace_reference): Make static.
        (java_replace_references): New function.
        (end_java_method): Clear base_decl_map.
        * java-tree.h (java_replace_references): Declare.
        (java_replace_reference): Remove.

        ada/
        * utils.c (end_subprog_body): Revert to pre-tuples state.  Remove
        unused parameter.
        (gnat_gimplify_function): Do not gimplify here.
        Fold into its only caller and remove.
        (gnat_builtin_function): Adjust for end_subprog_body signature change.
        (gnat_write_global_declarations): Also finalize the CU.
        * misc.c (gnat_parse_file): Do not finalize the CU here.
        * trans.c (gigi): Revert to pre-tuples state.
        (Subprogram_Body_to_gnu): Adjust for end_subprog_body signature
        change.
        * gigi.h (end_subprog_body): Remove unused parameter.

        fortran/
        * f95-lang.c (gfc_be_parse_file): Do not finalize the CU here.
        * trans-decl.c (gfc_gimplify_function): Remove.
        (build_entry_thunks): Do not gimplify here.
        (create_main_function): Likewise.
        (gfc_generate_function_code): Likewise.

        * g++.dg/rtti/crash4.C: New testcase.
        * g++.dg/torture/20090706-1.C: Likewise.
        * gcc.dg/redecl-17.c: Likewise.

        * gfortran.dg/missing_optional_dummy_5.f90: Adjust pattern.
        * gcc.dg/declspec-9.c: Expect extra error.
        * gcc.dg/declspec-10.c: Likewise.
        * gcc.dg/declspec-11.c: Likewise.
        * gcc.dg/redecl-10.c: Expect extra warnings.
        * gcc.target/i386/pr39082-1.c: Adjust diagnostic location.
        * gcc.target/i386/pr39545-1.c: Likewise.
        * g++.dg/ext/asm3.C: Expect more errors.
        * g++.dg/gomp/block-1.C: Likewise.
        * g++.dg/gomp/block-2.C: Likewise.
        * g++.dg/gomp/block-3.C: Likewise.
        * g++.dg/gomp/block-5.C: Likewise.
        * g++.old-deja/g++.jason/report.C: Expect extra warnings.
        * g++.dg/warn/unused-result1.C: XFAIL.

Added:
    trunk/gcc/testsuite/g++.dg/rtti/crash4.C
    trunk/gcc/testsuite/g++.dg/torture/20090706-1.C
    trunk/gcc/testsuite/gcc.dg/redecl-17.c
Modified:
    trunk/gcc/ChangeLog
    trunk/gcc/Makefile.in
    trunk/gcc/ada/ChangeLog
    trunk/gcc/ada/gcc-interface/gigi.h
    trunk/gcc/ada/gcc-interface/misc.c
    trunk/gcc/ada/gcc-interface/trans.c
    trunk/gcc/ada/gcc-interface/utils.c
    trunk/gcc/c-common.c
    trunk/gcc/c-common.h
    trunk/gcc/c-decl.c
    trunk/gcc/c-gimplify.c
    trunk/gcc/c-omp.c
    trunk/gcc/c-opts.c
    trunk/gcc/cgraph.c
    trunk/gcc/cgraph.h
    trunk/gcc/cgraphunit.c
    trunk/gcc/cp/ChangeLog
    trunk/gcc/cp/Make-lang.in
    trunk/gcc/cp/decl.c
    trunk/gcc/cp/decl2.c
    trunk/gcc/cp/error.c
    trunk/gcc/cp/optimize.c
    trunk/gcc/cp/semantics.c
    trunk/gcc/flags.h
    trunk/gcc/fortran/ChangeLog
    trunk/gcc/fortran/f95-lang.c
    trunk/gcc/fortran/trans-decl.c
    trunk/gcc/gimple.h
    trunk/gcc/gimplify.c
    trunk/gcc/java/ChangeLog
    trunk/gcc/java/decl.c
    trunk/gcc/java/java-gimplify.c
    trunk/gcc/java/java-tree.h
    trunk/gcc/java/jcf-parse.c
    trunk/gcc/langhooks.c
    trunk/gcc/omp-low.c
    trunk/gcc/opts.c
    trunk/gcc/passes.c
    trunk/gcc/testsuite/ChangeLog
    trunk/gcc/testsuite/g++.dg/ext/asm3.C
    trunk/gcc/testsuite/g++.dg/gomp/block-1.C
    trunk/gcc/testsuite/g++.dg/gomp/block-2.C
    trunk/gcc/testsuite/g++.dg/gomp/block-3.C
    trunk/gcc/testsuite/g++.dg/gomp/block-5.C
    trunk/gcc/testsuite/g++.dg/warn/unused-result1.C
    trunk/gcc/testsuite/g++.old-deja/g++.jason/report.C
    trunk/gcc/testsuite/gcc.dg/declspec-10.c
    trunk/gcc/testsuite/gcc.dg/declspec-11.c
    trunk/gcc/testsuite/gcc.dg/declspec-9.c
    trunk/gcc/testsuite/gcc.dg/redecl-10.c
    trunk/gcc/testsuite/gcc.target/i386/pr39082-1.c
    trunk/gcc/testsuite/gcc.target/i386/pr39545-1.c
    trunk/gcc/testsuite/gfortran.dg/missing_optional_dummy_5.f90
    trunk/gcc/toplev.c
    trunk/gcc/tree-cfg.c
    trunk/gcc/tree-inline.c
    trunk/gcc/tree-nested.c
    trunk/gcc/tree-pass.h


-- 


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


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [Bug c/40401] [4.5 Regression] ICE: verify_gimple failed
  2009-06-10 13:33 [Bug middle-end/40401] New: ICE: verify_gimple failed rmansfield at qnx dot com
                   ` (5 preceding siblings ...)
  2009-07-17 15:50 ` rguenth at gcc dot gnu dot org
@ 2009-07-17 16:07 ` rguenth at gcc dot gnu dot org
  6 siblings, 0 replies; 8+ messages in thread
From: rguenth at gcc dot gnu dot org @ 2009-07-17 16:07 UTC (permalink / raw)
  To: gcc-bugs



------- Comment #6 from rguenth at gcc dot gnu dot org  2009-07-17 16:07 -------
Fixed.


-- 

rguenth at gcc dot gnu dot org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
             Status|ASSIGNED                    |RESOLVED
         Resolution|                            |FIXED


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


^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2009-07-17 16:07 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-06-10 13:33 [Bug middle-end/40401] New: ICE: verify_gimple failed rmansfield at qnx dot com
2009-06-10 14:04 ` [Bug middle-end/40401] [4.5 Regression] " rguenth at gcc dot gnu dot org
2009-06-10 21:35 ` reichelt at gcc dot gnu dot org
2009-06-13 13:57 ` rguenth at gcc dot gnu dot org
2009-06-17 12:52 ` [Bug c/40401] " rguenth at gcc dot gnu dot org
2009-07-09 15:38 ` rguenth at gcc dot gnu dot org
2009-07-17 15:50 ` rguenth at gcc dot gnu dot org
2009-07-17 16:07 ` rguenth at gcc dot gnu dot org

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).