> Hi.
> 
> Last part of planned clean-up where I declare ::get as PURE.
> Patch can bootstrap on ppc64le-redhat-linux and survives regression tests.
> 
> Ready to be installed?
OK,
thanks!
Honza
> Martin

> From 540efe3374d649cc8745445a3e6dc1c720fb79ad Mon Sep 17 00:00:00 2001
> From: marxin <mli...@suse.cz>
> Date: Wed, 20 Jun 2018 14:26:48 +0200
> Subject: [PATCH] Make symbol_summary::get and call_summary::get pure.
> 
> gcc/ChangeLog:
> 
> 2018-06-20  Martin Liska  <mli...@suse.cz>
> 
>       * symbol-summary.h (get): Make it pure and inline move
>         functionality from ::get function.
>         (get): Remove and inline into ::get and ::get_create.
>         (get_create): Move code from ::get function.
> ---
>  gcc/symbol-summary.h | 74 +++++++++++---------------------------------
>  1 file changed, 18 insertions(+), 56 deletions(-)
> 
> diff --git a/gcc/symbol-summary.h b/gcc/symbol-summary.h
> index bf32810abd7..26e9773d3c0 100644
> --- a/gcc/symbol-summary.h
> +++ b/gcc/symbol-summary.h
> @@ -90,13 +90,19 @@ public:
>       does not exist it will be created.  */
>    T* get_create (cgraph_node *node)
>    {
> -    return get (node->get_uid (), true);
> +    bool existed;
> +    T **v = &m_map.get_or_insert (node->get_uid (), &existed);
> +    if (!existed)
> +      *v = allocate_new ();
> +
> +    return *v;
>    }
>  
>    /* Getter for summary callgraph node pointer.  */
> -  T* get (cgraph_node *node)
> +  T* get (cgraph_node *node) ATTRIBUTE_PURE
>    {
> -    return get (node->get_uid (), false);
> +    T **v = m_map.get (node->get_uid ());
> +    return v == NULL ? NULL : *v;
>    }
>  
>    /* Remove node from summary.  */
> @@ -152,9 +158,6 @@ protected:
>  private:
>    typedef int_hash <int, 0, -1> map_hash;
>  
> -  /* Getter for summary callgraph ID.  */
> -  T *get (int uid, bool lazy_insert);
> -
>    /* Indicates if insertion hook is enabled.  */
>    bool m_insertion_enabled;
>    /* Indicates if the summary is released.  */
> @@ -273,28 +276,6 @@ function_summary<T *>::symtab_duplication (cgraph_node 
> *node,
>      }
>  }
>  
> -template <typename T>
> -T*
> -function_summary<T *>::get (int uid, bool lazy_insert)
> -{
> -  gcc_checking_assert (uid > 0);
> -
> -  if (lazy_insert)
> -    {
> -      bool existed;
> -      T **v = &m_map.get_or_insert (uid, &existed);
> -      if (!existed)
> -     *v = allocate_new ();
> -
> -      return *v;
> -    }
> -  else
> -    {
> -      T **v = m_map.get (uid);
> -      return v == NULL ? NULL : *v;
> -    }
> -}
> -
>  template <typename T>
>  void
>  gt_ggc_mx(function_summary<T *>* const &summary)
> @@ -387,13 +368,19 @@ public:
>       If a summary for an edge does not exist, it will be created.  */
>    T* get_create (cgraph_edge *edge)
>    {
> -    return get (edge->get_uid (), true);
> +    bool existed;
> +    T **v = &m_map.get_or_insert (edge->get_uid (), &existed);
> +    if (!existed)
> +      *v = allocate_new ();
> +
> +    return *v;
>    }
>  
>    /* Getter for summary callgraph edge pointer.  */
> -  T* get (cgraph_edge *edge)
> +  T* get (cgraph_edge *edge) ATTRIBUTE_PURE
>    {
> -    return get (edge->get_uid (), false);
> +    T **v = m_map.get (edge->get_uid ());
> +    return v == NULL ? NULL : *v;
>    }
>  
>    /* Remove edge from summary.  */
> @@ -437,9 +424,6 @@ protected:
>  private:
>    typedef int_hash <int, 0, -1> map_hash;
>  
> -  /* Getter for summary callgraph ID.  */
> -  T *get (int uid, bool lazy_insert);
> -
>    /* Main summary store, where summary ID is used as key.  */
>    hash_map <map_hash, T *> m_map;
>    /* Internal summary removal hook pointer.  */
> @@ -457,28 +441,6 @@ private:
>        gt_pointer_operator, void *);
>  };
>  
> -template <typename T>
> -T*
> -call_summary<T *>::get (int uid, bool lazy_insert)
> -{
> -  gcc_checking_assert (uid > 0);
> -
> -  if (lazy_insert)
> -    {
> -      bool existed;
> -      T **v = &m_map.get_or_insert (uid, &existed);
> -      if (!existed)
> -     *v = allocate_new ();
> -
> -      return *v;
> -    }
> -  else
> -    {
> -      T **v = m_map.get (uid);
> -      return v == NULL ? NULL : *v;
> -    }
> -}
> -
>  template <typename T>
>  void
>  call_summary<T *>::release ()
> -- 
> 2.17.1
> 

Reply via email to