]>
Commit | Line | Data |
---|---|---|
ca4be2a0 | 1 | /* Description of pass structure |
f1717362 | 2 | Copyright (C) 1987-2016 Free Software Foundation, Inc. |
ca4be2a0 | 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 | /* | |
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); | |
22e3dcee | 127 | NEXT_PASS (pass_parallelize_loops, true /* oacc_kernels_p */); |
f71e6ee5 | 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); |
56686608 | 154 | NEXT_PASS (pass_ipa_hsa); |
ca4be2a0 | 155 | NEXT_PASS (pass_ipa_inline); |
156 | NEXT_PASS (pass_ipa_pure_const); | |
157 | NEXT_PASS (pass_ipa_reference); | |
3f1f2be0 | 158 | /* This pass needs to be scheduled after any IP code duplication. */ |
159 | NEXT_PASS (pass_ipa_single_use); | |
cf8b23bb | 160 | /* Comdat privatization come last, as direct references to comdat local |
161 | symbols are not allowed outside of the comdat group. Privatizing early | |
162 | would result in missed optimizations due to this restriction. */ | |
163 | NEXT_PASS (pass_ipa_comdats); | |
ca4be2a0 | 164 | TERMINATE_PASS_LIST () |
165 | ||
ca4be2a0 | 166 | /* Simple IPA passes executed after the regular passes. In WHOPR mode the |
167 | passes are executed after partitioning and thus see just parts of the | |
168 | compiled unit. */ | |
169 | INSERT_PASSES_AFTER (all_late_ipa_passes) | |
170 | NEXT_PASS (pass_ipa_pta); | |
ab50af2a | 171 | NEXT_PASS (pass_dispatcher_calls); |
d09768a4 | 172 | NEXT_PASS (pass_omp_simd_clone); |
ca4be2a0 | 173 | TERMINATE_PASS_LIST () |
174 | ||
175 | /* These passes are run after IPA passes on every function that is being | |
176 | output to the assembler file. */ | |
177 | INSERT_PASSES_AFTER (all_passes) | |
f34e160b | 178 | NEXT_PASS (pass_fixup_cfg); |
ca4be2a0 | 179 | NEXT_PASS (pass_lower_eh_dispatch); |
0bb0f256 | 180 | NEXT_PASS (pass_oacc_device_lower); |
c0998828 | 181 | NEXT_PASS (pass_omp_target_link); |
ca4be2a0 | 182 | NEXT_PASS (pass_all_optimizations); |
183 | PUSH_INSERT_PASSES_WITHIN (pass_all_optimizations) | |
184 | NEXT_PASS (pass_remove_cgraph_callee_edges); | |
185 | /* Initial scalar cleanups before alias computation. | |
186 | They ensure memory accesses are not indirect wherever possible. */ | |
187 | NEXT_PASS (pass_strip_predict_hints); | |
d0322b7d | 188 | NEXT_PASS (pass_ccp, true /* nonzero_p */); |
ca4be2a0 | 189 | /* After CCP we rewrite no longer addressed locals into SSA |
190 | form if possible. */ | |
b2e502cd | 191 | NEXT_PASS (pass_complete_unrolli); |
7fc2f613 | 192 | NEXT_PASS (pass_backprop); |
ca4be2a0 | 193 | NEXT_PASS (pass_phiprop); |
194 | NEXT_PASS (pass_forwprop); | |
0bb8a43b | 195 | NEXT_PASS (pass_object_sizes, false /* insert_min_max_p */); |
ca4be2a0 | 196 | /* pass_build_alias is a dummy pass that ensures that we |
197 | execute TODO_rebuild_alias at this point. */ | |
198 | NEXT_PASS (pass_build_alias); | |
199 | NEXT_PASS (pass_return_slot); | |
200 | NEXT_PASS (pass_fre); | |
ca4be2a0 | 201 | NEXT_PASS (pass_merge_phi); |
bc179819 | 202 | NEXT_PASS (pass_vrp, true /* warn_array_bounds_p */); |
058a1b7a | 203 | NEXT_PASS (pass_chkp_opt); |
ca4be2a0 | 204 | NEXT_PASS (pass_dce); |
379c7683 | 205 | NEXT_PASS (pass_stdarg); |
ca4be2a0 | 206 | NEXT_PASS (pass_call_cdce); |
207 | NEXT_PASS (pass_cselim); | |
5f4d66ea | 208 | NEXT_PASS (pass_copy_prop); |
ca4be2a0 | 209 | NEXT_PASS (pass_tree_ifcombine); |
cce09224 | 210 | NEXT_PASS (pass_merge_phi); |
ca4be2a0 | 211 | NEXT_PASS (pass_phiopt); |
212 | NEXT_PASS (pass_tail_recursion); | |
213 | NEXT_PASS (pass_ch); | |
ca4be2a0 | 214 | NEXT_PASS (pass_lower_complex); |
215 | NEXT_PASS (pass_sra); | |
ca4be2a0 | 216 | /* The dom pass will also resolve all __builtin_constant_p calls |
217 | that are still there to 0. This has to be done after some | |
218 | propagations have already run, but before some more dead code | |
219 | is removed, and this place fits nicely. Remember this when | |
220 | trying to move or duplicate pass_dominator somewhere earlier. */ | |
3279ea23 | 221 | NEXT_PASS (pass_dominator, true /* may_peel_loop_headers_p */); |
db242b6d | 222 | /* At this point the majority of const/copy propagations |
223 | are exposed. Go ahead and identify paths that should never | |
224 | be executed in a conforming program and isolate those paths. | |
225 | ||
226 | This will expose more degenerate PHIs in the main path and | |
227 | expose more PRE/DOM optimization opportunities. */ | |
228 | NEXT_PASS (pass_isolate_erroneous_paths); | |
ca4be2a0 | 229 | /* The only const/copy propagation opportunities left after |
db242b6d | 230 | DOM and erroneous path isolation should be due to degenerate PHI nodes. |
231 | So rather than run the full propagators, run a specialized pass which | |
ca4be2a0 | 232 | only examines PHIs to discover const/copy propagation |
233 | opportunities. */ | |
234 | NEXT_PASS (pass_phi_only_cprop); | |
235 | NEXT_PASS (pass_dse); | |
83505659 | 236 | NEXT_PASS (pass_reassoc, true /* insert_powi_p */); |
ca4be2a0 | 237 | NEXT_PASS (pass_dce); |
238 | NEXT_PASS (pass_forwprop); | |
239 | NEXT_PASS (pass_phiopt); | |
d0322b7d | 240 | NEXT_PASS (pass_ccp, true /* nonzero_p */); |
ca4be2a0 | 241 | /* After CCP we rewrite no longer addressed locals into SSA |
242 | form if possible. */ | |
ca4be2a0 | 243 | NEXT_PASS (pass_cse_sincos); |
244 | NEXT_PASS (pass_optimize_bswap); | |
07d294f7 | 245 | NEXT_PASS (pass_laddress); |
ca4be2a0 | 246 | NEXT_PASS (pass_split_crit_edges); |
247 | NEXT_PASS (pass_pre); | |
248 | NEXT_PASS (pass_sink_code); | |
d29e939c | 249 | NEXT_PASS (pass_sancov); |
ca4be2a0 | 250 | NEXT_PASS (pass_asan); |
251 | NEXT_PASS (pass_tsan); | |
ef3f2b6f | 252 | /* Pass group that runs when 1) enabled, 2) there are loops |
bf8e217d | 253 | in the function. Make sure to run pass_fix_loops before |
254 | to discover/remove loops before running the gate function | |
255 | of pass_tree_loop. */ | |
256 | NEXT_PASS (pass_fix_loops); | |
ca4be2a0 | 257 | NEXT_PASS (pass_tree_loop); |
258 | PUSH_INSERT_PASSES_WITHIN (pass_tree_loop) | |
259 | NEXT_PASS (pass_tree_loop_init); | |
260 | NEXT_PASS (pass_lim); | |
261 | NEXT_PASS (pass_copy_prop); | |
c919e493 | 262 | NEXT_PASS (pass_dce); |
ca4be2a0 | 263 | NEXT_PASS (pass_tree_unswitch); |
264 | NEXT_PASS (pass_scev_cprop); | |
265 | NEXT_PASS (pass_record_bounds); | |
ca4be2a0 | 266 | NEXT_PASS (pass_loop_distribution); |
267 | NEXT_PASS (pass_copy_prop); | |
268 | NEXT_PASS (pass_graphite); | |
269 | PUSH_INSERT_PASSES_WITHIN (pass_graphite) | |
270 | NEXT_PASS (pass_graphite_transforms); | |
271 | NEXT_PASS (pass_lim); | |
272 | NEXT_PASS (pass_copy_prop); | |
c919e493 | 273 | NEXT_PASS (pass_dce); |
ca4be2a0 | 274 | POP_INSERT_PASSES () |
275 | NEXT_PASS (pass_iv_canon); | |
31c2b13b | 276 | NEXT_PASS (pass_parallelize_loops, false /* oacc_kernels_p */); |
e6db04d7 | 277 | NEXT_PASS (pass_expand_omp_ssa); |
e7f9a223 | 278 | NEXT_PASS (pass_ch_vect); |
ca4be2a0 | 279 | NEXT_PASS (pass_if_conversion); |
c71d3c24 | 280 | /* pass_vectorize must immediately follow pass_if_conversion. |
281 | Please do not add any other passes in between. */ | |
ca4be2a0 | 282 | NEXT_PASS (pass_vectorize); |
283 | PUSH_INSERT_PASSES_WITHIN (pass_vectorize) | |
c919e493 | 284 | NEXT_PASS (pass_dce); |
ca4be2a0 | 285 | POP_INSERT_PASSES () |
286 | NEXT_PASS (pass_predcom); | |
287 | NEXT_PASS (pass_complete_unroll); | |
288 | NEXT_PASS (pass_slp_vectorize); | |
289 | NEXT_PASS (pass_loop_prefetch); | |
ef3f2b6f | 290 | /* Run IVOPTs after the last pass that uses data-reference analysis |
291 | as that doesn't handle TARGET_MEM_REFs. */ | |
ca4be2a0 | 292 | NEXT_PASS (pass_iv_optimize); |
293 | NEXT_PASS (pass_lim); | |
294 | NEXT_PASS (pass_tree_loop_done); | |
295 | POP_INSERT_PASSES () | |
ef3f2b6f | 296 | /* Pass group that runs when pass_tree_loop is disabled or there |
297 | are no loops in the function. */ | |
298 | NEXT_PASS (pass_tree_no_loop); | |
299 | PUSH_INSERT_PASSES_WITHIN (pass_tree_no_loop) | |
300 | NEXT_PASS (pass_slp_vectorize); | |
301 | POP_INSERT_PASSES () | |
9918db44 | 302 | NEXT_PASS (pass_simduid_cleanup); |
ca4be2a0 | 303 | NEXT_PASS (pass_lower_vector_ssa); |
304 | NEXT_PASS (pass_cse_reciprocals); | |
83505659 | 305 | NEXT_PASS (pass_reassoc, false /* insert_powi_p */); |
ca4be2a0 | 306 | NEXT_PASS (pass_strength_reduction); |
ae31bfaa | 307 | NEXT_PASS (pass_split_paths); |
388748aa | 308 | NEXT_PASS (pass_tracer); |
3279ea23 | 309 | NEXT_PASS (pass_dominator, false /* may_peel_loop_headers_p */); |
9f15ed6e | 310 | NEXT_PASS (pass_strlen); |
bc179819 | 311 | NEXT_PASS (pass_vrp, false /* warn_array_bounds_p */); |
ca4be2a0 | 312 | /* The only const/copy propagation opportunities left after |
b037180f | 313 | DOM and VRP should be due to degenerate PHI nodes. So rather than |
ca4be2a0 | 314 | run the full propagators, run a specialized pass which |
315 | only examines PHIs to discover const/copy propagation | |
316 | opportunities. */ | |
317 | NEXT_PASS (pass_phi_only_cprop); | |
ca4be2a0 | 318 | NEXT_PASS (pass_cd_dce); |
55bc8a5a | 319 | NEXT_PASS (pass_dse); |
320 | NEXT_PASS (pass_forwprop); | |
321 | NEXT_PASS (pass_phiopt); | |
322 | NEXT_PASS (pass_fold_builtins); | |
323 | NEXT_PASS (pass_optimize_widening_mul); | |
324 | NEXT_PASS (pass_tail_calls); | |
ca4be2a0 | 325 | /* FIXME: If DCE is not run before checking for uninitialized uses, |
326 | we may get false warnings (e.g., testsuite/gcc.dg/uninit-5.c). | |
327 | However, this also causes us to misdiagnose cases that should be | |
328 | real warnings (e.g., testsuite/gcc.dg/pr18501.c). | |
329 | ||
330 | To fix the false positives in uninit-5.c, we would have to | |
331 | account for the predicates protecting the set and the use of each | |
332 | variable. Using a representation like Gated Single Assignment | |
333 | may help. */ | |
13089d2b | 334 | /* Split critical edges before late uninit warning to reduce the |
335 | number of false positives from it. */ | |
336 | NEXT_PASS (pass_split_crit_edges); | |
ca4be2a0 | 337 | NEXT_PASS (pass_late_warn_uninitialized); |
ca4be2a0 | 338 | NEXT_PASS (pass_uncprop); |
339 | NEXT_PASS (pass_local_pure_const); | |
340 | POP_INSERT_PASSES () | |
341 | NEXT_PASS (pass_all_optimizations_g); | |
342 | PUSH_INSERT_PASSES_WITHIN (pass_all_optimizations_g) | |
343 | NEXT_PASS (pass_remove_cgraph_callee_edges); | |
344 | NEXT_PASS (pass_strip_predict_hints); | |
345 | /* Lower remaining pieces of GIMPLE. */ | |
346 | NEXT_PASS (pass_lower_complex); | |
347 | NEXT_PASS (pass_lower_vector_ssa); | |
348 | /* Perform simple scalar cleanup which is constant/copy propagation. */ | |
d0322b7d | 349 | NEXT_PASS (pass_ccp, true /* nonzero_p */); |
ca4be2a0 | 350 | NEXT_PASS (pass_object_sizes); |
351 | /* Fold remaining builtins. */ | |
352 | NEXT_PASS (pass_fold_builtins); | |
353 | /* Copy propagation also copy-propagates constants, this is necessary | |
354 | to forward object-size and builtin folding results properly. */ | |
355 | NEXT_PASS (pass_copy_prop); | |
356 | NEXT_PASS (pass_dce); | |
d29e939c | 357 | NEXT_PASS (pass_sancov); |
ca4be2a0 | 358 | NEXT_PASS (pass_asan); |
359 | NEXT_PASS (pass_tsan); | |
ca4be2a0 | 360 | /* ??? We do want some kind of loop invariant motion, but we possibly |
361 | need to adjust LIM to be more friendly towards preserving accurate | |
362 | debug information here. */ | |
13089d2b | 363 | /* Split critical edges before late uninit warning to reduce the |
364 | number of false positives from it. */ | |
365 | NEXT_PASS (pass_split_crit_edges); | |
ca4be2a0 | 366 | NEXT_PASS (pass_late_warn_uninitialized); |
367 | NEXT_PASS (pass_uncprop); | |
368 | NEXT_PASS (pass_local_pure_const); | |
369 | POP_INSERT_PASSES () | |
370 | NEXT_PASS (pass_tm_init); | |
371 | PUSH_INSERT_PASSES_WITHIN (pass_tm_init) | |
372 | NEXT_PASS (pass_tm_mark); | |
373 | NEXT_PASS (pass_tm_memopt); | |
374 | NEXT_PASS (pass_tm_edges); | |
375 | POP_INSERT_PASSES () | |
43895be5 | 376 | NEXT_PASS (pass_simduid_cleanup); |
b710ec85 | 377 | NEXT_PASS (pass_vtable_verify); |
82fc0e0a | 378 | NEXT_PASS (pass_lower_vaarg); |
ca4be2a0 | 379 | NEXT_PASS (pass_lower_vector); |
380 | NEXT_PASS (pass_lower_complex_O0); | |
d29e939c | 381 | NEXT_PASS (pass_sancov_O0); |
ca4be2a0 | 382 | NEXT_PASS (pass_asan_O0); |
383 | NEXT_PASS (pass_tsan_O0); | |
19b928d9 | 384 | NEXT_PASS (pass_sanopt); |
ca4be2a0 | 385 | NEXT_PASS (pass_cleanup_eh); |
386 | NEXT_PASS (pass_lower_resx); | |
387 | NEXT_PASS (pass_nrv); | |
ca4be2a0 | 388 | NEXT_PASS (pass_cleanup_cfg_post_optimizing); |
389 | NEXT_PASS (pass_warn_function_noreturn); | |
56686608 | 390 | NEXT_PASS (pass_gen_hsail); |
ca4be2a0 | 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 () |