diff --git a/gcc/analyzer/store.cc b/gcc/analyzer/store.cc index 0042a207ba6..8ee414da5c8 100644 --- a/gcc/analyzer/store.cc +++ b/gcc/analyzer/store.cc @@ -1323,6 +1323,7 @@ binding_cluster::purge_state_involving (const svalue *sval, region_model_manager *sval_mgr) { auto_vec to_remove; + auto_vec > to_make_unknown; for (auto iter : m_map) { const binding_key *iter_key = iter.first; @@ -1335,17 +1336,20 @@ binding_cluster::purge_state_involving (const svalue *sval, } const svalue *iter_sval = iter.second; if (iter_sval->involves_p (sval)) - { - const svalue *new_sval - = sval_mgr->get_or_create_unknown_svalue (iter_sval->get_type ()); - m_map.put (iter_key, new_sval); - } + to_make_unknown.safe_push (std::make_pair(iter_key, + iter_sval->get_type ())); } for (auto iter : to_remove) { m_map.remove (iter); m_touched = true; } + for (auto iter : to_make_unknown) + { + const svalue *new_sval + = sval_mgr->get_or_create_unknown_svalue (iter.second); + m_map.put (iter.first, new_sval); + } } /* Get any SVAL bound to REG within this cluster via kind KIND, diff --git a/gcc/testsuite/g++.dg/analyzer/pr101522.C b/gcc/testsuite/g++.dg/analyzer/pr101522.C new file mode 100644 index 00000000000..634a2ac30cd --- /dev/null +++ b/gcc/testsuite/g++.dg/analyzer/pr101522.C @@ -0,0 +1,31 @@ +// { dg-do compile { target c++11 } } + +double +sqrt (); + +namespace std { + class gamma_distribution { + public: + gamma_distribution () : _M_param () {} + + private: + struct param_type { + param_type () : _M_beta () { _M_a2 = 1 / ::sqrt (); } + double _M_beta, _M_a2; + }; + param_type _M_param; + int _M_saved_available, _M_saved = 0, _M_param0 = 0; + }; + + struct fisher_f_distribution { + gamma_distribution _M_gd_x, _M_gd_y; + }; +} + +int +main () +{ + std::fisher_f_distribution d; + + return 0; +}