regrename.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /* This file contains definitions for the register renamer.
  2. Copyright (C) 2011-2015 Free Software Foundation, Inc.
  3. This file is part of GCC.
  4. GCC is free software; you can redistribute it and/or modify it under
  5. the terms of the GNU General Public License as published by the Free
  6. Software Foundation; either version 3, or (at your option) any later
  7. version.
  8. GCC is distributed in the hope that it will be useful, but WITHOUT ANY
  9. WARRANTY; without even the implied warranty of MERCHANTABILITY or
  10. FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
  11. for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with GCC; see the file COPYING3. If not see
  14. <http://www.gnu.org/licenses/>. */
  15. #ifndef GCC_REGRENAME_H
  16. #define GCC_REGRENAME_H
  17. /* We keep linked lists of DU_HEAD structures, each of which describes
  18. a chain of occurrences of a reg. */
  19. struct du_head
  20. {
  21. /* The next chain. */
  22. struct du_head *next_chain;
  23. /* The first and last elements of this chain. */
  24. struct du_chain *first, *last;
  25. /* Describes the register being tracked. */
  26. unsigned regno;
  27. int nregs;
  28. /* A unique id to be used as an index into the conflicts bitmaps. */
  29. unsigned id;
  30. /* A bitmap to record conflicts with other chains. */
  31. bitmap_head conflicts;
  32. /* Conflicts with untracked hard registers. */
  33. HARD_REG_SET hard_conflicts;
  34. /* Nonzero if the chain crosses a call. */
  35. unsigned int need_caller_save_reg:1;
  36. /* Nonzero if the register is used in a way that prevents renaming,
  37. such as the SET_DEST of a CALL_INSN or an asm operand that used
  38. to be a hard register. */
  39. unsigned int cannot_rename:1;
  40. };
  41. typedef struct du_head *du_head_p;
  42. /* This struct describes a single occurrence of a register. */
  43. struct du_chain
  44. {
  45. /* Links to the next occurrence of the register. */
  46. struct du_chain *next_use;
  47. /* The insn where the register appears. */
  48. rtx_insn *insn;
  49. /* The location inside the insn. */
  50. rtx *loc;
  51. /* The register class required by the insn at this location. */
  52. ENUM_BITFIELD(reg_class) cl : 16;
  53. };
  54. /* This struct describes data gathered during regrename_analyze about
  55. a single operand of an insn. */
  56. struct operand_rr_info
  57. {
  58. /* The number of chains recorded for this operand. */
  59. int n_chains;
  60. /* Holds either the chain for the operand itself, or for the registers in
  61. a memory operand. */
  62. struct du_chain *chains[MAX_REGS_PER_ADDRESS];
  63. struct du_head *heads[MAX_REGS_PER_ADDRESS];
  64. };
  65. /* A struct to hold a vector of operand_rr_info structures describing the
  66. operands of an insn. */
  67. struct insn_rr_info
  68. {
  69. operand_rr_info *op_info;
  70. };
  71. extern vec<insn_rr_info> insn_rr;
  72. extern void regrename_init (bool);
  73. extern void regrename_finish (void);
  74. extern void regrename_analyze (bitmap);
  75. extern du_head_p regrename_chain_from_id (unsigned int);
  76. extern int find_rename_reg (du_head_p, enum reg_class, HARD_REG_SET *, int,
  77. bool);
  78. extern void regrename_do_replace (du_head_p, int);
  79. #endif