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:
parent
cfa55545f9
commit
76b6ddbfe2
6 changed files with 34 additions and 24 deletions
|
@ -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>
|
||||
|
||||
|
|
|
@ -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 &);
|
||||
|
|
|
@ -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);
|
||||
}
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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;
|
||||
}
|
||||
|
||||
|
|
|
@ -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 &);
|
||||
};
|
||||
|
|
Loading…
Add table
Reference in a new issue