]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/passes.def
gcc/
[thirdparty/gcc.git] / gcc / passes.def
CommitLineData
ca4be2a0 1/* Description of pass structure
d353bf18 2 Copyright (C) 1987-2015 Free Software Foundation, Inc.
ca4be2a0 3
4This file is part of GCC.
5
6GCC is free software; you can redistribute it and/or modify it under
7the terms of the GNU General Public License as published by the Free
8Software Foundation; either version 3, or (at your option) any later
9version.
10
11GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12WARRANTY; without even the implied warranty of MERCHANTABILITY or
13FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14for more details.
15
16You should have received a copy of the GNU General Public License
17along with GCC; see the file COPYING3. If not see
18<http://www.gnu.org/licenses/>. */
19
20/*
21 Macros that should be defined when using this file:
22 INSERT_PASSES_AFTER (PASS)
23 PUSH_INSERT_PASSES_WITHIN (PASS)
24 POP_INSERT_PASSES ()
25 NEXT_PASS (PASS)
26 TERMINATE_PASS_LIST ()
27 */
28
29 /* All passes needed to lower the function into shape optimizers can
30 operate on. These passes are always run first on the function, but
31 backend might produce already lowered functions that are not processed
32 by these passes. */
33 INSERT_PASSES_AFTER (all_lowering_passes)
34 NEXT_PASS (pass_warn_unused_result);
35 NEXT_PASS (pass_diagnose_omp_blocks);
36 NEXT_PASS (pass_diagnose_tm_blocks);
ca4be2a0 37 NEXT_PASS (pass_lower_omp);
38 NEXT_PASS (pass_lower_cf);
39 NEXT_PASS (pass_lower_tm);
40 NEXT_PASS (pass_refactor_eh);
41 NEXT_PASS (pass_lower_eh);
42 NEXT_PASS (pass_build_cfg);
43 NEXT_PASS (pass_warn_function_return);
44 NEXT_PASS (pass_expand_omp);
45 NEXT_PASS (pass_build_cgraph_edges);
46 TERMINATE_PASS_LIST ()
47
48 /* Interprocedural optimization passes. */
49 INSERT_PASSES_AFTER (all_small_ipa_passes)
50 NEXT_PASS (pass_ipa_free_lang_data);
51 NEXT_PASS (pass_ipa_function_and_variable_visibility);
058a1b7a 52 NEXT_PASS (pass_ipa_chkp_versioning);
312322ab 53 NEXT_PASS (pass_ipa_chkp_early_produce_thunks);
058a1b7a 54 NEXT_PASS (pass_build_ssa_passes);
55 PUSH_INSERT_PASSES_WITHIN (pass_build_ssa_passes)
ca4be2a0 56 NEXT_PASS (pass_fixup_cfg);
57 NEXT_PASS (pass_init_datastructures);
ca4be2a0 58 NEXT_PASS (pass_build_ssa);
19b928d9 59 NEXT_PASS (pass_ubsan);
ca4be2a0 60 NEXT_PASS (pass_early_warn_uninitialized);
73594827 61 NEXT_PASS (pass_nothrow);
058a1b7a 62 POP_INSERT_PASSES ()
63
64 NEXT_PASS (pass_chkp_instrumentation_passes);
65 PUSH_INSERT_PASSES_WITHIN (pass_chkp_instrumentation_passes)
66 NEXT_PASS (pass_fixup_cfg);
67 NEXT_PASS (pass_chkp);
68 NEXT_PASS (pass_rebuild_cgraph_edges);
69 POP_INSERT_PASSES ()
058a1b7a 70
71 NEXT_PASS (pass_local_optimization_passes);
72 PUSH_INSERT_PASSES_WITHIN (pass_local_optimization_passes)
73 NEXT_PASS (pass_fixup_cfg);
ca4be2a0 74 NEXT_PASS (pass_rebuild_cgraph_edges);
75 NEXT_PASS (pass_inline_parameters);
76 NEXT_PASS (pass_early_inline);
77 NEXT_PASS (pass_all_early_optimizations);
78 PUSH_INSERT_PASSES_WITHIN (pass_all_early_optimizations)
79 NEXT_PASS (pass_remove_cgraph_callee_edges);
0bb8a43b 80 NEXT_PASS (pass_object_sizes, true /* insert_min_max_p */);
d0322b7d 81 /* Don't record nonzero bits before IPA to avoid
82 using too much memory. */
83 NEXT_PASS (pass_ccp, false /* nonzero_p */);
ca4be2a0 84 /* After CCP we rewrite no longer addressed locals into SSA
85 form if possible. */
86 NEXT_PASS (pass_forwprop);
41f94d6c 87 NEXT_PASS (pass_sra_early);
ca4be2a0 88 /* pass_build_ealias is a dummy pass that ensures that we
89 execute TODO_rebuild_alias at this point. */
90 NEXT_PASS (pass_build_ealias);
ca4be2a0 91 NEXT_PASS (pass_fre);
ca4be2a0 92 NEXT_PASS (pass_merge_phi);
23db877c 93 NEXT_PASS (pass_dse);
ca4be2a0 94 NEXT_PASS (pass_cd_dce);
95 NEXT_PASS (pass_early_ipa_sra);
96 NEXT_PASS (pass_tail_recursion);
97 NEXT_PASS (pass_convert_switch);
058a1b7a 98 NEXT_PASS (pass_cleanup_eh);
99 NEXT_PASS (pass_profile);
100 NEXT_PASS (pass_local_pure_const);
ca4be2a0 101 /* Split functions creates parts that are not run through
102 early optimizations again. It is thus good idea to do this
058a1b7a 103 late. */
104 NEXT_PASS (pass_split_functions);
ca4be2a0 105 POP_INSERT_PASSES ()
106 NEXT_PASS (pass_release_ssa_names);
107 NEXT_PASS (pass_rebuild_cgraph_edges);
108 NEXT_PASS (pass_inline_parameters);
109 POP_INSERT_PASSES ()
f71e6ee5 110
111 NEXT_PASS (pass_ipa_oacc);
112 PUSH_INSERT_PASSES_WITHIN (pass_ipa_oacc)
113 NEXT_PASS (pass_ipa_pta);
114 /* Pass group that runs when the function is an offloaded function
115 containing oacc kernels loops. */
116 NEXT_PASS (pass_ipa_oacc_kernels);
117 PUSH_INSERT_PASSES_WITHIN (pass_ipa_oacc_kernels)
118 NEXT_PASS (pass_oacc_kernels);
119 PUSH_INSERT_PASSES_WITHIN (pass_oacc_kernels)
120 NEXT_PASS (pass_ch);
121 NEXT_PASS (pass_fre);
122 /* We use pass_lim to rewrite in-memory iteration and reduction
123 variable accesses in loops into local variables accesses. */
124 NEXT_PASS (pass_lim);
125 NEXT_PASS (pass_dominator, false /* may_peel_loop_headers_p */);
126 NEXT_PASS (pass_dce);
127 /* pass_parallelize_loops_oacc_kernels */
128 NEXT_PASS (pass_expand_omp_ssa);
129 NEXT_PASS (pass_rebuild_cgraph_edges);
130 POP_INSERT_PASSES ()
131 POP_INSERT_PASSES ()
132 POP_INSERT_PASSES ()
133
312322ab 134 NEXT_PASS (pass_ipa_chkp_produce_thunks);
94bed7c3 135 NEXT_PASS (pass_ipa_auto_profile);
ca4be2a0 136 NEXT_PASS (pass_ipa_free_inline_summary);
137 NEXT_PASS (pass_ipa_tree_profile);
138 PUSH_INSERT_PASSES_WITHIN (pass_ipa_tree_profile)
139 NEXT_PASS (pass_feedback_split_functions);
140 POP_INSERT_PASSES ()
141 NEXT_PASS (pass_ipa_increase_alignment);
142 NEXT_PASS (pass_ipa_tm);
143 NEXT_PASS (pass_ipa_lower_emutls);
144 TERMINATE_PASS_LIST ()
145
146 INSERT_PASSES_AFTER (all_regular_ipa_passes)
147 NEXT_PASS (pass_ipa_whole_program_visibility);
148 NEXT_PASS (pass_ipa_profile);
52200d03 149 NEXT_PASS (pass_ipa_icf);
84f6cc40 150 NEXT_PASS (pass_ipa_devirt);
ca4be2a0 151 NEXT_PASS (pass_ipa_cp);
152 NEXT_PASS (pass_ipa_cdtor_merge);
ab50af2a 153 NEXT_PASS (pass_target_clone);
ca4be2a0 154 NEXT_PASS (pass_ipa_inline);
155 NEXT_PASS (pass_ipa_pure_const);
156 NEXT_PASS (pass_ipa_reference);
3f1f2be0 157 /* This pass needs to be scheduled after any IP code duplication. */
158 NEXT_PASS (pass_ipa_single_use);
cf8b23bb 159 /* Comdat privatization come last, as direct references to comdat local
160 symbols are not allowed outside of the comdat group. Privatizing early
161 would result in missed optimizations due to this restriction. */
162 NEXT_PASS (pass_ipa_comdats);
ca4be2a0 163 TERMINATE_PASS_LIST ()
164
ca4be2a0 165 /* Simple IPA passes executed after the regular passes. In WHOPR mode the
166 passes are executed after partitioning and thus see just parts of the
167 compiled unit. */
168 INSERT_PASSES_AFTER (all_late_ipa_passes)
169 NEXT_PASS (pass_ipa_pta);
ab50af2a 170 NEXT_PASS (pass_dispatcher_calls);
d09768a4 171 NEXT_PASS (pass_omp_simd_clone);
ca4be2a0 172 TERMINATE_PASS_LIST ()
173
174 /* These passes are run after IPA passes on every function that is being
175 output to the assembler file. */
176 INSERT_PASSES_AFTER (all_passes)
f34e160b 177 NEXT_PASS (pass_fixup_cfg);
ca4be2a0 178 NEXT_PASS (pass_lower_eh_dispatch);
0bb0f256 179 NEXT_PASS (pass_oacc_device_lower);
c0998828 180 NEXT_PASS (pass_omp_target_link);
ca4be2a0 181 NEXT_PASS (pass_all_optimizations);
182 PUSH_INSERT_PASSES_WITHIN (pass_all_optimizations)
183 NEXT_PASS (pass_remove_cgraph_callee_edges);
184 /* Initial scalar cleanups before alias computation.
185 They ensure memory accesses are not indirect wherever possible. */
186 NEXT_PASS (pass_strip_predict_hints);
d0322b7d 187 NEXT_PASS (pass_ccp, true /* nonzero_p */);
ca4be2a0 188 /* After CCP we rewrite no longer addressed locals into SSA
189 form if possible. */
b2e502cd 190 NEXT_PASS (pass_complete_unrolli);
7fc2f613 191 NEXT_PASS (pass_backprop);
ca4be2a0 192 NEXT_PASS (pass_phiprop);
193 NEXT_PASS (pass_forwprop);
0bb8a43b 194 NEXT_PASS (pass_object_sizes, false /* insert_min_max_p */);
ca4be2a0 195 /* pass_build_alias is a dummy pass that ensures that we
196 execute TODO_rebuild_alias at this point. */
197 NEXT_PASS (pass_build_alias);
198 NEXT_PASS (pass_return_slot);
199 NEXT_PASS (pass_fre);
ca4be2a0 200 NEXT_PASS (pass_merge_phi);
bc179819 201 NEXT_PASS (pass_vrp, true /* warn_array_bounds_p */);
058a1b7a 202 NEXT_PASS (pass_chkp_opt);
ca4be2a0 203 NEXT_PASS (pass_dce);
379c7683 204 NEXT_PASS (pass_stdarg);
ca4be2a0 205 NEXT_PASS (pass_call_cdce);
206 NEXT_PASS (pass_cselim);
5f4d66ea 207 NEXT_PASS (pass_copy_prop);
ca4be2a0 208 NEXT_PASS (pass_tree_ifcombine);
cce09224 209 NEXT_PASS (pass_merge_phi);
ca4be2a0 210 NEXT_PASS (pass_phiopt);
211 NEXT_PASS (pass_tail_recursion);
212 NEXT_PASS (pass_ch);
ca4be2a0 213 NEXT_PASS (pass_lower_complex);
214 NEXT_PASS (pass_sra);
ca4be2a0 215 /* The dom pass will also resolve all __builtin_constant_p calls
216 that are still there to 0. This has to be done after some
217 propagations have already run, but before some more dead code
218 is removed, and this place fits nicely. Remember this when
219 trying to move or duplicate pass_dominator somewhere earlier. */
3279ea23 220 NEXT_PASS (pass_dominator, true /* may_peel_loop_headers_p */);
db242b6d 221 /* At this point the majority of const/copy propagations
222 are exposed. Go ahead and identify paths that should never
223 be executed in a conforming program and isolate those paths.
224
225 This will expose more degenerate PHIs in the main path and
226 expose more PRE/DOM optimization opportunities. */
227 NEXT_PASS (pass_isolate_erroneous_paths);
ca4be2a0 228 /* The only const/copy propagation opportunities left after
db242b6d 229 DOM and erroneous path isolation should be due to degenerate PHI nodes.
230 So rather than run the full propagators, run a specialized pass which
ca4be2a0 231 only examines PHIs to discover const/copy propagation
232 opportunities. */
233 NEXT_PASS (pass_phi_only_cprop);
234 NEXT_PASS (pass_dse);
83505659 235 NEXT_PASS (pass_reassoc, true /* insert_powi_p */);
ca4be2a0 236 NEXT_PASS (pass_dce);
237 NEXT_PASS (pass_forwprop);
238 NEXT_PASS (pass_phiopt);
d0322b7d 239 NEXT_PASS (pass_ccp, true /* nonzero_p */);
ca4be2a0 240 /* After CCP we rewrite no longer addressed locals into SSA
241 form if possible. */
ca4be2a0 242 NEXT_PASS (pass_cse_sincos);
243 NEXT_PASS (pass_optimize_bswap);
07d294f7 244 NEXT_PASS (pass_laddress);
ca4be2a0 245 NEXT_PASS (pass_split_crit_edges);
246 NEXT_PASS (pass_pre);
247 NEXT_PASS (pass_sink_code);
d29e939c 248 NEXT_PASS (pass_sancov);
ca4be2a0 249 NEXT_PASS (pass_asan);
250 NEXT_PASS (pass_tsan);
ef3f2b6f 251 /* Pass group that runs when 1) enabled, 2) there are loops
bf8e217d 252 in the function. Make sure to run pass_fix_loops before
253 to discover/remove loops before running the gate function
254 of pass_tree_loop. */
255 NEXT_PASS (pass_fix_loops);
ca4be2a0 256 NEXT_PASS (pass_tree_loop);
257 PUSH_INSERT_PASSES_WITHIN (pass_tree_loop)
258 NEXT_PASS (pass_tree_loop_init);
259 NEXT_PASS (pass_lim);
260 NEXT_PASS (pass_copy_prop);
c919e493 261 NEXT_PASS (pass_dce);
ca4be2a0 262 NEXT_PASS (pass_tree_unswitch);
263 NEXT_PASS (pass_scev_cprop);
264 NEXT_PASS (pass_record_bounds);
ca4be2a0 265 NEXT_PASS (pass_loop_distribution);
266 NEXT_PASS (pass_copy_prop);
267 NEXT_PASS (pass_graphite);
268 PUSH_INSERT_PASSES_WITHIN (pass_graphite)
269 NEXT_PASS (pass_graphite_transforms);
270 NEXT_PASS (pass_lim);
271 NEXT_PASS (pass_copy_prop);
c919e493 272 NEXT_PASS (pass_dce);
ca4be2a0 273 POP_INSERT_PASSES ()
274 NEXT_PASS (pass_iv_canon);
275 NEXT_PASS (pass_parallelize_loops);
8917c50b 276 PUSH_INSERT_PASSES_WITHIN (pass_parallelize_loops)
277 NEXT_PASS (pass_expand_omp_ssa);
278 POP_INSERT_PASSES ()
e7f9a223 279 NEXT_PASS (pass_ch_vect);
ca4be2a0 280 NEXT_PASS (pass_if_conversion);
c71d3c24 281 /* pass_vectorize must immediately follow pass_if_conversion.
282 Please do not add any other passes in between. */
ca4be2a0 283 NEXT_PASS (pass_vectorize);
284 PUSH_INSERT_PASSES_WITHIN (pass_vectorize)
c919e493 285 NEXT_PASS (pass_dce);
ca4be2a0 286 POP_INSERT_PASSES ()
287 NEXT_PASS (pass_predcom);
288 NEXT_PASS (pass_complete_unroll);
289 NEXT_PASS (pass_slp_vectorize);
290 NEXT_PASS (pass_loop_prefetch);
ef3f2b6f 291 /* Run IVOPTs after the last pass that uses data-reference analysis
292 as that doesn't handle TARGET_MEM_REFs. */
ca4be2a0 293 NEXT_PASS (pass_iv_optimize);
294 NEXT_PASS (pass_lim);
295 NEXT_PASS (pass_tree_loop_done);
296 POP_INSERT_PASSES ()
ef3f2b6f 297 /* Pass group that runs when pass_tree_loop is disabled or there
298 are no loops in the function. */
299 NEXT_PASS (pass_tree_no_loop);
300 PUSH_INSERT_PASSES_WITHIN (pass_tree_no_loop)
301 NEXT_PASS (pass_slp_vectorize);
302 POP_INSERT_PASSES ()
9918db44 303 NEXT_PASS (pass_simduid_cleanup);
ca4be2a0 304 NEXT_PASS (pass_lower_vector_ssa);
305 NEXT_PASS (pass_cse_reciprocals);
83505659 306 NEXT_PASS (pass_reassoc, false /* insert_powi_p */);
ca4be2a0 307 NEXT_PASS (pass_strength_reduction);
ae31bfaa 308 NEXT_PASS (pass_split_paths);
388748aa 309 NEXT_PASS (pass_tracer);
3279ea23 310 NEXT_PASS (pass_dominator, false /* may_peel_loop_headers_p */);
9f15ed6e 311 NEXT_PASS (pass_strlen);
bc179819 312 NEXT_PASS (pass_vrp, false /* warn_array_bounds_p */);
ca4be2a0 313 /* The only const/copy propagation opportunities left after
b037180f 314 DOM and VRP should be due to degenerate PHI nodes. So rather than
ca4be2a0 315 run the full propagators, run a specialized pass which
316 only examines PHIs to discover const/copy propagation
317 opportunities. */
318 NEXT_PASS (pass_phi_only_cprop);
ca4be2a0 319 NEXT_PASS (pass_cd_dce);
55bc8a5a 320 NEXT_PASS (pass_dse);
321 NEXT_PASS (pass_forwprop);
322 NEXT_PASS (pass_phiopt);
323 NEXT_PASS (pass_fold_builtins);
324 NEXT_PASS (pass_optimize_widening_mul);
325 NEXT_PASS (pass_tail_calls);
ca4be2a0 326 /* FIXME: If DCE is not run before checking for uninitialized uses,
327 we may get false warnings (e.g., testsuite/gcc.dg/uninit-5.c).
328 However, this also causes us to misdiagnose cases that should be
329 real warnings (e.g., testsuite/gcc.dg/pr18501.c).
330
331 To fix the false positives in uninit-5.c, we would have to
332 account for the predicates protecting the set and the use of each
333 variable. Using a representation like Gated Single Assignment
334 may help. */
13089d2b 335 /* Split critical edges before late uninit warning to reduce the
336 number of false positives from it. */
337 NEXT_PASS (pass_split_crit_edges);
ca4be2a0 338 NEXT_PASS (pass_late_warn_uninitialized);
ca4be2a0 339 NEXT_PASS (pass_uncprop);
340 NEXT_PASS (pass_local_pure_const);
341 POP_INSERT_PASSES ()
342 NEXT_PASS (pass_all_optimizations_g);
343 PUSH_INSERT_PASSES_WITHIN (pass_all_optimizations_g)
344 NEXT_PASS (pass_remove_cgraph_callee_edges);
345 NEXT_PASS (pass_strip_predict_hints);
346 /* Lower remaining pieces of GIMPLE. */
347 NEXT_PASS (pass_lower_complex);
348 NEXT_PASS (pass_lower_vector_ssa);
349 /* Perform simple scalar cleanup which is constant/copy propagation. */
d0322b7d 350 NEXT_PASS (pass_ccp, true /* nonzero_p */);
ca4be2a0 351 NEXT_PASS (pass_object_sizes);
352 /* Fold remaining builtins. */
353 NEXT_PASS (pass_fold_builtins);
354 /* Copy propagation also copy-propagates constants, this is necessary
355 to forward object-size and builtin folding results properly. */
356 NEXT_PASS (pass_copy_prop);
357 NEXT_PASS (pass_dce);
d29e939c 358 NEXT_PASS (pass_sancov);
ca4be2a0 359 NEXT_PASS (pass_asan);
360 NEXT_PASS (pass_tsan);
ca4be2a0 361 /* ??? We do want some kind of loop invariant motion, but we possibly
362 need to adjust LIM to be more friendly towards preserving accurate
363 debug information here. */
13089d2b 364 /* Split critical edges before late uninit warning to reduce the
365 number of false positives from it. */
366 NEXT_PASS (pass_split_crit_edges);
ca4be2a0 367 NEXT_PASS (pass_late_warn_uninitialized);
368 NEXT_PASS (pass_uncprop);
369 NEXT_PASS (pass_local_pure_const);
370 POP_INSERT_PASSES ()
371 NEXT_PASS (pass_tm_init);
372 PUSH_INSERT_PASSES_WITHIN (pass_tm_init)
373 NEXT_PASS (pass_tm_mark);
374 NEXT_PASS (pass_tm_memopt);
375 NEXT_PASS (pass_tm_edges);
376 POP_INSERT_PASSES ()
43895be5 377 NEXT_PASS (pass_simduid_cleanup);
b710ec85 378 NEXT_PASS (pass_vtable_verify);
82fc0e0a 379 NEXT_PASS (pass_lower_vaarg);
ca4be2a0 380 NEXT_PASS (pass_lower_vector);
381 NEXT_PASS (pass_lower_complex_O0);
d29e939c 382 NEXT_PASS (pass_sancov_O0);
ca4be2a0 383 NEXT_PASS (pass_asan_O0);
384 NEXT_PASS (pass_tsan_O0);
19b928d9 385 NEXT_PASS (pass_sanopt);
ca4be2a0 386 NEXT_PASS (pass_cleanup_eh);
387 NEXT_PASS (pass_lower_resx);
388 NEXT_PASS (pass_nrv);
ca4be2a0 389 NEXT_PASS (pass_cleanup_cfg_post_optimizing);
390 NEXT_PASS (pass_warn_function_noreturn);
391
392 NEXT_PASS (pass_expand);
393
394 NEXT_PASS (pass_rest_of_compilation);
395 PUSH_INSERT_PASSES_WITHIN (pass_rest_of_compilation)
396 NEXT_PASS (pass_instantiate_virtual_regs);
397 NEXT_PASS (pass_into_cfg_layout_mode);
398 NEXT_PASS (pass_jump);
399 NEXT_PASS (pass_lower_subreg);
400 NEXT_PASS (pass_df_initialize_opt);
401 NEXT_PASS (pass_cse);
402 NEXT_PASS (pass_rtl_fwprop);
403 NEXT_PASS (pass_rtl_cprop);
404 NEXT_PASS (pass_rtl_pre);
405 NEXT_PASS (pass_rtl_hoist);
406 NEXT_PASS (pass_rtl_cprop);
407 NEXT_PASS (pass_rtl_store_motion);
408 NEXT_PASS (pass_cse_after_global_opts);
409 NEXT_PASS (pass_rtl_ifcvt);
410 NEXT_PASS (pass_reginfo_init);
411 /* Perform loop optimizations. It might be better to do them a bit
412 sooner, but we want the profile feedback to work more
413 efficiently. */
414 NEXT_PASS (pass_loop2);
415 PUSH_INSERT_PASSES_WITHIN (pass_loop2)
416 NEXT_PASS (pass_rtl_loop_init);
417 NEXT_PASS (pass_rtl_move_loop_invariants);
c836de3f 418 NEXT_PASS (pass_rtl_unroll_loops);
ca4be2a0 419 NEXT_PASS (pass_rtl_doloop);
420 NEXT_PASS (pass_rtl_loop_done);
ca4be2a0 421 POP_INSERT_PASSES ()
422 NEXT_PASS (pass_web);
423 NEXT_PASS (pass_rtl_cprop);
424 NEXT_PASS (pass_cse2);
425 NEXT_PASS (pass_rtl_dse1);
426 NEXT_PASS (pass_rtl_fwprop_addr);
427 NEXT_PASS (pass_inc_dec);
428 NEXT_PASS (pass_initialize_regs);
429 NEXT_PASS (pass_ud_rtl_dce);
430 NEXT_PASS (pass_combine);
431 NEXT_PASS (pass_if_after_combine);
432 NEXT_PASS (pass_partition_blocks);
ca4be2a0 433 NEXT_PASS (pass_outof_cfg_layout_mode);
434 NEXT_PASS (pass_split_all_insns);
435 NEXT_PASS (pass_lower_subreg2);
436 NEXT_PASS (pass_df_initialize_no_opt);
437 NEXT_PASS (pass_stack_ptr_mod);
438 NEXT_PASS (pass_mode_switching);
439 NEXT_PASS (pass_match_asm_constraints);
440 NEXT_PASS (pass_sms);
57a8bf1b 441 NEXT_PASS (pass_live_range_shrinkage);
ca4be2a0 442 NEXT_PASS (pass_sched);
443 NEXT_PASS (pass_ira);
444 NEXT_PASS (pass_reload);
445 NEXT_PASS (pass_postreload);
446 PUSH_INSERT_PASSES_WITHIN (pass_postreload)
447 NEXT_PASS (pass_postreload_cse);
448 NEXT_PASS (pass_gcse2);
449 NEXT_PASS (pass_split_after_reload);
450 NEXT_PASS (pass_ree);
451 NEXT_PASS (pass_compare_elim_after_reload);
452 NEXT_PASS (pass_branch_target_load_optimize1);
453 NEXT_PASS (pass_thread_prologue_and_epilogue);
454 NEXT_PASS (pass_rtl_dse2);
455 NEXT_PASS (pass_stack_adjustments);
456 NEXT_PASS (pass_jump2);
9f4ec746 457 NEXT_PASS (pass_duplicate_computed_gotos);
012ad66c 458 NEXT_PASS (pass_sched_fusion);
9f4ec746 459 NEXT_PASS (pass_peephole2);
ca4be2a0 460 NEXT_PASS (pass_if_after_reload);
461 NEXT_PASS (pass_regrename);
462 NEXT_PASS (pass_cprop_hardreg);
463 NEXT_PASS (pass_fast_rtl_dce);
464 NEXT_PASS (pass_reorder_blocks);
465 NEXT_PASS (pass_branch_target_load_optimize2);
466 NEXT_PASS (pass_leaf_regs);
467 NEXT_PASS (pass_split_before_sched2);
468 NEXT_PASS (pass_sched2);
469 NEXT_PASS (pass_stack_regs);
470 PUSH_INSERT_PASSES_WITHIN (pass_stack_regs)
471 NEXT_PASS (pass_split_before_regstack);
472 NEXT_PASS (pass_stack_regs_run);
473 POP_INSERT_PASSES ()
6fe9a05b 474 POP_INSERT_PASSES ()
475 NEXT_PASS (pass_late_compilation);
476 PUSH_INSERT_PASSES_WITHIN (pass_late_compilation)
ca4be2a0 477 NEXT_PASS (pass_compute_alignments);
ca4be2a0 478 NEXT_PASS (pass_variable_tracking);
479 NEXT_PASS (pass_free_cfg);
480 NEXT_PASS (pass_machine_reorg);
481 NEXT_PASS (pass_cleanup_barriers);
482 NEXT_PASS (pass_delay_slots);
483 NEXT_PASS (pass_split_for_shorten_branches);
484 NEXT_PASS (pass_convert_to_eh_region_ranges);
485 NEXT_PASS (pass_shorten_branches);
486 NEXT_PASS (pass_set_nothrow_function_flags);
487 NEXT_PASS (pass_dwarf2_frame);
488 NEXT_PASS (pass_final);
489 POP_INSERT_PASSES ()
490 NEXT_PASS (pass_df_finish);
491 POP_INSERT_PASSES ()
492 NEXT_PASS (pass_clean_state);
493 TERMINATE_PASS_LIST ()