/* Representation of adjustment made to virtual clones in the symbol table. Copyright (C) 2003-2021 Free Software Foundation, Inc. Contributed by Jan Hubicka This file is part of GCC. GCC is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. GCC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GCC; see the file COPYING3. If not see . */ #ifndef GCC_SYMTAB_CLONES_H #define GCC_SYMTAB_CLONES_H struct GTY(()) clone_info { /* Constructor. */ clone_info () : tree_map (NULL), param_adjustments (NULL), performed_splits (NULL) { } /* Constants discovered by IPA-CP, i.e. which parameter should be replaced with what. */ vec *tree_map; /* Parameter modification that IPA-SRA decided to perform. */ ipa_param_adjustments *param_adjustments; /* Lists of dummy-decl and offset pairs representing split formal parameters in the caller. Offsets of all new replacements are enumerated, those coming from the same original parameter have the same dummy decl stored along with them. Dummy decls sit in call statement arguments followed by new parameter decls (or their SSA names) in between (caller) clone materialization and call redirection. Redirection then recognizes the dummy variable and together with the stored offsets can reconstruct what exactly the new parameter decls represent and can leave in place only those that the callee expects. */ vec *performed_splits; /* Return clone_info, if available. */ static clone_info *get (cgraph_node *node); /* Return clone_info possibly creating new one. */ static clone_info *get_create (cgraph_node *node); /* Remove clone_info. */ static void remove (cgraph_node *node); /* Release all clone_infos. */ static void release (void); }; /* Return clone_info, if available. */ inline clone_info * clone_info::get (cgraph_node *node) { if (!symtab->m_clones) return NULL; return symtab->m_clones->get (node); } /* Remove clone_info association for NODE. */ inline void clone_info::remove (cgraph_node *node) { symtab->m_clones->remove (node); } /* Free clone info summaries. */ inline void clone_info::release () { if (symtab->m_clones) ggc_delete (symtab->m_clones); symtab->m_clones = NULL; } #endif /* GCC_SYMTAB_CLONES_H */