1 // Function-related RTL SSA classes                                 -*- C++ -*-
2 // Copyright (C) 2020-2021 Free Software Foundation, Inc.
3 //
4 // This file is part of GCC.
5 //
6 // GCC is free software; you can redistribute it and/or modify it under
7 // the terms of the GNU General Public License as published by the Free
8 // Software Foundation; either version 3, or (at your option) any later
9 // version.
10 //
11 // GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 // WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 // FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14 // for more details.
15 //
16 // You should have received a copy of the GNU General Public License
17 // along with GCC; see the file COPYING3.  If not see
18 // <http://www.gnu.org/licenses/>.
19 
20 namespace rtl_ssa {
21 
22 // SSA-related information about a function.  It contains three levels
23 // of information, each in reverse postorder:
24 //
25 // - a list of extended basic blocks
26 // - a list of basic blocks
27 // - a list of instructions
28 //
29 // It also maintains a list of definitions of memory, and a list of
30 // definitions of each register.
31 //
32 // See doc/rtl.texi for more details about the way this information
33 // is organized and how changes to it are made.
34 class function_info
35 {
36   // The default obstack alignment takes long double into account.
37   // Since we have no use for that here, and since we allocate many
38   // relatively small objects, it's better to specify an alignment
39   // explicitly.  The allocation routines assert that the alignment
40   // is enough for the objects being allocated.
41   //
42   // Because various structures use pointer_mux, we need at least 2 bytes
43   // of alignment.
44   static const size_t obstack_alignment = sizeof (void *);
45 
46 public:
47   // Construct SSA form for function FN.
48   function_info (function *fn);
49   ~function_info ();
50 
51   // Return a list of all the extended basic blocks in the function, in reverse
52   // postorder.  The list includes the entry and exit blocks.
53   iterator_range<ebb_iterator> ebbs () const;
54 
55   // Like ebbs (), but in the reverse order.
56   iterator_range<reverse_ebb_iterator> reverse_ebbs () const;
57 
58   // Return a list of all the basic blocks in the function, in reverse
59   // postorder.  The list includes the entry and exit blocks.
60   iterator_range<bb_iterator> bbs () const;
61 
62   // Like bbs (), but in the reverse order.
63   iterator_range<reverse_bb_iterator> reverse_bbs () const;
64 
65   // Return the SSA information for the basic block with index INDEX.
66   bb_info *bb (unsigned int index) const { return m_bbs[index]; }
67 
68   // Return the SSA information for CFG_BB.
69   bb_info *bb (basic_block cfg_bb) const { return m_bbs[cfg_bb->index]; }
70 
71   // Return a list of all the instructions in the function, in reverse
_SendRecv()72   // postorder.  The list includes both real and artificial instructions.
73   //
74   // Iterations over the list will pick up any new instructions that are
75   // inserted after the iterator's current instruction.
76   iterator_range<any_insn_iterator> all_insns () const;
77 
78   // Like all_insns (), but in the reverse order.
79   //
80   // Iterations over the list will pick up any new instructions that are
81   // inserted before the iterator's current instruction.
82   iterator_range<reverse_any_insn_iterator> reverse_all_insns () const;
83 
84   // Like all_insns (), but without the debug instructions.
85   iterator_range<nondebug_insn_iterator> nondebug_insns () const;
86 
87   // Like reverse_all_insns (), but without the debug instructions.
88   iterator_range<reverse_nondebug_insn_iterator>
89     reverse_nondebug_insns () const;
90 
91   // Return the first and last instructions in insns ().
92   insn_info *first_insn () const { return m_first_insn; }
93   insn_info *last_insn () const { return m_last_insn; }
94 
95   // Return a list of all definitions of memory, in reverse postorder.
96   // This includes both real stores by instructions and artificial
97   // definitions by things like phi nodes.
98   iterator_range<def_iterator> mem_defs () const;
99 
100   // Return a list of all definitions of register REGNO, in reverse postorder.
101   // This includes both real stores by instructions and artificial
102   // definitions by things like phi nodes.
103   iterator_range<def_iterator> reg_defs (unsigned int regno) const;
104 
105   // Check if all uses of register REGNO are either unconditionally undefined
106   // or use the same single dominating definition.  Return the definition
107   // if so, otherwise return null.
108   set_info *single_dominating_def (unsigned int regno) const;
109 
110   // Look for a definition of RESOURCE at INSN.  Return the result of the
111   // search as a def_lookup; see the comments there for more details.
112   def_lookup find_def (resource_info resource, insn_info *insn);
113 
114   // Return an RAII object that owns all temporary RTL SSA memory
115   // allocated during a change attempt.  The object should remain in
116   // scope until the change has been aborted or successfully completed.
117   obstack_watermark new_change_attempt () { return &m_temp_obstack; }
118 
119   // Make a best attempt to check whether the values used by USES are
120   // available on entry to BB, without solving a full dataflow problem.
121   // If all the values are already live on entry to BB or can be made
122   // available there, return a use_array that describes the uses as
123   // if they occured at the start of BB.  These uses are purely temporary,
124   // and will not become permanent unless applied using change_insns.
125   //
126   // If the operation fails, return an invalid use_array.
127   //
128   // WATERMARK is a watermark returned by new_change_attempt ().
129   use_array make_uses_available (obstack_watermark &watermark,
130 				 use_array uses, bb_info *bb);
131 
132   // If CHANGE doesn't already clobber REGNO, try to add such a clobber,
133   // limiting the movement range in order to make the clobber valid.
134   // When determining whether REGNO is live, ignore accesses made by an
135   // instruction I if IGNORE (I) is true.  The caller then assumes the
136   // responsibility of ensuring that CHANGE and I are placed in a valid order.
137   //
138   // Return true on success.  Leave CHANGE unmodified when returning false.
139   //
140   // WATERMARK is a watermark returned by new_change_attempt ().
141   template<typename IgnorePredicate>
142   bool add_regno_clobber (obstack_watermark &watermark, insn_change &change,
143 			  unsigned int regno, IgnorePredicate ignore);
144 
145   // Return true if change_insns will be able to perform the changes
146   // described by CHANGES.
147   bool verify_insn_changes (array_slice<insn_change *const> changes);
148 
149   // Perform all the changes in CHANGES, keeping the instructions in the
150   // order specified by the CHANGES array.  On return, the SSA information
151   // remains up-to-date.  The same is true for instruction-level DF
152   // information, although the block-level DF information might be
153   // marked dirty.
154   void change_insns (array_slice<insn_change *> changes);
155 
156   // Like change_insns, but for a single change CHANGE.
157   void change_insn (insn_change &change);
158 
159   // If the changes that have been made to instructions require updates
160   // to the CFG, perform those updates now.  Return true if something changed.
161   // If it did:
162   //
163   // - The SSA information is now invalid and needs to be recomputed.
164   //
165   // - Dominance information is no longer available (in either direction).
166   //
167   // - The caller will need to call cleanup_cfg at some point.
168   //
169   // ??? We could probably update the SSA information for simple updates,
170   // but currently nothing would benefit.  These late CFG changes are
171   // relatively rare anyway, since gimple optimisers should remove most
172   // unnecessary control flow.
173   bool perform_pending_updates ();
174 
175   // Print the contents of the function to PP.
176   void print (pretty_printer *pp) const;
177 
178 private:
179   class bb_phi_info;
180   class build_info;
181   class bb_walker;
182 
183   // Return an RAII object that owns all objects allocated by
184   // allocate_temp during its lifetime.
185   obstack_watermark temp_watermark () { return &m_temp_obstack; }
186 
187   template<typename T, typename... Ts>
188   T *allocate (Ts... args);
189 
190   template<typename T, typename... Ts>
191   T *allocate_temp (Ts... args);
192 
193   access_array temp_access_array (access_array accesses);
194 
195   clobber_group *need_clobber_group (clobber_info *);
196   def_node *need_def_node (def_info *);
197   def_splay_tree need_def_splay_tree (def_info *);
198 
199   use_info *make_use_available (use_info *, bb_info *);
200   def_array insert_temp_clobber (obstack_watermark &, insn_info *,
201 				 unsigned int, def_array);
202 
203   void insert_def_before (def_info *, def_info *);
204   void insert_def_after (def_info *, def_info *);
205   void remove_def_from_list (def_info *);
206 
207   void add_clobber (clobber_info *, clobber_group *);
208   void remove_clobber (clobber_info *, clobber_group *);
209   void prepend_clobber_to_group (clobber_info *, clobber_group *);
210   void append_clobber_to_group (clobber_info *, clobber_group *);
211   void merge_clobber_groups (clobber_info *, clobber_info *,
212 			     def_info *);
213   clobber_info *split_clobber_group (clobber_group *, insn_info *);
214 
215   void append_def (def_info *);
216   void add_def (def_info *);
217   void remove_def (def_info *);
218 
219   void need_use_splay_tree (set_info *);
220 
221   static void insert_use_before (use_info *, use_info *);
222   static void insert_use_after (use_info *, use_info *);
223 
224   void add_use (use_info *);
225   void remove_use (use_info *);
226 
227   insn_info::order_node *need_order_node (insn_info *);
228 
229   void add_insn_after (insn_info *, insn_info *);
230   void append_insn (insn_info *);
231   void remove_insn (insn_info *);
232 
233   insn_info *append_artificial_insn (bb_info *, rtx_insn * = nullptr);
234 
235   void start_insn_accesses ();
236   void finish_insn_accesses (insn_info *);
237 
238   use_info *create_reg_use (build_info &, insn_info *, resource_info);
239   void record_use (build_info &, insn_info *, rtx_obj_reference);
240   void record_call_clobbers (build_info &, insn_info *, rtx_call_insn *);
241   void record_def (build_info &, insn_info *, rtx_obj_reference);
242   void add_insn_to_block (build_info &, rtx_insn *);
243 
244   void add_reg_unused_notes (insn_info *);
245 
246   void add_live_out_use (bb_info *, set_info *);
247   set_info *live_out_value (bb_info *, set_info *);
248 
249   void append_phi (ebb_info *, phi_info *);
250   void remove_phi (phi_info *);
251   void delete_phi (phi_info *);
252   void replace_phi (phi_info *, set_info *);
253   phi_info *create_phi (ebb_info *, resource_info, access_info **,
254 			unsigned int);
255   phi_info *create_degenerate_phi (ebb_info *, set_info *);
256 
257   bb_info *create_bb_info (basic_block);
258   void append_bb (bb_info *);
259 
260   insn_info *add_placeholder_after (insn_info *);
261   void possibly_queue_changes (insn_change &);
262   void finalize_new_accesses (insn_change &);
263   void apply_changes_to_insn (insn_change &);
264 
265   void init_function_data ();
266   void calculate_potential_phi_regs (build_info &);
267   void place_phis (build_info &);
268   void create_ebbs (build_info &);
269   void add_entry_block_defs (build_info &);
270   void calculate_ebb_live_in_for_debug (build_info &);
271   void add_phi_nodes (build_info &);
272   void add_artificial_accesses (build_info &, df_ref_flags);
273   void add_block_contents (build_info &);
274   void record_block_live_out (build_info &);
275   void start_block (build_info &, bb_info *);
276   void end_block (build_info &, bb_info *);
277   void populate_phi_inputs (build_info &);
278   void process_all_blocks ();
279 
280   void simplify_phi_setup (phi_info *, set_info **, bitmap);
281   void simplify_phi_propagate (phi_info *, set_info **, bitmap, bitmap);
282   void simplify_phis ();
283 
284   // The function that this object describes.
285   function *m_fn;
286 
287   // The lowest (negative) in-use artificial insn uid minus one.
288   int m_next_artificial_uid;
289 
290   // The highest in-use phi uid plus one.
291   unsigned int m_next_phi_uid;
292 
293   // The highest in-use register number plus one.
294   unsigned int m_num_regs;
295 
296   // M_DEFS[R] is the first definition of register R - 1 in a reverse
297   // postorder traversal of the function, or null if the function has
298   // no definition of R.  Applying last () gives the last definition of R.
299   //
300   // M_DEFS[0] is for memory; MEM_REGNO + 1 == 0.
301   auto_vec<def_info *> m_defs;
302 
303   // M_BBS[BI] gives the SSA information about the block with index BI.
304   auto_vec<bb_info *> m_bbs;
305 
306   // An obstack used to allocate the main RTL SSA information.
307   obstack m_obstack;
308 
309   // An obstack used for temporary work, such as while building up a list
310   // of possible instruction changes.
311   obstack m_temp_obstack;
312 
313   // The start of each obstack, so that all memory in them can be freed.
314   char *m_obstack_start;
315   char *m_temp_obstack_start;
316 
317   // The entry and exit blocks.
318   bb_info *m_first_bb;
319   bb_info *m_last_bb;
320 
321   // The first and last instructions in a reverse postorder traversal
322   // of the function.
323   insn_info *m_first_insn;
324   insn_info *m_last_insn;
325 
326   // The last nondebug instruction in the list of instructions.
327   // This is only different from m_last_insn when building the initial
328   // SSA information; after that, the last instruction is always a
329   // BB end instruction.
330   insn_info *m_last_nondebug_insn;
331 
332   // Temporary working state when building up lists of definitions and uses.
333   // Keeping them around should reduce the number of unnecessary reallocations.
334   auto_vec<access_info *> m_temp_defs;
335   auto_vec<access_info *> m_temp_uses;
336 
337   // A list of phis that are no longer in use.  Their uids are still unique
338   // and so can be recycled.
339   phi_info *m_free_phis;
340 
341   // A list of instructions that have been changed in ways that need
342   // further processing later, such as removing dead instructions or
343   // altering the CFG.
344   auto_vec<insn_info *> m_queued_insn_updates;
345 
346   // The INSN_UIDs of all instructions in M_QUEUED_INSN_UPDATES.
347   auto_bitmap m_queued_insn_update_uids;
348 
349   // A basic_block is in this bitmap if we need to call purge_dead_edges
350   // on it.  As with M_QUEUED_INSN_UPDATES, these updates are queued until
351   // a convenient point.
352   auto_bitmap m_need_to_purge_dead_edges;
353 };
354 
355 void pp_function (pretty_printer *, const function_info *);
356 }
357 
358 void dump (FILE *, const rtl_ssa::function_info *);
359 
360 void DEBUG_FUNCTION debug (const rtl_ssa::function_info *);
361