public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug analyzer/96699] New: [11 Regression] ICE in fold_convert_const_int_from_real, at fold-const.c:2038
@ 2020-08-19  2:28 asolokha at gmx dot com
  2020-08-19 19:25 ` [Bug analyzer/96699] " cvs-commit at gcc dot gnu.org
  2020-08-19 19:32 ` dmalcolm at gcc dot gnu.org
  0 siblings, 2 replies; 3+ messages in thread
From: asolokha at gmx dot com @ 2020-08-19  2:28 UTC (permalink / raw)
  To: gcc-bugs

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=96699

            Bug ID: 96699
           Summary: [11 Regression] ICE in
                    fold_convert_const_int_from_real, at fold-const.c:2038
           Product: gcc
           Version: 11.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: analyzer
          Assignee: dmalcolm at gcc dot gnu.org
          Reporter: asolokha at gmx dot com
  Target Milestone: ---

gcc-11.0.0-alpha20200816 snapshot (g:c99116aeeb9644ebddec653ee8b19de4d38b65bd)
ICEs when compiling the following testcase w/ -fanalyzer:

struct qi {
  union {
    int hj;
    float sl;
  };
};

void
i2 (struct qi *la)
{
  if (la->hj == 0)
    la->sl = 0.0f;
}

% gcc-11.0.0 -fanalyzer -c lnlqkm5b.c
during IPA pass: analyzer
lnlqkm5b.c: In function 'i2':
lnlqkm5b.c:12:12: internal compiler error: in fold_convert_const_int_from_real,
at fold-const.c:2038
   12 |     la->sl = 0.0f;
      |     ~~~~~~~^~~~~~
0x62e70b fold_convert_const_int_from_real
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/fold-const.c:2038
0x62e70b fold_convert_const
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/fold-const.c:2284
0xa7016d fold_unary_loc(unsigned int, tree_code, tree_node*, tree_node*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/fold-const.c:8731
0x1123e9c ana::region_model_manager::maybe_fold_unaryop(tree_node*, tree_code,
ana::svalue const*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/region-model-manager.cc:369
0x1123f8a ana::region_model_manager::get_or_create_unaryop(tree_node*,
tree_code, ana::svalue const*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/region-model-manager.cc:382
0x1123f8a ana::region_model_manager::get_or_create_cast(tree_node*, ana::svalue
const*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/region-model-manager.cc:399
0x114a1f3 ana::initial_svalue::implicitly_live_p(hash_set<ana::svalue const*,
false, default_hash_traits<ana::svalue const*> > const&, ana::region_model
const*) const
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/svalue.cc:529
0x114a1f3 ana::initial_svalue::implicitly_live_p(hash_set<ana::svalue const*,
false, default_hash_traits<ana::svalue const*> > const&, ana::region_model
const*) const
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/svalue.cc:518
0x184ad0d ana::dead_svalue_purger::should_purge_p(ana::svalue const*) const
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/constraint-manager.cc:1613
0x184ad0d void
ana::constraint_manager::purge<ana::dead_svalue_purger>(ana::dead_svalue_purger
const&, ana::purge_stats*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/constraint-manager.cc:1494
0x1849fa6 ana::constraint_manager::on_liveness_change(hash_set<ana::svalue
const*, false, default_hash_traits<ana::svalue const*> > const&,
ana::region_model const*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/constraint-manager.cc:1630
0x1103f5d ana::program_state::detect_leaks(ana::program_state const&,
ana::program_state const&, ana::svalue const*, ana::extrinsic_state const&,
ana::region_model_context*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/program-state.cc:1037
0x10f430a ana::exploded_graph::process_node(ana::exploded_node*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/engine.cc:2538
0x10f4d5a ana::exploded_graph::process_worklist()
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/engine.cc:2341
0x10f6e8f ana::impl_run_checkers(ana::logger*)
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/engine.cc:4107
0x10f7aac ana::run_checkers()
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/engine.cc:4175
0x10ec468 execute
       
/var/tmp/portage/sys-devel/gcc-11.0.0_alpha20200816/work/gcc-11-20200816/gcc/analyzer/analyzer-pass.cc:84

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

* [Bug analyzer/96699] [11 Regression] ICE in fold_convert_const_int_from_real, at fold-const.c:2038
  2020-08-19  2:28 [Bug analyzer/96699] New: [11 Regression] ICE in fold_convert_const_int_from_real, at fold-const.c:2038 asolokha at gmx dot com
@ 2020-08-19 19:25 ` cvs-commit at gcc dot gnu.org
  2020-08-19 19:32 ` dmalcolm at gcc dot gnu.org
  1 sibling, 0 replies; 3+ messages in thread
From: cvs-commit at gcc dot gnu.org @ 2020-08-19 19:25 UTC (permalink / raw)
  To: gcc-bugs

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=96699

--- Comment #1 from CVS Commits <cvs-commit at gcc dot gnu.org> ---
The master branch has been updated by David Malcolm <dmalcolm@gcc.gnu.org>:

https://gcc.gnu.org/g:366bd1ac01a5249a463e64234674ad2d174faa9a

commit r11-2770-g366bd1ac01a5249a463e64234674ad2d174faa9a
Author: David Malcolm <dmalcolm@redhat.com>
Date:   Wed Aug 19 05:00:52 2020 -0400

    analyzer: fix ICE converting float to int [PR96699]

    gcc/analyzer/ChangeLog:
            PR analyzer/96699
            * region-model-manager.cc
            (region_model_manager::get_or_create_cast): Use FIX_TRUNC_EXPR for
            casting from REAL_TYPE to INTEGER_TYPE.

    gcc/testsuite/ChangeLog:
            PR analyzer/96699
            * gcc.dg/analyzer/pr96699.c: New test.

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

* [Bug analyzer/96699] [11 Regression] ICE in fold_convert_const_int_from_real, at fold-const.c:2038
  2020-08-19  2:28 [Bug analyzer/96699] New: [11 Regression] ICE in fold_convert_const_int_from_real, at fold-const.c:2038 asolokha at gmx dot com
  2020-08-19 19:25 ` [Bug analyzer/96699] " cvs-commit at gcc dot gnu.org
@ 2020-08-19 19:32 ` dmalcolm at gcc dot gnu.org
  1 sibling, 0 replies; 3+ messages in thread
From: dmalcolm at gcc dot gnu.org @ 2020-08-19 19:32 UTC (permalink / raw)
  To: gcc-bugs

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=96699

David Malcolm <dmalcolm at gcc dot gnu.org> changed:

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

--- Comment #2 from David Malcolm <dmalcolm at gcc dot gnu.org> ---
Should be fixed by the above commit.

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

end of thread, other threads:[~2020-08-19 19:32 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-08-19  2:28 [Bug analyzer/96699] New: [11 Regression] ICE in fold_convert_const_int_from_real, at fold-const.c:2038 asolokha at gmx dot com
2020-08-19 19:25 ` [Bug analyzer/96699] " cvs-commit at gcc dot gnu.org
2020-08-19 19:32 ` dmalcolm at gcc dot gnu.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).