destroy values as well as keys when removing them from hash maps

gcc/ChangeLog:

2015-11-24  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>

	* hash-map-traits.h (simple_hashmap_traits ::remove): call
	destructors on values that are being removed.
	* mem-stats.h (hash_map): Pass type of values to
	simple_hashmap_traits.
	* tree-sra.c (sra_deinitialize): Remove work around for hash
	maps not destructing values.
	* genmatch.c (sinfo_hashmap_traits): Adjust.
	* tree-ssa-uncprop.c (val_ssa_equiv_hash_traits): Likewise.

From-SVN: r230801
This commit is contained in:
Trevor Saunders 2015-11-24 11:46:10 +00:00 committed by Trevor Saunders
parent cfa55545f9
commit 76b6ddbfe2
6 changed files with 34 additions and 24 deletions

View File

@ -1,3 +1,14 @@
2015-11-24 Trevor Saunders <tbsaunde+gcc@tbsaunde.org>
* hash-map-traits.h (simple_hashmap_traits ::remove): call
destructors on values that are being removed.
* mem-stats.h (hash_map): Pass type of values to
simple_hashmap_traits.
* tree-sra.c (sra_deinitialize): Remove work around for hash
maps not destructing values.
* genmatch.c (sinfo_hashmap_traits): Adjust.
* tree-ssa-uncprop.c (val_ssa_equiv_hash_traits): Likewise.
2015-11-24 Richard Biener <rguenther@suse.de>
Kyrylo Tkachov <kyrylo.tkachov@arm.com>

View File

@ -1397,7 +1397,8 @@ struct sinfo
unsigned cnt;
};
struct sinfo_hashmap_traits : simple_hashmap_traits <pointer_hash <dt_simplify> >
struct sinfo_hashmap_traits : simple_hashmap_traits<pointer_hash<dt_simplify>,
sinfo *>
{
static inline hashval_t hash (const key_type &);
static inline bool equal_keys (const key_type &, const key_type &);

View File

@ -28,7 +28,7 @@ along with GCC; see the file COPYING3. If not see
/* Implement hash_map traits for a key with hash traits H. Empty and
deleted map entries are represented as empty and deleted keys. */
template <typename H>
template <typename H, typename Value>
struct simple_hashmap_traits
{
typedef typename H::value_type key_type;
@ -41,56 +41,58 @@ struct simple_hashmap_traits
template <typename T> static inline void mark_deleted (T &);
};
template <typename H>
template <typename H, typename Value>
inline hashval_t
simple_hashmap_traits <H>::hash (const key_type &h)
simple_hashmap_traits <H, Value>::hash (const key_type &h)
{
return H::hash (h);
}
template <typename H>
template <typename H, typename Value>
inline bool
simple_hashmap_traits <H>::equal_keys (const key_type &k1, const key_type &k2)
simple_hashmap_traits <H, Value>::equal_keys (const key_type &k1,
const key_type &k2)
{
return H::equal (k1, k2);
}
template <typename H>
template <typename H, typename Value>
template <typename T>
inline void
simple_hashmap_traits <H>::remove (T &entry)
simple_hashmap_traits <H, Value>::remove (T &entry)
{
H::remove (entry.m_key);
entry.m_value.~Value ();
}
template <typename H>
template <typename H, typename Value>
template <typename T>
inline bool
simple_hashmap_traits <H>::is_empty (const T &entry)
simple_hashmap_traits <H, Value>::is_empty (const T &entry)
{
return H::is_empty (entry.m_key);
}
template <typename H>
template <typename H, typename Value>
template <typename T>
inline bool
simple_hashmap_traits <H>::is_deleted (const T &entry)
simple_hashmap_traits <H, Value>::is_deleted (const T &entry)
{
return H::is_deleted (entry.m_key);
}
template <typename H>
template <typename H, typename Value>
template <typename T>
inline void
simple_hashmap_traits <H>::mark_empty (T &entry)
simple_hashmap_traits <H, Value>::mark_empty (T &entry)
{
H::mark_empty (entry.m_key);
}
template <typename H>
template <typename H, typename Value>
template <typename T>
inline void
simple_hashmap_traits <H>::mark_deleted (T &entry)
simple_hashmap_traits <H, Value>::mark_deleted (T &entry)
{
H::mark_deleted (entry.m_key);
}

View File

@ -3,7 +3,8 @@
/* Forward declaration. */
template<typename Key, typename Value,
typename Traits = simple_hashmap_traits<default_hash_traits<Key> > >
typename Traits = simple_hashmap_traits<default_hash_traits<Key>,
Value> >
class hash_map;
#define LOCATION_LINE_EXTRA_SPACE 30

View File

@ -674,12 +674,6 @@ sra_deinitialize (void)
assign_link_pool.release ();
obstack_free (&name_obstack, NULL);
/* TODO: hash_map does not support traits that can release
value type of the hash_map. */
for (hash_map<tree, auto_vec<access_p> >::iterator it =
base_access_vec->begin (); it != base_access_vec->end (); ++it)
(*it).second.release ();
delete base_access_vec;
}

View File

@ -277,7 +277,8 @@ struct equiv_hash_elt
/* Value to ssa name equivalence hashtable helpers. */
struct val_ssa_equiv_hash_traits : simple_hashmap_traits <tree_operand_hash>
struct val_ssa_equiv_hash_traits : simple_hashmap_traits <tree_operand_hash,
vec<tree> >
{
template<typename T> static inline void remove (T &);
};