linux/scripts/gcc-plugins/gcc-common.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0 */
   2#ifndef GCC_COMMON_H_INCLUDED
   3#define GCC_COMMON_H_INCLUDED
   4
   5#include "bversion.h"
   6#if BUILDING_GCC_VERSION >= 6000
   7#include "gcc-plugin.h"
   8#else
   9#include "plugin.h"
  10#endif
  11#include "plugin-version.h"
  12#include "config.h"
  13#include "system.h"
  14#include "coretypes.h"
  15#include "tm.h"
  16#include "line-map.h"
  17#include "input.h"
  18#include "tree.h"
  19
  20#include "tree-inline.h"
  21#include "version.h"
  22#include "rtl.h"
  23#include "tm_p.h"
  24#include "flags.h"
  25#include "hard-reg-set.h"
  26#include "output.h"
  27#include "except.h"
  28#include "function.h"
  29#include "toplev.h"
  30#if BUILDING_GCC_VERSION >= 5000
  31#include "expr.h"
  32#endif
  33#include "basic-block.h"
  34#include "intl.h"
  35#include "ggc.h"
  36#include "timevar.h"
  37
  38#if BUILDING_GCC_VERSION < 10000
  39#include "params.h"
  40#endif
  41
  42#if BUILDING_GCC_VERSION <= 4009
  43#include "pointer-set.h"
  44#else
  45#include "hash-map.h"
  46#endif
  47
  48#if BUILDING_GCC_VERSION >= 7000
  49#include "memmodel.h"
  50#endif
  51#include "emit-rtl.h"
  52#include "debug.h"
  53#include "target.h"
  54#include "langhooks.h"
  55#include "cfgloop.h"
  56#include "cgraph.h"
  57#include "opts.h"
  58#include "tree-pretty-print.h"
  59#include "gimple-pretty-print.h"
  60#include "c-family/c-common.h"
  61#include "tree-cfgcleanup.h"
  62#include "tree-ssa-operands.h"
  63#include "tree-into-ssa.h"
  64#include "is-a.h"
  65#include "diagnostic.h"
  66#include "tree-dump.h"
  67#include "tree-pass.h"
  68#include "pass_manager.h"
  69#include "predict.h"
  70#include "ipa-utils.h"
  71
  72#if BUILDING_GCC_VERSION >= 8000
  73#include "stringpool.h"
  74#endif
  75
  76#include "attribs.h"
  77#include "varasm.h"
  78#include "stor-layout.h"
  79#include "internal-fn.h"
  80#include "gimple-expr.h"
  81#include "gimple-fold.h"
  82#include "context.h"
  83#include "tree-ssa-alias.h"
  84#include "tree-ssa.h"
  85#include "stringpool.h"
  86#if BUILDING_GCC_VERSION >= 7000
  87#include "tree-vrp.h"
  88#endif
  89#include "tree-ssanames.h"
  90#include "print-tree.h"
  91#include "tree-eh.h"
  92#include "stmt.h"
  93#include "gimplify.h"
  94#include "gimple.h"
  95#include "tree-ssa-operands.h"
  96#include "tree-phinodes.h"
  97#include "tree-cfg.h"
  98#include "gimple-iterator.h"
  99#include "gimple-ssa.h"
 100#include "ssa-iterators.h"
 101
 102#if BUILDING_GCC_VERSION >= 5000
 103#include "builtins.h"
 104#endif
 105
 106/* missing from basic_block.h... */
 107void debug_dominance_info(enum cdi_direction dir);
 108void debug_dominance_tree(enum cdi_direction dir, basic_block root);
 109
 110#ifndef __unused
 111#define __unused __attribute__((__unused__))
 112#endif
 113#ifndef __visible
 114#define __visible __attribute__((visibility("default")))
 115#endif
 116
 117#define DECL_NAME_POINTER(node) IDENTIFIER_POINTER(DECL_NAME(node))
 118#define DECL_NAME_LENGTH(node) IDENTIFIER_LENGTH(DECL_NAME(node))
 119#define TYPE_NAME_POINTER(node) IDENTIFIER_POINTER(TYPE_NAME(node))
 120#define TYPE_NAME_LENGTH(node) IDENTIFIER_LENGTH(TYPE_NAME(node))
 121
 122/* should come from c-tree.h if only it were installed for gcc 4.5... */
 123#define C_TYPE_FIELDS_READONLY(TYPE) TREE_LANG_FLAG_1(TYPE)
 124
 125static inline tree build_const_char_string(int len, const char *str)
 126{
 127        tree cstr, elem, index, type;
 128
 129        cstr = build_string(len, str);
 130        elem = build_type_variant(char_type_node, 1, 0);
 131        index = build_index_type(size_int(len - 1));
 132        type = build_array_type(elem, index);
 133        TREE_TYPE(cstr) = type;
 134        TREE_CONSTANT(cstr) = 1;
 135        TREE_READONLY(cstr) = 1;
 136        TREE_STATIC(cstr) = 1;
 137        return cstr;
 138}
 139
 140#define PASS_INFO(NAME, REF, ID, POS)           \
 141struct register_pass_info NAME##_pass_info = {  \
 142        .pass = make_##NAME##_pass(),           \
 143        .reference_pass_name = REF,             \
 144        .ref_pass_instance_number = ID,         \
 145        .pos_op = POS,                          \
 146}
 147
 148#define add_referenced_var(var)
 149#define mark_sym_for_renaming(var)
 150#define varpool_mark_needed_node(node)
 151#define create_var_ann(var)
 152#define TODO_dump_func 0
 153#define TODO_dump_cgraph 0
 154
 155#if BUILDING_GCC_VERSION <= 4009
 156#define TODO_verify_il 0
 157#define AVAIL_INTERPOSABLE AVAIL_OVERWRITABLE
 158
 159#define section_name_prefix LTO_SECTION_NAME_PREFIX
 160#define fatal_error(loc, gmsgid, ...) fatal_error((gmsgid), __VA_ARGS__)
 161
 162rtx emit_move_insn(rtx x, rtx y);
 163
 164typedef struct rtx_def rtx_insn;
 165
 166static inline const char *get_decl_section_name(const_tree decl)
 167{
 168        if (DECL_SECTION_NAME(decl) == NULL_TREE)
 169                return NULL;
 170
 171        return TREE_STRING_POINTER(DECL_SECTION_NAME(decl));
 172}
 173
 174static inline void set_decl_section_name(tree node, const char *value)
 175{
 176        if (value)
 177                DECL_SECTION_NAME(node) = build_string(strlen(value) + 1, value);
 178        else
 179                DECL_SECTION_NAME(node) = NULL;
 180}
 181#endif
 182
 183#if BUILDING_GCC_VERSION == 4009
 184typedef struct gimple_statement_asm gasm;
 185typedef struct gimple_statement_base gassign;
 186typedef struct gimple_statement_call gcall;
 187typedef struct gimple_statement_base gcond;
 188typedef struct gimple_statement_base gdebug;
 189typedef struct gimple_statement_base ggoto;
 190typedef struct gimple_statement_phi gphi;
 191typedef struct gimple_statement_base greturn;
 192
 193static inline gasm *as_a_gasm(gimple stmt)
 194{
 195        return as_a<gasm>(stmt);
 196}
 197
 198static inline const gasm *as_a_const_gasm(const_gimple stmt)
 199{
 200        return as_a<const gasm>(stmt);
 201}
 202
 203static inline gassign *as_a_gassign(gimple stmt)
 204{
 205        return stmt;
 206}
 207
 208static inline const gassign *as_a_const_gassign(const_gimple stmt)
 209{
 210        return stmt;
 211}
 212
 213static inline gcall *as_a_gcall(gimple stmt)
 214{
 215        return as_a<gcall>(stmt);
 216}
 217
 218static inline const gcall *as_a_const_gcall(const_gimple stmt)
 219{
 220        return as_a<const gcall>(stmt);
 221}
 222
 223static inline gcond *as_a_gcond(gimple stmt)
 224{
 225        return stmt;
 226}
 227
 228static inline const gcond *as_a_const_gcond(const_gimple stmt)
 229{
 230        return stmt;
 231}
 232
 233static inline gdebug *as_a_gdebug(gimple stmt)
 234{
 235        return stmt;
 236}
 237
 238static inline const gdebug *as_a_const_gdebug(const_gimple stmt)
 239{
 240        return stmt;
 241}
 242
 243static inline ggoto *as_a_ggoto(gimple stmt)
 244{
 245        return stmt;
 246}
 247
 248static inline const ggoto *as_a_const_ggoto(const_gimple stmt)
 249{
 250        return stmt;
 251}
 252
 253static inline gphi *as_a_gphi(gimple stmt)
 254{
 255        return as_a<gphi>(stmt);
 256}
 257
 258static inline const gphi *as_a_const_gphi(const_gimple stmt)
 259{
 260        return as_a<const gphi>(stmt);
 261}
 262
 263static inline greturn *as_a_greturn(gimple stmt)
 264{
 265        return stmt;
 266}
 267
 268static inline const greturn *as_a_const_greturn(const_gimple stmt)
 269{
 270        return stmt;
 271}
 272#endif
 273
 274#define TODO_ggc_collect 0
 275#define NODE_SYMBOL(node) (node)
 276#define NODE_DECL(node) (node)->decl
 277#define cgraph_node_name(node) (node)->name()
 278#define NODE_IMPLICIT_ALIAS(node) (node)->cpp_implicit_alias
 279
 280static inline opt_pass *get_pass_for_id(int id)
 281{
 282        return g->get_passes()->get_pass_for_id(id);
 283}
 284
 285#if BUILDING_GCC_VERSION >= 5000 && BUILDING_GCC_VERSION < 6000
 286/* gimple related */
 287template <>
 288template <>
 289inline bool is_a_helper<const gassign *>::test(const_gimple gs)
 290{
 291        return gs->code == GIMPLE_ASSIGN;
 292}
 293#endif
 294
 295#if BUILDING_GCC_VERSION >= 5000
 296#define TODO_verify_ssa TODO_verify_il
 297#define TODO_verify_flow TODO_verify_il
 298#define TODO_verify_stmts TODO_verify_il
 299#define TODO_verify_rtl_sharing TODO_verify_il
 300
 301#define INSN_DELETED_P(insn) (insn)->deleted()
 302
 303static inline const char *get_decl_section_name(const_tree decl)
 304{
 305        return DECL_SECTION_NAME(decl);
 306}
 307
 308/* symtab/cgraph related */
 309#define debug_cgraph_node(node) (node)->debug()
 310#define cgraph_get_node(decl) cgraph_node::get(decl)
 311#define cgraph_get_create_node(decl) cgraph_node::get_create(decl)
 312#define cgraph_create_node(decl) cgraph_node::create(decl)
 313#define cgraph_n_nodes symtab->cgraph_count
 314#define cgraph_max_uid symtab->cgraph_max_uid
 315#define varpool_get_node(decl) varpool_node::get(decl)
 316#define dump_varpool_node(file, node) (node)->dump(file)
 317
 318#if BUILDING_GCC_VERSION >= 8000
 319#define cgraph_create_edge(caller, callee, call_stmt, count, freq) \
 320        (caller)->create_edge((callee), (call_stmt), (count))
 321
 322#define cgraph_create_edge_including_clones(caller, callee,     \
 323                old_call_stmt, call_stmt, count, freq, reason)  \
 324        (caller)->create_edge_including_clones((callee),        \
 325                (old_call_stmt), (call_stmt), (count), (reason))
 326#else
 327#define cgraph_create_edge(caller, callee, call_stmt, count, freq) \
 328        (caller)->create_edge((callee), (call_stmt), (count), (freq))
 329
 330#define cgraph_create_edge_including_clones(caller, callee,     \
 331                old_call_stmt, call_stmt, count, freq, reason)  \
 332        (caller)->create_edge_including_clones((callee),        \
 333                (old_call_stmt), (call_stmt), (count), (freq), (reason))
 334#endif
 335
 336typedef struct cgraph_node *cgraph_node_ptr;
 337typedef struct cgraph_edge *cgraph_edge_p;
 338typedef struct varpool_node *varpool_node_ptr;
 339
 340static inline void change_decl_assembler_name(tree decl, tree name)
 341{
 342        symtab->change_decl_assembler_name(decl, name);
 343}
 344
 345static inline void varpool_finalize_decl(tree decl)
 346{
 347        varpool_node::finalize_decl(decl);
 348}
 349
 350static inline void varpool_add_new_variable(tree decl)
 351{
 352        varpool_node::add(decl);
 353}
 354
 355static inline unsigned int rebuild_cgraph_edges(void)
 356{
 357        return cgraph_edge::rebuild_edges();
 358}
 359
 360static inline cgraph_node_ptr cgraph_function_node(cgraph_node_ptr node, enum availability *availability)
 361{
 362        return node->function_symbol(availability);
 363}
 364
 365static inline cgraph_node_ptr cgraph_function_or_thunk_node(cgraph_node_ptr node, enum availability *availability = NULL)
 366{
 367        return node->ultimate_alias_target(availability);
 368}
 369
 370static inline bool cgraph_only_called_directly_p(cgraph_node_ptr node)
 371{
 372        return node->only_called_directly_p();
 373}
 374
 375static inline enum availability cgraph_function_body_availability(cgraph_node_ptr node)
 376{
 377        return node->get_availability();
 378}
 379
 380static inline cgraph_node_ptr cgraph_alias_target(cgraph_node_ptr node)
 381{
 382        return node->get_alias_target();
 383}
 384
 385static inline bool cgraph_for_node_and_aliases(cgraph_node_ptr node, bool (*callback)(cgraph_node_ptr, void *), void *data, bool include_overwritable)
 386{
 387        return node->call_for_symbol_thunks_and_aliases(callback, data, include_overwritable);
 388}
 389
 390static inline struct cgraph_node_hook_list *cgraph_add_function_insertion_hook(cgraph_node_hook hook, void *data)
 391{
 392        return symtab->add_cgraph_insertion_hook(hook, data);
 393}
 394
 395static inline void cgraph_remove_function_insertion_hook(struct cgraph_node_hook_list *entry)
 396{
 397        symtab->remove_cgraph_insertion_hook(entry);
 398}
 399
 400static inline struct cgraph_node_hook_list *cgraph_add_node_removal_hook(cgraph_node_hook hook, void *data)
 401{
 402        return symtab->add_cgraph_removal_hook(hook, data);
 403}
 404
 405static inline void cgraph_remove_node_removal_hook(struct cgraph_node_hook_list *entry)
 406{
 407        symtab->remove_cgraph_removal_hook(entry);
 408}
 409
 410static inline struct cgraph_2node_hook_list *cgraph_add_node_duplication_hook(cgraph_2node_hook hook, void *data)
 411{
 412        return symtab->add_cgraph_duplication_hook(hook, data);
 413}
 414
 415static inline void cgraph_remove_node_duplication_hook(struct cgraph_2node_hook_list *entry)
 416{
 417        symtab->remove_cgraph_duplication_hook(entry);
 418}
 419
 420static inline void cgraph_call_node_duplication_hooks(cgraph_node_ptr node, cgraph_node_ptr node2)
 421{
 422        symtab->call_cgraph_duplication_hooks(node, node2);
 423}
 424
 425static inline void cgraph_call_edge_duplication_hooks(cgraph_edge *cs1, cgraph_edge *cs2)
 426{
 427        symtab->call_edge_duplication_hooks(cs1, cs2);
 428}
 429
 430#if BUILDING_GCC_VERSION >= 6000
 431typedef gimple *gimple_ptr;
 432typedef const gimple *const_gimple_ptr;
 433#define gimple gimple_ptr
 434#define const_gimple const_gimple_ptr
 435#undef CONST_CAST_GIMPLE
 436#define CONST_CAST_GIMPLE(X) CONST_CAST(gimple, (X))
 437#endif
 438
 439/* gimple related */
 440static inline gimple gimple_build_assign_with_ops(enum tree_code subcode, tree lhs, tree op1, tree op2 MEM_STAT_DECL)
 441{
 442        return gimple_build_assign(lhs, subcode, op1, op2 PASS_MEM_STAT);
 443}
 444
 445#if BUILDING_GCC_VERSION < 10000
 446template <>
 447template <>
 448inline bool is_a_helper<const ggoto *>::test(const_gimple gs)
 449{
 450        return gs->code == GIMPLE_GOTO;
 451}
 452
 453template <>
 454template <>
 455inline bool is_a_helper<const greturn *>::test(const_gimple gs)
 456{
 457        return gs->code == GIMPLE_RETURN;
 458}
 459#endif
 460
 461static inline gasm *as_a_gasm(gimple stmt)
 462{
 463        return as_a<gasm *>(stmt);
 464}
 465
 466static inline const gasm *as_a_const_gasm(const_gimple stmt)
 467{
 468        return as_a<const gasm *>(stmt);
 469}
 470
 471static inline gassign *as_a_gassign(gimple stmt)
 472{
 473        return as_a<gassign *>(stmt);
 474}
 475
 476static inline const gassign *as_a_const_gassign(const_gimple stmt)
 477{
 478        return as_a<const gassign *>(stmt);
 479}
 480
 481static inline gcall *as_a_gcall(gimple stmt)
 482{
 483        return as_a<gcall *>(stmt);
 484}
 485
 486static inline const gcall *as_a_const_gcall(const_gimple stmt)
 487{
 488        return as_a<const gcall *>(stmt);
 489}
 490
 491static inline ggoto *as_a_ggoto(gimple stmt)
 492{
 493        return as_a<ggoto *>(stmt);
 494}
 495
 496static inline const ggoto *as_a_const_ggoto(const_gimple stmt)
 497{
 498        return as_a<const ggoto *>(stmt);
 499}
 500
 501static inline gphi *as_a_gphi(gimple stmt)
 502{
 503        return as_a<gphi *>(stmt);
 504}
 505
 506static inline const gphi *as_a_const_gphi(const_gimple stmt)
 507{
 508        return as_a<const gphi *>(stmt);
 509}
 510
 511static inline greturn *as_a_greturn(gimple stmt)
 512{
 513        return as_a<greturn *>(stmt);
 514}
 515
 516static inline const greturn *as_a_const_greturn(const_gimple stmt)
 517{
 518        return as_a<const greturn *>(stmt);
 519}
 520
 521/* IPA/LTO related */
 522#define ipa_ref_list_referring_iterate(L, I, P) \
 523        (L)->referring.iterate((I), &(P))
 524#define ipa_ref_list_reference_iterate(L, I, P) \
 525        (L)->reference.iterate((I), &(P))
 526
 527static inline cgraph_node_ptr ipa_ref_referring_node(struct ipa_ref *ref)
 528{
 529        return dyn_cast<cgraph_node_ptr>(ref->referring);
 530}
 531
 532static inline void ipa_remove_stmt_references(symtab_node *referring_node, gimple stmt)
 533{
 534        referring_node->remove_stmt_references(stmt);
 535}
 536#endif
 537
 538#if BUILDING_GCC_VERSION < 6000
 539#define get_inner_reference(exp, pbitsize, pbitpos, poffset, pmode, punsignedp, preversep, pvolatilep, keep_aligning)   \
 540        get_inner_reference(exp, pbitsize, pbitpos, poffset, pmode, punsignedp, pvolatilep, keep_aligning)
 541#define gen_rtx_set(ARG0, ARG1) gen_rtx_SET(VOIDmode, (ARG0), (ARG1))
 542#endif
 543
 544#if BUILDING_GCC_VERSION >= 6000
 545#define gen_rtx_set(ARG0, ARG1) gen_rtx_SET((ARG0), (ARG1))
 546#endif
 547
 548#ifdef __cplusplus
 549static inline void debug_tree(const_tree t)
 550{
 551        debug_tree(CONST_CAST_TREE(t));
 552}
 553
 554static inline void debug_gimple_stmt(const_gimple s)
 555{
 556        debug_gimple_stmt(CONST_CAST_GIMPLE(s));
 557}
 558#else
 559#define debug_tree(t) debug_tree(CONST_CAST_TREE(t))
 560#define debug_gimple_stmt(s) debug_gimple_stmt(CONST_CAST_GIMPLE(s))
 561#endif
 562
 563#if BUILDING_GCC_VERSION >= 7000
 564#define get_inner_reference(exp, pbitsize, pbitpos, poffset, pmode, punsignedp, preversep, pvolatilep, keep_aligning)   \
 565        get_inner_reference(exp, pbitsize, pbitpos, poffset, pmode, punsignedp, preversep, pvolatilep)
 566#endif
 567
 568#if BUILDING_GCC_VERSION < 7000
 569#define SET_DECL_ALIGN(decl, align)     DECL_ALIGN(decl) = (align)
 570#define SET_DECL_MODE(decl, mode)       DECL_MODE(decl) = (mode)
 571#endif
 572
 573#endif
 574