2015-06-25 Zhouyi Zhou <yizhouzhou@ict.ac.cn>
[official-gcc.git] / gcc / valtrack.h
blob67bdebb3503b32a8b536df2219ae3f05e0e18336
1 /* Infrastructure for tracking user variable locations and values
2 throughout compilation.
3 Copyright (C) 2010-2015 Free Software Foundation, Inc.
4 Contributed by Alexandre Oliva <aoliva@redhat.com>.
6 This file is part of GCC.
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 3, or (at your option) any later
11 version.
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3. If not see
20 <http://www.gnu.org/licenses/>. */
22 #ifndef GCC_VALTRACK_H
23 #define GCC_VALTRACK_H
25 #include "bitmap.h"
26 #include "df.h"
27 #include "rtl.h"
29 /* Debug uses of dead regs. */
31 /* Entry that maps a dead pseudo (REG) used in a debug insns that dies
32 at different blocks to the debug temp (DTEMP) it was replaced
33 with. */
35 struct dead_debug_global_entry
37 rtx reg;
38 rtx dtemp;
41 /* Descriptor for hash_table to hash by dead_debug_global_entry's REG
42 and map to DTEMP. */
44 struct dead_debug_hash_descr
46 /* The hash table contains pointers to entries of this type. */
47 typedef struct dead_debug_global_entry *value_type;
48 typedef struct dead_debug_global_entry *compare_type;
49 /* Hash on the pseudo number. */
50 static inline hashval_t hash (const dead_debug_global_entry *my);
51 /* Entries are identical if they refer to the same pseudo. */
52 static inline bool equal (const dead_debug_global_entry *my,
53 const dead_debug_global_entry *other);
54 /* Release entries when they're removed. */
55 static inline void remove (dead_debug_global_entry *p);
58 /* Hash on the pseudo number. */
59 inline hashval_t
60 dead_debug_hash_descr::hash (const dead_debug_global_entry *my)
62 return REGNO (my->reg);
65 /* Entries are identical if they refer to the same pseudo. */
66 inline bool
67 dead_debug_hash_descr::equal (const dead_debug_global_entry *my,
68 const dead_debug_global_entry *other)
70 return my->reg == other->reg;
73 /* Release entries when they're removed. */
74 inline void
75 dead_debug_hash_descr::remove (dead_debug_global_entry *p)
77 XDELETE (p);
80 /* Maintain a global table of pseudos used in debug insns after their
81 deaths in other blocks, and debug temps their deathpoint values are
82 to be bound to. */
84 struct dead_debug_global
86 /* This hash table that maps pseudos to debug temps. */
87 hash_table<dead_debug_hash_descr> *htab;
88 /* For each entry in htab, the bit corresponding to its REGNO will
89 be set. */
90 bitmap used;
93 /* Node of a linked list of uses of dead REGs in debug insns. */
95 struct dead_debug_use
97 df_ref use;
98 struct dead_debug_use *next;
101 /* Linked list of the above, with a bitmap of the REGs in the
102 list. */
104 struct dead_debug_local
106 /* The first dead_debug_use entry in the list. */
107 struct dead_debug_use *head;
108 /* A pointer to the global tracking data structure. */
109 struct dead_debug_global *global;
110 /* A bitmap that has bits set for each REG used in the
111 dead_debug_use list, and for each entry in the global hash
112 table. */
113 bitmap used;
114 /* A bitmap that has bits set for each INSN that is to be
115 rescanned. */
116 bitmap to_rescan;
119 /* This type controls the behavior of dead_debug_insert_temp WRT
120 UREGNO and INSN. */
122 enum debug_temp_where
124 /* Bind a newly-created debug temporary to a REG for UREGNO, and
125 insert the debug insn before INSN. REG is expected to die at
126 INSN. */
127 DEBUG_TEMP_BEFORE_WITH_REG = -1,
128 /* Bind a newly-created debug temporary to the value INSN stores
129 in REG, and insert the debug insn before INSN. */
130 DEBUG_TEMP_BEFORE_WITH_VALUE = 0,
131 /* Bind a newly-created debug temporary to a REG for UREGNO, and
132 insert the debug insn after INSN. REG is expected to be set at
133 INSN. */
134 DEBUG_TEMP_AFTER_WITH_REG = 1,
135 /* Like DEBUG_TEMP_AFTER_WITH_REG, but force addition of a debug
136 temporary even if there is just a single debug use. This is used
137 on regs that are becoming REG_DEAD on INSN and so uses of the
138 reg later on are invalid. */
139 DEBUG_TEMP_AFTER_WITH_REG_FORCE = 2
142 extern void dead_debug_global_init (struct dead_debug_global *, bitmap);
143 extern void dead_debug_global_finish (struct dead_debug_global *, bitmap);
144 extern void dead_debug_local_init (struct dead_debug_local *, bitmap,
145 struct dead_debug_global *);
146 extern void dead_debug_local_finish (struct dead_debug_local *, bitmap);
147 extern void dead_debug_add (struct dead_debug_local *, df_ref, unsigned int);
148 extern int dead_debug_insert_temp (struct dead_debug_local *,
149 unsigned int uregno, rtx_insn *insn,
150 enum debug_temp_where);
152 extern void propagate_for_debug (rtx_insn *, rtx_insn *, rtx, rtx, basic_block);
155 #endif /* GCC_VALTRACK_H */