re PR target/54089 ([SH] Refactor shift patterns)
[gcc.git] / gcc / ChangeLog
1 2012-08-16 Oleg Endo <olegendo@gcc.gnu.org>
2
3 PR target/54089
4 * config/sh/sh.md (ashlsi3_d): Do not split if it would result
5 in a T_REG clobber. Correct comment.
6 (ashlsi3_n): Correct comment.
7
8 2012-08-16 Hans-Peter Nilsson <hp@axis.com>
9
10 PR middle-end/54261
11 * optabs.c (expand_atomic_fetch_op): Save and restore code when
12 retrying after failed attempt.
13
14 2012-08-16 Yuri Rumyantsev <ysrumyan@gmail.com>
15
16 * config/i386/i386-protos.h (ix86_split_lea_for_addr) : Add
17 additional argument.
18 * config/i386/i386.md (ix86_split_lea_for_addr) : Add
19 additional argument curr_insn.
20 * config/i386/i386.c (ix86_split_lea_for_addr): Load base or index
21 register first, depending on their defintion distances.
22 (ix86_lea_outperforms): Prefer LEA only if split cost exceeds
23 AGU stall.
24 (find_nearest_reg-def): New function. Find register with
25 nearest definition.
26
27 2012-08-16 Walter Lee <walt@tilera.com>
28
29 * config.gcc (tilegx-*-linux*): Add feedback.h.
30 (tilepro-*-linux*): Likewise.
31 * config/tilegx/feedback.h: New file.
32 * config/tilepro/feedback.h: New file.
33
34 2012-08-16 Diego Novillo <dnovillo@google.com>
35
36 Revert
37
38 PR bootstrap/54281
39 * double-int.h: Move including of gmp.h ...
40 * system.h: ... here.
41 * realmpfr.h: Do not include gmp.h.
42 * tree-ssa-loop-niter.c: Do not include gmp.h.
43
44 2012-08-16 Segher Boessenkool <segher@kernel.crashing.org>
45
46 * config/rs6000/darwin.h (TARGET_IEEE_QUAD): Fix comment.
47
48 2012-08-16 Richard Guenther <rguenther@suse.de>
49
50 PR middle-end/54146
51 * tree-ssa-loop-niter.c (find_loop_niter_by_eval): Free the
52 exit vector.
53 * ipa-pure-const.c (analyze_function): Use FOR_EACH_LOOP_BREAK.
54 * cfgloop.h (FOR_EACH_LOOP_BREAK): Fix.
55 * tree-ssa-structalias.c (handle_lhs_call): Properly free rhsc.
56 * tree-into-ssa.c (get_ssa_name_ann): Allocate info only when
57 needed.
58 * tree-ssa-loop-im.c (analyze_memory_references): Adjust.
59 (tree_ssa_lim_finalize): Free all mem_refs.
60 * tree-ssa-sccvn.c (extract_and_process_scc_for_name): Free
61 scc when bailing out.
62 * modulo-sched.c (sms_schedule): Use FOR_EACH_LOOP_BREAK.
63 * ira-build.c (loop_with_complex_edge_p): Free loop exit vector.
64 * graphite-sese-to-poly.c (scop_ivs_can_be_represented): Use
65 FOR_EACH_LOOP_BREAK.
66
67 2012-08-16 Diego Novillo <dnovillo@google.com>
68
69 PR bootstrap/54281
70 * double-int.h: Move including of gmp.h ...
71 * system.h: ... here.
72 * realmpfr.h: Do not include gmp.h.
73 * tree-ssa-loop-niter.c: Do not include gmp.h.
74
75 2012-08-16 Steven Bosscher <steven@gcc.gnu.org>
76
77 PR middle-end/54146
78 * tree-flow.h (compute_global_livein): Remove prototype.
79 * tree-into-ssa.c (compute_global_livein): Remove function.
80 * tree-ssa-loop-manip.c: Include gimple-pretty-print.h.
81 (find_sibling_superloop): New function.
82 (compute_live_loop_exits): New function.
83 (add_exit_phis_edge): Rename to add_exit_phi. Do not allow
84 inserting a PHI in a block that is not a loop exit for VAR.
85 Add dumping if TDF_DETAILS.
86 (add_exit_phis_var): Rewrite.
87 (add_exit_phis): Update.
88 (get_loops_exits): Rewrite to return an array of per-loop exits
89 rather than one bitmap with all loop exits.
90 (find_uses_to_rename_bb): Ignore virtual PHI nodes.
91 (rewrite_into_loop_closed_ssa): Update.
92
93 2012-08-16 Nick Clifton <nickc@redhat.com>
94
95 * config/i386/i386elf.h (ASM_OUTPUT_ASCII): Cast _ascii_bytes
96 before passing it to ASM_OUTPUT_LIMITED_STRING.
97
98 * config/bfin/bfin.c (hwloop_optimize): Fix use of VEC_last macro.
99
100 * config/avr/t-avr: Replace occurrences of $(CC) with $(COMPILER).
101 * config/avr/avr.c (avr_legitimize_reload_address): Add casts
102 for reload_type enums.
103 (DEF_BUILTIN): Cast the icode to enum insn_code.
104
105 2012-08-15 Segher Boessenkool <segher@kernel.crashing.org>
106
107 * config/rs6000/aix43.h (ASM_CPU_SPEC): Use %(asm_default)
108 instead of -mppc.
109 * config/rs6000/aix51.h (ASM_CPU_SPEC): Ditto.
110
111 2012-08-15 Segher Boessenkool <segher@kernel.crashing.org>
112
113 * config/rs6000/aix43.h (TARGET_DEFAULT): Delete MASK_NEW_MNEMONICS.
114 (RS6000_CALL_GLUE): Adjust for single assembler syntax.
115 * config/rs6000/aix51.h (TARGET_DEFAULT, RS6000_CALL_GLUE):
116 Ditto.
117 * config/rs6000/aix52.h (TARGET_DEFAULT, RS6000_CALL_GLUE):
118 Ditto.
119 * config/rs6000/aix53.h (TARGET_DEFAULT, RS6000_CALL_GLUE):
120 Ditto.
121 * config/rs6000/aix61.h (TARGET_DEFAULT, RS6000_CALL_GLUE):
122 Ditto.
123 * config/rs6000/darwin.h (TARGET_DEFAULT): Ditto.
124 * config/rs6000/darwin.md (whole file): Adjust to single
125 assembler syntax.
126 * config/rs6000/darwin64.h (TARGET_DEFAULT): Delete
127 MASK_NEW_MNEMONICS.
128 * config/rs6000/default64.h (TARGET_DEFAULT): Ditto.
129 * config/rs6000/dfp.md: (whole file): Adjust to single
130 assembler syntax.
131 * config/rs6000/eabi.h (TARGET_DEFAULT): Delete
132 MASK_NEW_MNEMONICS.
133 * config/rs6000/eabialtivec.h (TARGET_DEFAULT): Ditto.
134 * config/rs6000/eabispe.h (TARGET_DEFAULT): Ditto.
135 * config/rs6000/linuxaltivec.h (TARGET_DEFAULT): Ditto.
136 * config/rs6000/linuxspe.h (TARGET_DEFAULT): Ditto.
137 * config/rs6000/rs6000-cpus.def (whole file): Delete
138 POWERPC_BASE_MASK.
139 * config/rs6000/rs6000-tables.opt: Regenerate.
140 * config/rs6000/rs6000.c (POWERPC_BASE_MASK): Delete.
141 (num_insns_constant_wide): Adjust comments.
142 (whole file): Adjust to single assembler syntax.
143 (output_cbranch): Adjust comment.
144 * config/rs6000/rs6000.h (ASSEMBLER_DIALECT): Delete.
145 * config/rs6000/rs6000.md: (whole file): Adjust to single
146 assembler syntax.
147 * config/rs6000/rs6000.opt (mnew-mnemonics): Delete.
148 (mold-mnemonics): Delete.
149 * config/rs6000/spe.md: (whole file): Adjust to single
150 assembler syntax.
151 * config/rs6000/sync.md: (whole file): Adjust to single
152 assembler syntax.
153 * config/rs6000/sysv4.h (TARGET_DEFAULT): Delete
154 MASK_NEW_MNEMONICS.
155 (ASM_OUTPUT_REG_PUSH): Adjust.
156 (ASM_OUTPUT_REG_POP): Adjust.
157 * config/rs6000/sysv4le.h (TARGET_DEFAULT): Delete
158 MASK_NEW_MNEMONICS.
159 * config/rs6000/vsx.md: (whole file): Adjust to single
160 assembler syntax.
161 * config/rs6000/vxworks.h (TARGET_DEFAULT): Delete
162 MASK_NEW_MNEMONICS.
163 * doc/invoke.texi: Adjust documentation to reflect the
164 removal of -mnew-mnemonics and -mold-mnemonics.
165
166 2012-08-15 Segher Boessenkool <segher@kernel.crashing.org>
167
168 * common/config/rs6000/rs6000-common.c (rs6000_handle_option):
169 Delete handling for -mno-powerpc and -mpowerpc.
170 * config/rs6000/aix43.h (ASM_CPU_SPEC): Similar.
171 (ASM_DEFAULT_SPEC): Use -mppc instead of -mcom.
172 * config/rs6000/aix51.h (ASM_CPU_SPEC, ASM_DEFAULT_SPEC): Ditto.
173 * config/rs6000/aix52.h (TARGET_DEFAULT): Delete MASK_POWERPC.
174 * config/rs6000/aix53.h (TARGET_DEFAULT): Ditto.
175 * config/rs6000/aix61.h (TARGET_DEFAULT): Ditto.
176 * config/rs6000/darwin.h (TARGET_DEFAULT): Ditto.
177 * config/rs6000/darwin64.h (TARGET_DEFAULT): Ditto.
178 * config/rs6000/default64.h (TARGET_DEFAULT): Ditto.
179 * config/rs6000/driver-rs6000.c (asm_names): Delete handling
180 for -mcpu=common and -mpowerpc.
181 * config/rs6000/eabi.h (TARGET_DEFAULT): Delete MASK_POWERPC.
182 * config/rs6000/eabialtivec.h (TARGET_DEFAULT): Ditto.
183 * config/rs6000/eabispe.h (TARGET_DEFAULT): Ditto.
184 * config/rs6000/linuxaltivec.h (TARGET_DEFAULT): Ditto.
185 * config/rs6000/linuxspe.h (TARGET_DEFAULT): Ditto.
186 * config/rs6000/rs6000-builtin.def (RS6000_BUILTIN_CFSTRING):
187 Use RS6000_BTM_ALWAYS instead of RS6000_BTM_POWERPC.
188 * config/rs6000/rs6000-c.c (rs6000_target_modify_macros):
189 Adjust.
190 (rs6000_cpu_cpp_builtins): Adjust.
191 * config/rs6000/rs6000.c (POWERPC_BASE_MASK): Delete MASK_POWERPC.
192 (rs6000_builtin_mask_calculate): Adjust.
193 (rs6000_emit_move): Delete code for ! TARGET_POWERPC.
194 (rs6000_init_libfuncs): Ditto.
195 (rs6000_output_function_prologue): Ditto.
196 (rs6000_opt_masks): Delete MASK_POWERPC.
197 (rs6000_builtin_mask_names): Delete RS6000_BTM_POWERPC.
198 * config/rs6000/rs6000.h (ASM_CPU_SPEC): Delete handling for
199 -mpowerpc.
200 (RS6000_BTM_POWERPC): Delete.
201 (RS6000_BTM_COMMON): Delete RS6000_BTM_POWERPC.
202 * config/rs6000/rs6000.md (extendqisi2 patterns): Adjust for
203 TARGET_POWERPC always on.
204 (extendqihi2 patterns): Similar.
205 (various unnamed subtract patterns): Similar.
206 (bswaphi2 patterns): Similar.
207 (divmodsi4): Similar.
208 (udiv<GPR:mode>3): Similar.
209 (div<GPR:mode>3 patterns): Similar.
210 (udivmodsi4): Similar.
211 (mulhcall): Delete.
212 (mullcall): Delete.
213 (divss_call): Delete.
214 (divus_call): Delete.
215 (quoss_call): Delete.
216 (quous_call): Delete.
217 (insvsi patterns): Adjust.
218 (addsf3 patterns): Adjust.
219 (subsf3 patterns): Adjust.
220 (mulsf3 patterns): Adjust.
221 (divsf3 patterns): Adjust.
222 (*fmasf4_fpr): Adjust.
223 (*fmssf4_fpr): Adjust.
224 (*nfmasf4_fpr): Adjust.
225 (*nfmssf4_fpr): Adjust.
226 (*floatunssidf2_internal): Adjust.
227 (fix_trunc<SFDF:mode>si2_internal): Adjust.
228 (fctiwz_<SFDF:mode>): Adjust.
229 (mulsidi3 patterns): Adjust.
230 (smulsi3_highpart patterns): Adjust.
231 (umulsi3_highpart patterns): Adjust.
232 (fix_trunctfsi2 patterns): Adjust.
233 (prefetch): Adjust.
234 * config/rs6000/rs6000.opt (mpowerpc): Replace by stub option.
235 (mno-powerpc): Delete.
236 * config/rs6000/sync.md (load_locked<ATOMIC:mode>): Adjust.
237 (store_conditional<ATOMIC:mode>): Adjust.
238 (atomic_compare_and_swap<ATOMIC:mode>): Adjust.
239 (atomic_exchange<ATOMIC:mode>): Adjust.
240 (atomic_<fetchop_name><ATOMIC:mode>): Adjust.
241 (atomic_nand<ATOMIC:mode>): Adjust.
242 (atomic_fetch_<fetchop_name><ATOMIC:mode>): Adjust.
243 (atomic_fetch_nand<ATOMIC:mode>): Adjust.
244 (atomic_<fetchop_name>_fetch<ATOMIC:mode>): Adjust.
245 (atomic_nand_fetch<ATOMIC:mode>): Adjust.
246 * config/rs6000/sysv4.h (TARGET_DEFAULT): Delete MASK_POWERPC.
247 * config/rs6000/sysv4le.h (TARGET_DEFAULT): Ditto.
248 * config/rs6000/vxworks.h (TARGET_DEFAULT): Ditto.
249 * doc/invoke.texi: Adjust documentation.
250
251 2012-08-15 Segher Boessenkool <segher@kernel.crashing.org>
252
253 * config/rs6000/rs6000.h (RS6000_BTM_ALWAYS): New.
254
255 2012-08-15 Segher Boessenkool <segher@kernel.crashing.org>
256
257 * config/rs6000/aix52.h (ASM_CPU_SPEC): Fix typo.
258 * config/rs6000/aix53.h (ASM_CPU_SPEC): Ditto.
259 * config/rs6000/aix61.h (ASM_CPU_SPEC): Ditto.
260 * config/rs6000/driver-rs6000.c (asm_names): Ditto.
261
262 2012-08-15 Segher Boessenkool <segher@kernel.crashing.org>
263
264 PR target/54142
265 * config/rs6000/driver-rs6000.c (asm_names): Use %(asm_default)
266 instead of -mcom.
267 * config/rs6000/rs6000.h (ASM_CPU_SPEC): Ditto.
268
269 2012-08-15 Sandra Loosemore <sandra@codesourcery.com>
270 Maxim Kuvyrkov <maxim@codesourcery.com>
271 Julian Brown <julian@codesourcery.com>
272 MIPS Technologies, Inc.
273
274 gcc/
275 * config/mips/mips.md (dspmac, dspmacsat, accext, accmod, dspalu)
276 (dspalusat): Add insn types.
277 * config/mips/mips-dsp.md (add<DSPV:mode>3)
278 (mips_add<DSP:dspfmt1>_s_<DSP:dspfmt2>)
279 (sub<DSPV:mode>3, mips_sub<DSP:dspfmt1>_s_<DSP:dspfmt2>, mips_addsc)
280 (mips_addwc, mips_modsub, mips_raddu_w_qb, mips_absq_s_<DSPQ:dspfmt2>)
281 (mips_precrq_qb_ph, mips_precrq_ph_w, mips_precrq_rs_ph_w)
282 (mips_precrqu_s_qb_ph, mips_preceq_w_phl, mips_preceq_w_phr)
283 (mips_precequ_ph_qbl, mips_precequ_ph_qbr, mips_precequ_ph_qbla)
284 (mips_precequ_ph_qbra, mips_preceu_ph_qbl, mips_preceu_ph_qbr)
285 (mips_preceu_ph_qbla, mips_preceu_ph_qbra, mips_shll_<DSPV:dspfmt2>)
286 (mips_shll_s_<DSPQ:dspfmt2>, mips_shll_s_<DSPQ:dspfmt2>, mips_shrl_qb)
287 (mips_shra_ph, mips_shra_r_<DSPQ:dspfmt2>, mips_bitrev, mips_insv)
288 (mips_repl_qb, mips_repl_ph)
289 (mips_cmp<DSPV:dspfmt1_1>_eq_<DSPV:dspfmt2>)
290 (mips_cmp<DSPV:dspfmt1_1>_lt_<DSPV:dspfmt2>)
291 (mips_cmp<DSPV:dspfmt1_1>_le_<DSPV:dspfmt2>, mips_cmpgu_eq_qb)
292 (mips_cmpgu_lt_qb, mips_cmpgu_le_qb, mips_pick_<DSPV:dspfmt2>)
293 (mips_packrl_ph, mips_wrdsp, mips_rddsp): Change type to dspalu.
294 (mips_dpau_h_qbl, mips_dpau_h_qbr, mips_dpsu_h_qbl, mips_dpsu_h_qbr)
295 (mips_dpaq_s_w_ph, mips_dpsq_s_w_ph, mips_mulsaq_s_w_ph)
296 (mips_maq_s_w_phl, mips_maq_s_w_phr, mips_maq_sa_w_phr): Set type to
297 dspmac.
298 (mips_dpaq_sa_l_w, mips_dpsq_sa_l_w, mips_maq_sa_w_phl): Set type to
299 dspmacsat.
300 (mips_extr_w, mips_extr_r_w, mips_extr_rs_w, mips_extp, mips_extpdp):
301 Set type to accext.
302 (mips_shilo, mips_mthlip): Set type to accmod.
303 * config/mips/mips-dspr2.md (mips_absq_s_qb, mips_addu_s_ph)
304 (mips_adduh_r_qb): Set type to dspalusat.
305 (mips_addu_ph, mips_adduh_qb, mips_append, mips_balign)
306 (mips_cmpgdu_eq_qb, mips_cmpgdu_lt_qb, mips_cmpgdu_le_qb)
307 (mips_precr_qb_ph, mips_precr_sra_ph_w, mips_precr_sra_r_ph_w)
308 (mips_prepend, mips_shra_qb, mips_shra_r_qb, mips_shrl_ph)
309 (mips_subu_ph, mips_subuh_qb, mips_subuh_r_qb, mips_addqh_ph)
310 (mips_addqh_r_ph, mips_addqh_w, mips_addqh_r_w, mips_subqh_ph)
311 (mips_subqh_r_ph, mips_subqh_w, mips_subqh_r_w): Set type to dspalu.
312 (mips_dpa_w_ph, mips_dps_w_ph, mips_mulsa_w_ph, mips_dpax_w_ph)
313 (mips_dpsx_w_ph, mips_dpaqx_s_w_ph, mips_dpsqx_s_w_ph): Set type to
314 dspmac. Set accum_in attribute.
315 (mips_subu_s_ph): Set type to dspalusat.
316 (mips_dpaqx_sa_w_ph, mips_dpsqx_sa_w_ph): Set type to dspmacsat.
317 Set accum_in attribute.
318 * config/mips/mips-protos.h (mips_dspalu_bypass_p): Add prototype.
319 * config/mips/mips.c (dspalu_bypass_table): New.
320 (mips_dspalu_bypass_p): New.
321 * config/mips/24k.md (r24k_dsp_alu, r24k_dsp_mac, r24k_dsp_mac_sat)
322 (r24k_dsp_acc_ext, r24k_dsp_acc_mod): New insn reservations.
323 (r24k_int_mult, r24k_int_mthilo, r24k_dsp_mac, r24k_dsp_mac_sat)
324 (r24k_dsp_acc_ext, r24k_dsp_acc_mod, r24k_dsp_alu): New bypasses.
325 * config/mips/74k.md (r74k_dsp_alu, r74k_dsp_alu_sat, r74k_dsp_mac)
326 (r74k_dsp_mac_sat, r74k_dsp_acc_ext, r74k_dsp_acc_mod): New insn
327 reservations.
328 (r74k_dsp_mac, r74k_dsp_mac_sat, r74k_int_mult, r74k_int_mul3)
329 (r74k_dsp_mac, r74k_dsp_mac_sat): New bypasses.
330
331 2012-08-15 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
332
333 * config/spu/spu.c: Include "cfgloop.h".
334 (spu_machine_dependent_reorg): Call loop_optimizer_init and
335 loop_optimizer_finalize. Use bb_loop_depth instead of loop_depth.
336 Directly compare loop_father values where appropriate.
337 * config/spu/t-spu-elf (spu.o): Update dependencies.
338
339 2012-08-15 H.J. Lu <hongjiu.lu@intel.com>
340
341 * Makefile.in (tree-cfg.o): Also depend on $(TARGET_H).
342
343 2012-08-15 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
344
345 PR tree-optimization/54245
346 * gimple-ssa-strength-reduction.c (legal_cast_p_1): New function.
347 (legal_cast_p): Split out logic to legal_cast_p_1.
348 (analyze_increments): Avoid introducing multiplies in smaller types.
349
350 2012-08-15 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
351
352 PR tree-optimization/54240
353 * tree-ssa-phiopt.c (hoist_adjacent_loads): Correct test for
354 existence of conditional move with given mode.
355
356 2012-08-15 Richard Guenther <rguenther@suse.de>
357
358 * double-int.h (double_int::from_unsigned): Rename to ...
359 (double_int::from_uhwi): ... this.
360 (double_int::from_signed): Rename to ...
361 (double_int::from_shwi): ... this.
362 (double_int::to_signed): Rename to ...
363 (double_int::to_shwi): ... this.
364 (double_int::to_unsigned): Rename to ...
365 (double_int::to_uhwi): ... this.
366 (double_int::fits_unsigned): Rename to ...
367 (double_int::fits_uhwi): ... this.
368 (double_int::fits_signed): Rename to ...
369 (double_int::fits_shwi): ... this.
370 (double_int::fits): Rename to ...
371 (double_int::fits_hwi): ... this.
372 * double-int.c: Likewise.
373
374 2012-08-15 Steven Bosscher <steven@gcc.gnu.org>
375
376 * timevar.def (TV_VARPOOL, TV_WHOPR_WPA_LTRANS_EXEC, TV_LIFE,
377 TV_LIFE_UPDATE, TV_DF_UREC, TV_INLINE_HEURISTICS,
378 TV_TREE_LINEAR_TRANSFORM, TV_TREE_LOOP_INIT, TV_TREE_LOOP_FINI,
379 TV_VPT, TV_LOCAL_ALLOC, TV_GLOBAL_ALLOC, TV_SEQABSTR): Remove.
380 (TV_IPA_INLINING, TV_FLATTEN_INLINING, TV_EARLY_INLINING,
381 TV_INLINE_PARAMETERS, TV_LOOP_INIT, TV_LOOP_FINI): New.
382 * timevar.c (timevar_print): Make printing width of timevar names
383 more flexible, but enforce maximum length.
384 * ipa-inline.c (pass_early_inline): Use TV_EARLY_INLINING.
385 (pass_ipa_inline): Use TV_IPA_INLINING.
386 * ipa-inline-analysis.c (pass_inline_parameters): Use
387 TV_INLINE_HEURISTICS.
388 * tree-ssa-loop.c (pass_tree_loop_init): No timevar for wrapper pass.
389 (pass_tree_loop_done): Likewise.
390 * final.c (pass_shorten_branches): Use TV_SHORTEN_BRANCH.
391 * loop-init.c (loop_optimizer_init): Push/pop TV_LOOP_INIT.
392 (loop_optimizer_finalize): Push/pop TV_LOOP_FINI.
393
394 2012-08-15 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
395
396 * config/arm/neon.md (neon_vaba<mode> VDQIW): Canonicalize
397 operands.
398 (neon_vabal<mode> VDQIW): Likewise.
399
400 2012-08-15 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
401
402 PR target/54212
403 * config/arm/neon.md (vec_set<mode>_internal VD,VQ): Do not
404 mark as predicable. Adjust asm template.
405 (vec_setv2di_internal): Likewise.
406 (vec_extract<mode> VD, VQ): Likewise.
407 (vec_extractv2di): Likewise.
408 (neon_vget_lane<mode>_sext_internal VD, VQ): Likewise.
409 (neon_vset_lane<mode>_sext_internal VD, VQ): Likewise.
410 (neon_vdup_n<mode> VX, V32): Likewise.
411 (neon_vdup_nv2di): Likewise.
412
413 2012-08-14 Maxim Kuvyrkov <maxim@codesourcery.com>
414
415 * config/mips/mips.md (define_attr accum_in): New instruction
416 attribute. Set it for imadd and fmadd patterns.
417 * config/mips/mips.c (mips_linked_madd_p): Use accum_in to extract
418 accumulator register.
419
420 2012-08-14 Diego Novillo <dnovillo@google.com>
421
422 Merge from cxx-conversion branch. Configury.
423
424 * configure.ac (CXX_FOR_BUILD): Define and substitute.
425 (BUILD_CXXFLAGS): Define.
426 Remove all handlers of ENABLE_BUILD_WITH_CXX.
427 Force all build to be with C++.
428 * Makefile.in (BUILD_CXXFLAGS): Use it.
429 Remove all handlers of ENABLE_BUILD_WITH_CXX.
430 * configure: Regenerate.
431 * config.in: Regenerate.
432 * doc/install.texi: Remove documentation for --enable-build-with-cxx
433 and --enable-build-poststage1-with-cxx.
434
435 2012-08-14 Diego Novillo <dnovillo@google.com>
436
437 Merge from cxx-conversion branch. Re-implement VEC in C++.
438
439 * vec.c (vec_heap_free): Convert into a template function.
440 (vec_gc_o_reserve_1): Make extern.
441 (vec_gc_p_reserve): Remove.
442 (vec_gc_p_reserve_exact): Remove.
443 (vec_gc_o_reserve): Remove.
444 (vec_gc_o_reserve_exact): Remove.
445 (vec_heap_o_reserve_1): Make extern.
446 (vec_heap_p_reserve): Remove.
447 (vec_heap_p_reserve_exact): Remove.
448 (vec_heap_o_reserve): Remove.
449 (vec_heap_o_reserve_exact): Remove.
450 (vec_stack_p_reserve): Remove.
451 (vec_stack_p_reserve_exact): Remove.
452 * vec.h (VEC_CHECK_INFO, VEC_CHECK_DECL, VEC_CHECK_PASS,
453 VEC_ASSERT, VEC_ASSERT_FAIL, vec_assert_fail): Move earlier
454 in the file.
455 (VEC): Define to vec_t<T>.
456 (vec_allocation_t): Define.
457 (struct vec_prefix): Move earlier in the file.
458 (vec_t<T>): New template.
459 (DEF_VEC_I, DEF_VECL_ALLOC_I, DEF_VEC_P, DEF_VEC_ALLOC_P,
460 DEF_VEC_O, DEF_VEC_ALLOC_P, DEF_VEC_O, DEF_VEC_ALLOC_O,
461 DEF_VEC_ALLOC_P_STACK, DEF_VEC_ALLOC_O_STACK,
462 DEF_VEC_ALLOC_I_STACK): Expand to 'struct vec_swallow_trailing_semi'.
463 (DEF_VEC_A): Provide template instantiations for
464 GC/PCH markers that do not traverse the vector.
465 (vec_stack_p_reserve): Remove.
466 (vec_stack_p_reserve_exact): Remove.
467 (vec_stack_p_reserve_exact_1): Remove.
468 (vec_stack_o_reserve): Remove.
469 (vec_stack_o_reserve_exact): Remove.
470 (vec_stack_free): Re-write as a template function.
471 (vec_reserve): New template function.
472 (vec_reserve_exact): New template function.
473 (vec_heap_free): New template function if GATHER_STATISTICS is
474 defined. Otherwise, macro that expands to free().
475 (VEC_length_1): New template function.
476 (VEC_length): Call it.
477 (VEC_empty_1): New template function.
478 (VEC_empty): Call it.
479 (VEC_address_1): New template function.
480 (VEC_address): Call it.
481 (VEC_last_1): New template function.
482 (VEC_last): Call it. Change return type to T&.
483 Change all users that used VEC_Os.
484 (VEC_index_1): New template function.
485 (VEC_index): Call it. Return a T& instead of a T*.
486 Update all callers that were using VEC_O before.
487 (VEC_iterate_1): New template function.
488 (VEC_iterate): Call it.
489 (VEC_embedded_size_1): New template function.
490 (VEC_embedded_size): Call it.
491 (VEC_embedded_init_1): New template function.
492 (VEC_embedded_init): Call it.
493 (VEC_alloc_1): New template function.
494 (VEC_alloc): Call it. If A is 'stack', call XALLOCAVAR to
495 do the allocation.
496 (VEC_free_1): New template function.
497 (VEC_free): Call it.
498 (VEC_copy_1): New template function.
499 (VEC_copy): Call it.
500 (VEC_space_1): New template function
501 (VEC_space): Call it.
502 (VEC_reserve_1): New template function.
503 (VEC_reserve): Call it.
504 (VEC_reserve_exact_1): New template function.
505 (VEC_reserve_exact): Call it.
506 (VEC_splice_1): New template function.
507 (VEC_splice): Call it.
508 (VEC_safe_splice_1): New template function.
509 (VEC_safe_splice): Call it.
510 (VEC_quick_push_1): New template function. Create two overloads, one
511 accepting T, the other accepting T *. Update all callers
512 where T and T * are ambiguous.
513 (VEC_quick_push): Call it.
514 (VEC_safe_push_1): New template function. Create two overloads, one
515 accepting T, the other accepting T *. Update all callers
516 where T and T * are ambiguous.
517 (VEC_safe_push): Call it.
518 (VEC_pop_1): New template function.
519 (VEC_pop): Call it.
520 (VEC_truncate_1): New template function.
521 (VEC_truncate): Call it.
522 (VEC_safe_grow_1): New template function.
523 (VEC_safe_grow): Call it.
524 (VEC_safe_grow_cleared_1): New template function.
525 (VEC_safe_grow_cleared): Call it.
526 (VEC_replace_1): New template function.
527 (VEC_replace): Call it. Always accept T instead of T*.
528 Update all callers that used VEC_Os.
529 (VEC_quick_insert_1): New template function.
530 (VEC_quick_insert): Call it.
531 (VEC_safe_insert_1): New template function.
532 (VEC_safe_insert): Call it.
533 (VEC_ordered_remove_1): New template function.
534 (VEC_ordered_remove): Call it.
535 (VEC_unordered_remove_1): New template function.
536 (VEC_unordered_remove): Call it.
537 (VEC_block_remove_1): New template function.
538 (VEC_block_remove): Call it.
539 (VEC_lower_bound_1): New template function.
540 (VEC_lower_bound): Call it.
541 (VEC_OP): Remove.
542 (DEF_VEC_FUNC_P): Remove.
543 (DEF_VEC_ALLOC_FUNC_P): Remove.
544 (DEF_VEC_NONALLOC_FUNCS_P): Remove.
545 (DEF_VEC_FUNC_O): Remove.
546 (DEF_VEC_ALLOC_FUNC_O): Remove.
547 (DEF_VEC_NONALLOC_FUNCS_O): Remove.
548 (DEF_VEC_ALLOC_FUNC_I): Remove.
549 (DEF_VEC_NONALLOC_FUNCS_I): Remove.
550 (DEF_VEC_ALLOC_FUNC_P_STACK): Remove.
551 (DEF_VEC_ALLOC_FUNC_O_STACK): Remove.
552 (DEF_VEC_ALLOC_FUNC_I_STACK): Remove.
553 (vec_reserve_exact): New template function.
554
555 * gengtype-lex.l (DEF_VEC_ALLOC_[IOP]/{EOID}): Remove.
556 * gengtype-parse.c (token_names): Remove DEF_VEC_ALLOC_[IOP].
557 (typedef_name): Emit vec_t<C1> instead of VEC_C1_C2.
558 (def_vec_alloc): Remove. Update all callers.
559 * gengtype.c (filter_type_name): New.
560 (output_mangled_typename): Call it.
561 (write_func_for_structure): Likewise.
562 (write_types): Likewise.
563 (write_root): Likewise.
564 (write_typed_alloc_def): Likewise.
565 (note_def_vec): Emit vec_t<TYPE_NAME> instead of VEC_TYPE_NAME_base.
566 (note_def_vec_alloc): Remove.
567 * gengtype.h (note_def_vec_alloc): Remove.
568 (DEFVEC_ALLOC): Remove token code.
569
570 * df-scan.c (df_bb_verify): Remove call to df_free_collection_rec
571 inside the insn traversal loop.
572 * gimplify.c (gimplify_compound_lval): Rename STACK to EXPR_STACK.
573 * ipa-inline.c (inline_small_functions): Rename HEAP to EDGE_HEAP.
574 * reg-stack.c (stack): Rename to STACK_PTR. Update all users.
575 * tree-vrp.c (stack): Rename to EQUIV_STACK. Update all users.
576
577 * config/bfin/bfin.c (hwloop_optimize): Update some calls to
578 VEC_* for vectors of non-pointers.
579 * config/c6x/c6x.c (try_rename_operands): Likewise.
580 (reshuffle_units): Likewise.
581 * config/mips/mips.c (mips_multi_start): Likewise.
582 (mips_multi_add): Likewise.
583 (mips_multi_copy_insn): Likewise.
584 (mips_multi_set_operand): Likewise.
585 * hw-doloop.c (discover_loop): Likewise.
586 (discover_loops): Likewise.
587 (reorg_loops): Likewise.
588
589 2012-08-14 Diego Novillo <dnovillo@google.com>
590
591 Merge from cxx-conversion branch. C++ support in gengtype.
592
593 * coretypes.h (gt_pointer_operator): Move from ...
594 * ggc.h: ... here.
595 * doc/gty.texi: Document support for C++ templates and
596 user-provided markers.
597 * gcc/gengtype-lex.l: Update copyright year.
598 Remove support for recognizing DEF_VEC_O, DEF_VEC_P and
599 DEFVEC_I.
600 * gengtype-parse.c: Update copyright year.
601 (token_names): Remove DEF_VEC_O, DEF_VEC_P and DEF_VEC_I.
602 (require_template_declaration): New.
603 (typedef_name): Call it.
604 (type): Replace IS_UNION with KIND. Replace all users.
605 (def_vec): Remove. Update all users.
606 * gengtype-state.c (type_lineloc): Handle TYPE_USER_STRUCT.
607 (write_state_user_struct_type): New.
608 (write_state_type): Call it.
609 (read_state_user_struct_type): New.
610 (read_state_type): Call it.
611 * gengtype.c: Update copyright year.
612 (dump_pair): Move declaration to the top.
613 (dump_type): Likewise.
614 (dump_type_list): Likewise.
615 (dbgprint_count_type_at): Handle TYPE_USER_STRUCT.
616 (create_user_defined_type): New.
617 (resolve_typedef): Call it.
618 (new_structure): Replace argument ISUNION with KIND.
619 Change users to refer to KIND directly.
620 Update all callers.
621 (find_structure): Likewise.
622 (set_gc_used_type): Handle TYPE_USER_STRUCT.
623 (create_file): Update HDR to include new copyright year.
624 (struct walk_type_data): Add field IN_PTR_FIELD.
625 (output_mangled_typename): Handle TYPE_USER_STRUCT.
626 (walk_type): Set D->IN_PTR_FIELD when walking a TYPE_POINTER.
627 Clear it afterwards.
628 Handle TYPE_USER_STRUCT.
629 (write_types_process_field): Handle TYPE_USER_STRUCT.
630 (get_type_specifier): Move earlier in the file.
631 (write_type_decl): New.
632 (write_marker_function_name): New.
633 (write_user_func_for_structure_ptr): New.
634 (write_user_func_for_structure_body): New.
635 (write_user_marking_functions): New.
636 (write_func_for_structure): Call write_marker_function_name
637 and write_type_decl.
638 Do not call walk_type for TYPE_USER_STRUCT. Emit a call to the user
639 function directly.
640 Call write_user_marking_functions on TYPE_USER_STRUCTs.
641 (write_types_local_user_process_field): New.
642 (write_pch_user_walking_for_structure_body): New.
643 (write_pch_user_walking_functions): New.
644 (write_types_local_process_field): Handle TYPE_USER_STRUCT.
645 (write_local_func_for_structure): Do not call walk_type for
646 TYPE_USER_STRUCT. Instead, emit the call to gt_pch_nx directly.
647 Call write_pch_user_walking_functions for TYPE_USER_STRUCTs.
648 (write_root): Handle TYPE_USER_STRUCT.
649 (vec_prefix_type): Remove. Update all users.
650 (note_def_vec): Remove. Update all users.
651 (dump_typekind): Handle TYPE_USER_STRUCT.
652 (dump_type): Initialize SEEN_TYPES, if needed.
653 Handle TYPE_USER_STRUCT.
654 (dump_everything): Do not initialize SEEN_TYPES.
655 * gengtype.h: Update copyright year.
656 (enum typekind): Add TYPE_USER_STRUCT.
657 (union_or_struct_p): Rename from UNION_OR_STRUCT_P.
658 Convert into function.
659 Add an overload taking const_type_p.
660 Update all callers.
661 (new_structure): Change second field to type enum typekind.
662 Update all users.
663 (find_structure): Likewise.
664 (note_def_vec): Remove.
665 (DEFVEC_OP): Remove.
666 (DEFVEC_I): Remove.
667 * ggc-page.c (gt_ggc_mx): Add entry points for marking
668 'const char *&', 'unsigned char *&' and 'unsigned char&'.
669 * ggc-zone.c (gt_ggc_mx): Add entry points for marking
670 'const char *&' and 'unsigned char *&'.
671 * stringpool.c (gt_pch_nx): Add entry points for marking
672 'const char *&', 'unsigned char *&' and 'unsigned char&'.
673 Add an entry point for the overload taking arguments 'unsigned char
674 *', 'gt_pointer_operator' and 'void *'.
675 * vec.h (struct vec_prefix): Remove GTY marker.
676 (struct vec_t): Remove GTY((length)) attribute from field 'vec'.
677 (gt_ggc_mx (vec_t<T> *)): New template function.
678 (gt_pch_nx (vec_t<T> *)): New template function.
679 (gt_pch_nx (vec_t<T *> *, gt_pointer_operator, void *)): New template
680 function.
681 (gt_pch_nx (vec_t<T> *, gt_pointer_operator, void *)): New template
682 function.
683
684 * basic-block.h (struct edge_def): Mark GTY((user)).
685 Remove all GTY markers from fields.
686 (gt_ggc_mx): Declare.
687 (gt_pch_nx): Declare.
688 * tree-cfg.c (gt_ggc_mx): New.
689 (gt_pch_nx): New.
690
691 * gengtype-lex.l (USER_GTY): Add pattern for "user".
692 * gengtype-parse.c (option): Handle USER_GTY.
693 (opts_have): New.
694 (type): Call it.
695 If the keyword 'user' is used, do not walk the fields
696 of the structure.
697 * gengtype.h (USER_GTY): Add.
698 * doc/gty.texi: Update.
699
700 2012-08-14 Lawrence Crowl <crowl@google.com>
701
702 Merge cxx-conversion branch. Implement C++ hash table.
703
704 * hash-table.h: New. Implementation borrowed from libiberty/hashtab.c.
705 * hash-table.c: Likewise.
706 * tree-ssa-tail-merge.c: Include hash-table.h instead of hashtab.h.
707 (static htab_t same_succ_htab): Change type to hash_table;
708 move specification of helper functions from create call to declaration.
709 Change users to invoke member functions.
710 (same_succ_print_traverse): Make extern ssa_.... Change callers.
711 Remove void* casting.
712 (same_succ_hash): Likewise.
713 (same_succ_equal): Likewise.
714 (same_succ_delete): Likewise.
715 * tree-ssa-threadupdate.c: Include hash-table.h.
716 (struct local_info): Rename to ssa_local_info_t to avoid overloading
717 the type name local_info with the variable name local_info.
718 (static htab_t redirection_data): Change type to hash_table.
719 Move specification of helper functions from create call to declaration.
720 Change users to invoke member functions.
721 (redirection_data_hash): Make extern ssa_.... Change callers.
722 Remove void* casting.
723 (redirection_data_eq): Likewise.
724 (fix_duplicate_block_edges): Likewise.
725 (create_duplicates): Likewise.
726 (fixup_template_block): Likewise.
727 (redirect_edges): Likewise.
728 (lookup_redirection_data): Change types associated with the hash table
729 from void* to their actual type. Remove unnecessary casts.
730 * tree-ssa-ccp.c: Include hash-table.h.
731 (typedef gimple_htab): New. Uses hash_table. Replace specific uses
732 of htab_t with gimple_htab. Change users to invoke member functions.
733 Move specification of helper functions from create call to declaration.
734 * tree-ssa-coalesce.c: Include hash-table.h instead of hashtab.h.
735 (hash_ssa_name_by_var): Make extern. Remove void* casting.
736 (eq_ssa_name_by_var): Likewise.
737 (coalesce_ssa_name): Change type of local static htab_t ssa_name_hash
738 to hash_table. Change users to invoke member functions.
739 Move specification of helper functions from create call to declaration.
740 * coverage.c: Include hash-table.h instead of hashtab.h.
741 (static htab_t counts_hash): Change type to hash_table;
742 move specification of helper functions from create call to declaration.
743 Change users to invoke member functions.
744 (htab_counts_entry_hash): Make extern. Rename with coverage_... instead
745 of htab_... Remove void* casting.
746 (htab_counts_entry_eq): Likewise.
747 (htab_counts_entry_del): Likewise.
748 * tree-ssa-pre.c: Include hash-table.h instead of hashtab.h.
749 (static htab_t expression_to_id): Change type to hash_table.
750 Move specification of helper functions from create call to declaration.
751 Change users to invoke member functions.
752 (static htab_t phi_translate_table): Likewise.
753 (pre_expr_eq): Make extern ssa_.... Change callers.
754 Remove void* casting.
755 (pre_expr_hash): Likewise.
756 (expr_pred_trans_hash): Likewise.
757 (expr_pred_trans_eq): Likewise.
758 (alloc_expression_id): Change types associated with the hash table
759 from void* to their actual type. Remove unnecessary casts.
760 (lookup_expression_id): Likewise.
761 (phi_trans_lookup): Likewise.
762 (phi_trans_add): Likewise.
763 * stringpool.c: Rename uses of libcpp typedef hash_table to
764 cpp_hash_table.
765 * Makefile.in: Add hash-table.o to OBJS-libcommon-target.
766 Add $(HASH_TABLE_H). Add new dependences on $(HASH_TABLE_H).
767
768 2012-08-14 Lawrence Crowl <crowl@google.com>
769
770 Merge from cxx-conversion branch. Re-write double_int in C++.
771
772 * hash-table.h
773 (typedef double_int): Change to struct (POD).
774 (double_int::make): New overloads for int to double-int conversion.
775 (double_int::mask): New.
776 (double_int::max_value): New.
777 (double_int::min_value): New.
778 (double_int::operator ++): New.
779 (double_int::operator --): New.
780 (double_int::operator *=): New.
781 (double_int::operator +=): New.
782 (double_int::operator -=): New.
783 (double_int::to_signed): New.
784 (double_int::to_unsigned): New.
785 (double_int::fits_unsigned): New.
786 (double_int::fits_signed): New.
787 (double_int::fits): New.
788 (double_int::trailing_zeros): New.
789 (double_int::popcount): New.
790 (double_int::multiple_of): New.
791 (double_int::set_bit): New.
792 (double_int::mul_with_sign): New.
793 (double_int::operator * (binary)): New.
794 (double_int::operator + (binary)): New.
795 (double_int::operator - (binary)): New.
796 (double_int::operator - (unary)): New.
797 (double_int::operator ~ (unary)): New.
798 (double_int::operator & (binary)): New.
799 (double_int::operator | (binary)): New.
800 (double_int::operator ^ (binary)): New.
801 (double_int::and_not): New.
802 (double_int::lshift): New.
803 (double_int::rshift): New.
804 (double_int::alshift): New.
805 (double_int::arshift): New.
806 (double_int::llshift): New.
807 (double_int::lrshift): New.
808 (double_int::lrotate): New.
809 (double_int::rrotate): New.
810 (double_int::div): New.
811 (double_int::sdiv): New.
812 (double_int::udiv): New.
813 (double_int::mod): New.
814 (double_int::smod): New.
815 (double_int::umod): New.
816 (double_int::divmod): New.
817 (double_int::sdivmod): New.
818 (double_int::udivmod): New.
819 (double_int::ext): New.
820 (double_int::zext): New.
821 (double_int::sext): New.
822 (double_int::is_zero): New.
823 (double_int::is_one): New.
824 (double_int::is_minus_one): New.
825 (double_int::is_negative): New.
826 (double_int::cmp): New.
827 (double_int::ucmp): New.
828 (double_int::scmp): New.
829 (double_int::ult): New.
830 (double_int::ugt): New.
831 (double_int::slt): New.
832 (double_int::sgt): New.
833 (double_int::max): New.
834 (double_int::smax): New.
835 (double_int::umax): New.
836 (double_int::min): New.
837 (double_int::smin): New.
838 (double_int::umin): New.
839 (double_int::operator ==): New.
840 (double_int::operator !=): New.
841 (shwi_to_double_int): Change implementation to use member function.
842 (double_int_minus_one): Likewise.
843 (double_int_zero): Likewise.
844 (double_int_one): Likewise.
845 (double_int_two): Likewise.
846 (double_int_ten): Likewise.
847 (uhwi_to_double_int): Likewise.
848 (double_int_to_shwi): Likewise.
849 (double_int_to_uhwi): Likewise.
850 (double_int_fits_in_uhwi_p): Likewise.
851 (double_int_fits_in_shwi_p): Likewise.
852 (double_int_fits_in_hwi_p): Likewise.
853 (double_int_mul): Likewise.
854 (double_int_mul_with_sign): Likewise.
855 (double_int_add): Likewise.
856 (double_int_sub): Likewise.
857 (double_int_neg): Likewise.
858 (double_int_div): Likewise.
859 (double_int_sdiv): Likewise.
860 (double_int_udiv): Likewise.
861 (double_int_mod): Likewise.
862 (double_int_smod): Likewise.
863 (double_int_umod): Likewise.
864 (double_int_divmod): Likewise.
865 (double_int_sdivmod): Likewise.
866 (double_int_udivmod): Likewise.
867 (double_int_multiple_of): Likewise.
868 (double_int_setbit): Likewise.
869 (double_int_ctz): Likewise.
870 (double_int_not): Likewise.
871 (double_int_ior): Likewise.
872 (double_int_and): Likewise.
873 (double_int_and_not): Likewise.
874 (double_int_xor): Likewise.
875 (double_int_lshift): Likewise.
876 (double_int_rshift): Likewise.
877 (double_int_lrotate): Likewise.
878 (double_int_rrotate): Likewise.
879 (double_int_cmp): Likewise.
880 (double_int_scmp): Likewise.
881 (double_int_ucmp): Likewise.
882 (double_int_max): Likewise.
883 (double_int_smax): Likewise.
884 (double_int_umax): Likewise.
885 (double_int_min): Likewise.
886 (double_int_smin): Likewise.
887 (double_int_umin): Likewise.
888 (double_int_ext): Likewise.
889 (double_int_sext): Likewise.
890 (double_int_zext): Likewise.
891 (double_int_mask): Likewise.
892 (double_int_max_value): Likewise.
893 (double_int_min_value): Likewise.
894 (double_int_zero_p): Likewise.
895 (double_int_one_p): Likewise.
896 (double_int_minus_one_p): Likewise.
897 (double_int_equal_p): Likewise.
898 (double_int_popcount): Likewise.
899 * hash-table.c
900 (double_int_mask): Reuse implementation for double_int::mask.
901 (double_int_max_value): Likewise.
902 (double_int_min_value): Likewise.
903 (double_int_ext): Likewise.
904 (double_int_zext): Likewise.
905 (double_int_sext): Likewise.
906 (double_int_mul_with_sign): Likewise.
907 (double_int_divmod): Likewise.
908 (double_int_sdivmod): Likewise.
909 (double_int_udivmod): Likewise.
910 (double_int_div): Likewise.
911 (double_int_sdiv): Likewise.
912 (double_int_udiv): Likewise.
913 (double_int_mod): Likewise.
914 (double_int_smod): Likewise.
915 (double_int_umod): Likewise.
916 (double_int_multiple_of): Likewise.
917 (double_int_lshift): Likewise.
918 (double_int_rshift): Likewise.
919 (double_int_lrotate): Likewise.
920 (double_int_rrotate): Likewise.
921 (double_int_cmp): Likewise.
922 (double_int_ucmp): Likewise.
923 (double_int_scmp): Likewise.
924 (double_int_max): Likewise.
925 (double_int_smax): Likewise.
926 (double_int_umax): Likewise.
927 (double_int_min): Likewise.
928 (double_int_smin): Likewise.
929 (double_int_umin): Likewise.
930 (double_int_min): Likewise.
931 (double_int_min): Likewise.
932 (double_int_min): Likewise.
933 (double_int_min): Likewise.
934 (double_int_min): Likewise.
935 (double_int_min): Likewise.
936 (double_int::alshift): New.
937 (double_int::arshift): New.
938 (double_int::llshift): New.
939 (double_int::lrshift): New.
940 (double_int::ult): New.
941 (double_int::ugt): New.
942 (double_int::slt): New.
943 (double_int::sgt): New.
944 (double_int_setbit): Reuse implementation for double_int::set_bit,
945 which avoids a name conflict with a macro.
946 (double_int_double_int_ctz): Reuse implementation for
947 double_int::trailing_zeros.
948 (double_int_fits_in_shwi_p): Reuse implementation for
949 double_int::fits_signed.
950 (double_int_fits_in_hwi_p): Reuse implementation for double_int::fits.
951 (double_int_mul): Reuse implementation for binary
952 double_int::operator *.
953 (double_int_add): Likewise.
954 (double_int_sub): Likewise.
955 (double_int_neg): Reuse implementation for unary
956 double_int::operator -.
957 (double_int_max_value): Likewise.
958 * fixed-value.c: Change to use member functions introduced above.
959
960 2012-08-14 Lawrence Crowl <crowl@google.com>
961
962 Merge cxx-conversion branch. Support tree macro calling
963 from gdb.
964
965 * tree.h (tree_check): New.
966 (TREE_CHECK): Use inline function above instead of __extension__.
967 (tree_not_check): New.
968 (TREE_NOT_CHECK): Use inline function above instead of __extension__.
969 (tree_check2): New.
970 (TREE_CHECK2): Use inline function above instead of __extension__.
971 (tree_not_check2): New.
972 (TREE_NOT_CHECK2): Use inline function above instead of __extension__.
973 (tree_check3): New.
974 (TREE_CHECK3): Use inline function above instead of __extension__.
975 (tree_not_check3): New.
976 (TREE_NOT_CHECK3): Use inline function above instead of __extension__.
977 (tree_check4): New.
978 (TREE_CHECK4): Use inline function above instead of __extension__.
979 (tree_not_check4): New.
980 (TREE_NOT_CHECK4): Use inline function above instead of __extension__.
981 (tree_check5): New.
982 (TREE_CHECK5): Use inline function above instead of __extension__.
983 (tree_not_check5): New.
984 (TREE_NOT_CHECK5): Use inline function above instead of __extension__.
985 (contains_struct_check): New.
986 (CONTAINS_STRUCT_CHECK): Use inline function above instead of
987 __extension__.
988 (tree_class_check): New.
989 (TREE_CLASS_CHECK): Use inline function above instead of __extension__.
990 (tree_range_check): New.
991 (TREE_RANGE_CHECK): Use inline function above instead of __extension__.
992 (omp_clause_subcode_check): New.
993 (OMP_CLAUSE_SUBCODE_CHECK): Use inline function above instead of
994 __extension__.
995 (omp_clause_range_check): New.
996 (OMP_CLAUSE_RANGE_CHECK): Use inline function above instead of
997 __extension__.
998 (expr_check): New.
999 (EXPR_CHECK): Use inline function above instead of __extension__.
1000 (non_type_check): New.
1001 (NON_TYPE_CHECK): Use inline function above instead of __extension__.
1002 (tree_vec_elt_check): New.
1003 (TREE_VEC_ELT_CHECK): Use inline function above instead of
1004 __extension__.
1005 (omp_clause_elt_check): New.
1006 (OMP_CLAUSE_ELT_CHECK): Use inline function above instead of
1007 __extension__.
1008 (tree_operand_check): New.
1009 (TREE_OPERAND_CHECK): Use inline function above instead of
1010 __extension__.
1011 (tree_operand_check_code): New.
1012 (TREE_OPERAND_CHECK_CODE): Use inline function above instead of
1013 __extension__.
1014 (TREE_CHAIN): Simplify implementation.
1015 (TREE_TYPE): Simplify implementation.
1016 (tree_operand_length): Move for compilation dependences.
1017 * gdbinit.in: (macro define __FILE__): New.
1018 (macro define __LINE__): New.
1019 (skip "tree.h"): New.
1020
1021 2012-08-14 Uros Bizjak <ubizjak@gmail.com>
1022
1023 * config/i386/i386.md (enabled): Add comment with explanation
1024 why fma4 instructions are disabled for generic code.
1025
1026 2012-08-14 Oleg Endo <olegendo@gcc.gnu.org>
1027
1028 PR target/52933
1029 * config/sh/sh.md (cmp_div0s_0, cmp_div0s_1, *cmp_div0s_0,
1030 *cmp_div0s_1, *cbranch_div0s, *movsicc_div0s): New insns.
1031 * config/sh/sh.c (sh_rtx_costs): Handle div0s patterns.
1032
1033 2012-08-14 Oleg Endo <olegendo@gcc.gnu.org>
1034
1035 PR target/50751
1036 * config/sh/constraints.md (Sra): New constraint.
1037 * config/sh/predicates.md (simple_mem_operand,
1038 displacement_mem_operand, zero_extend_movu_operand): New predicates.
1039 (zero_extend_operand): Check zero_extend_movu_operand for SH2A.
1040 * config/sh/sh.md (*zero_extendqisi2_disp_mem,
1041 *zero_extendhisi2_disp_mem): Add new insns and two new related
1042 peephole2 patterns.
1043
1044 2012-08-14 Steven Bosscher <steven@gcc.gnu.org>
1045
1046 * graphite-scop-detection.c (create_sese_edges): Compute dominance
1047 info before trying to fix loop structure.
1048 * cfgloopmanip.c (fix_loop_structure): Require fast DOM queries.
1049 * tree-cfgcleanup.c (repair_loop_structures): Likewise.
1050 * cfgloop.c (verify_loop_structure): Verify loop fathers.
1051
1052 * dominance.c (init_dom_info): Use gcc_checking_assert, not gcc_assert.
1053 (dom_convert_dir_to_idx, compute_dom_fast_query,
1054 get_immediate_dominator, set_immediate_dominator, get_dominated_by,
1055 redirect_immediate_dominators, nearest_common_dominator,
1056 (dominated_by_p, bb_dom_dfs_in, bb_dom_dfs_out, recompute_dominator,
1057 iterate_fix_dominators, add_to_dominance_info,
1058 delete_from_dominance_info): Likewise.
1059
1060 2012-08-14 Richard Guenther <rguenther@suse.de>
1061
1062 * cfgexpand.c (expand_used_vars): Use virtual_operand_p.
1063 * gimple-pretty-print.c (dump_phi_nodes): Likewise.
1064 * gimple-streamer-out.c (output_bb): Likewise.
1065 * graphite-sese-to-poly.c (scalar_close_phi_node_p): Likewise.
1066 (rewrite_reductions_out_of_ssa): Likewise.
1067 (rewrite_commutative_reductions_out_of_ss): Likewise.
1068 * ipa-split.c (verify_non_ssa_vars): Likewise.
1069 (consider_split): Likewise.
1070 (visit_bb): Likewise.
1071 (split_function): Likewise.
1072 * lto-streamer-out.c (output_ssa_names): Likewise.
1073 * sese.c (rename_uses): Likewise.
1074 * tree-cfg.c (replace_uses_by): Likewise.
1075 (gimple_merge_blocks): Likewise.
1076 (gimple_cfg2dot): Likewise.
1077 (verify_gimple_phi): Likewise.
1078 (replace_ssa_name): Likewise.
1079 (move_block_to_fn): Likewise.
1080 * tree-eh.c (cleanup_empty_eh_merge_phis): Likewise.
1081 * tree-if-conv.c (if_convertible_phi_p): Likewise.
1082 (predicate_scalar_phi): Likewise.
1083 * tree-inline.c (update_ssa_across_abnormal_edges): Likewise.
1084 (copy_phis_for_bb): Likewise.
1085 * tree-loop-distribution.c (generate_loops_for_partition): Likewise.
1086 (destroy_loop): Likewise.
1087 * tree-outof-ssa.c (eliminate_useless_phis): Likewise.
1088 (insert_backedge_copies): Likewise.
1089 * tree-parloops.c (transform_to_exit_first_loop): Likewise.
1090 (gather_scalar_reductions): Likewise.
1091 (try_create_reduction_list): Likewise.
1092 * tree-scalar-evolution.c (analyze_scalar_evolution_for_all_loop_ph):
1093 Likewise.
1094 (scev_const_prop): Likewise.
1095 * tree-ssa-ccp.c (debug_lattice_value): Likewise.
1096 (get_default_value): Likewise.
1097 (ccp_initialize): Likewise.
1098 * tree-ssa-coalesce.c (create_outofssa_var_map): Likewise.
1099 * tree-ssa-copy.c (may_propagate_copy): Likewise.
1100 (init_copy_prop): Likewise.
1101 * tree-ssa-dce.c (propagate_necessity): Likewise.
1102 (remove_dead_phis): Likewise.
1103 (forward_edge_to_pdom): Likewise.
1104 (eliminate_unnecessary_stmts): Likewise.
1105 * tree-ssa-live.c (partition_view_init): Likewise.
1106 (remove_unused_locals): Likewise.
1107 (register_ssa_partition_check): Likewise.
1108 * tree-ssa-loop-im.c (movement_possibility): Likewise.
1109 (move_computations_stmt): Likewise.
1110 * tree-ssa-loop-ivopts.c (determine_biv_step): Likewise.
1111 (record_invariant): Likewise.
1112 (find_interesting_uses_outside): Likewise.
1113 (determine_set_costs): Likewise.
1114 * tree-ssa-loop-manip.c (add_exit_phis_var): Likewise.
1115 (find_uses_to_rename_use): Likewise.
1116 (check_loop_closed_ssa_use): Likewise.
1117 (rewrite_phi_with_iv): Likewise.
1118 (canonicalize_loop_ivs): Likewise.
1119 * tree-ssa-math-opts.c (execute_cse_reciprocals): Likewise.
1120 * tree-ssa-phiopt.c (hoist_adjacent_loads): Likewise.
1121 * tree-ssa-pre.c (make_values_for_phi): Likewise.
1122 (compute_avail): Likewise.
1123 (eliminate): Likewise.
1124 * tree-ssa-propagate.c (substitute_and_fold): Likewise.
1125 * tree-ssa-reassoc.c (phi_rank): Likewise.
1126 * tree-ssa-strlen.c (strlen_enter_block): Likewise.
1127 * tree-ssa-structalias.c (compute_points_to_sets): Likewise.
1128 (ipa_pta_execute): Likewise.
1129 * tree-ssa-tail-merge.c (same_succ_hash): Likewise.
1130 (release_last_vdef): Likewise.
1131 (same_phi_alternatives_1): Likewise.
1132 (bb_has_non_vop_phi): Likewise.
1133 (vop_phi): Likewise.
1134 * tree-ssa-threadedge.c (record_temporary_equivalences_from_phis):
1135 Likewise.
1136 * tree-ssa-uninit.c (warn_uninitialized_phi): Likewise.
1137 (execute_late_warn_uninitialized): Likewise.
1138 * tree-ssa.c (verify_ssa_name): Likewise.
1139 (verify_phi_args): Likewise.
1140 (verify_ssa): Likewise.
1141 * tree-stdarg.c (execute_optimize_stdarg): Likewise.
1142 * tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard1):
1143 Likewise.
1144 (slpeel_tree_peel_loop_to_edge): Likewise.
1145 (vect_can_advance_ivs_p): Likewise.
1146 (vect_update_ivs_after_vectorizer): Likewise.
1147 * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Likewise.
1148 * tree-vrp.c (remove_range_assertions): Likewise.
1149 * value-prof.c (gimple_divmod_values_to_profile): Likewise.
1150
1151 2012-08-14 Richard Guenther <rguenther@suse.de>
1152
1153 PR tree-optimization/54146
1154 * tree-ssa-pre.c (do_regular_insertion): Use a VEC
1155 indexed by pred edge index for avail.
1156 (do_partial_partial_insertion): Likewise.
1157 (insert_into_preds_of_block): Adjust.
1158
1159 2012-08-14 Richard Guenther <rguenther@suse.de>
1160
1161 * gimplify.c (create_tmp_from_val): Mark temporary with
1162 DECL_GIMPLE_REG_P here ...
1163 (internal_get_tmp_var): ... instead of here. If we go into
1164 SSA create an SSA name instead of a VAR_DECL.
1165 (gimplify_modify_expr): Do not create SSA names here, assert
1166 we already got them.
1167 (force_gimple_operand_1): Create an SSA name if we go into SSA.
1168 * sese.c (rename_uses): Simplify.
1169
1170 2012-08-14 Richard Guenther <rguenther@suse.de>
1171
1172 * tree-into-ssa.c: Include diagnostic-core.h.
1173 * Makefile.in (tree-into-ssa.o): Adjust.
1174
1175 2012-08-14 Richard Guenther <rguenther@suse.de>
1176
1177 * tree-into-ssa.c (update_ssa): Verify we do not rename
1178 symbols that are already partly in SSA form.
1179
1180 2012-08-14 Jakub Jelinek <jakub@redhat.com>
1181
1182 PR middle-end/53411
1183 PR rtl-optimization/53495
1184 * ira.c (ira): Move delete_trivially_dead_insns call before
1185 find_moveable_pseudos call.
1186
1187 2012-08-13 Steven Bosscher <steven@gcc.gnu.org>
1188
1189 * tree-ssa-pre.c (do_regular_insertion): Add FIXME markers at points
1190 of potentially huge memset overhead.
1191 (do_partial_partial_insertion): Likewise.
1192 * cfgexpand.c (gimple_expand_cfg): Use XCNEWVEC instead of xcalloc.
1193 * tree-vrp.c (find_assert_locations): Use XNEWVEC instead of XCNEWVEC
1194 for arrays to be filled by pre_and_rev_post_order_compute. Allocate
1195 the right number of slots, not that number plus NUM_FIXED_BLOCKS.
1196 * tree-ssa-reassoc.c (init_reassoc): Likewise.
1197 * cfganal.c (dfs_enumerate_from): Use XNEWVEC instead of XCNEWVEC for
1198 array used as stack.
1199 * tree-ssa-sccvn.c (init_scc_vn): Use XNEWVEC instead of XCNEWVEC for
1200 arrays to be filled by pre_and_rev_post_order_compute.
1201 * cfgloopmanip.c (find_path): Use XNEWVEC instead of XCNEWVEC for
1202 array to be filled by dfs_enumerate_from.
1203 (remove_path): Likewise.
1204 (duplicate_loop_to_header_edge): Use XNEWVEC instead of XCNEWVEC for
1205 array of loops that is filled on the next lines.
1206 * cfgloop.c (get_loop_body): Use XNEWVEC instead of XCNEWVEC for
1207 array of basic blocks to be returned.
1208 (get_loop_body_in_dom_order): Likewise.
1209 (get_loop_body_in_bfs_order): Likewise.
1210 * tree-ssa-loop-manip.c (loop_renamer_obstack): New static obstack
1211 for all bitmaps used for rewriting into loop-closed SSA form.
1212 (add_exit_phis_var): Allocate the def bitmap on it. Clear the livein
1213 bitmap at the end to release a lot of memory.
1214 (add_exit_phis): Allocate the exits bitmap on the new obstack.
1215 (get_loops_exits): Allocate the exits bitmap on the new obstack.
1216 (find_uses_to_rename_use): Allocate a use_blocks bitmap if ver is
1217 seen for the first time.
1218 (find_uses_to_rename): Add "???" for why the whole function must
1219 be re-scanned if changed_bbs is empty.
1220 (rewrite_into_loop_closed_ssa): Allocate bitmaps on the new obstack.
1221 Use XNEWVEC to allocate the use_blocks array. Initialize the new
1222 obstack, and free it at the end. Remove loop over all SSA names.
1223 (check_loop_closed_ssa_stmt): Look only at SSA_OP_USE operands.
1224 * tree-cfg.c (move_sese_region_to_fn): Use XNEWVEC instead of
1225 xcalloc to allocate edge_pred and edge_flag arrays.
1226
1227 2012-08-13 Uros Bizjak <ubizjak@gmail.com>
1228
1229 * config/i386/i386.h (FIXED_REGISTERS): Do not mark REX registers here.
1230 (CALL_USED_REGISTERS): Use bitmaps to mark call-used registers
1231 for different ABIs.
1232 (enum reg_class): Move CLOBBERED_REGS just before GENERAL_REGS.
1233 (REG_CLASS_NAMES): Update.
1234 (REG_CLASS_CONTENTS): Update. Clear CLOBBERED_REGS members.
1235 * config/i386/i386.c (ix86_conditional_register_usage): Disable
1236 REX registers on 32bit targets. Handle bitmaps from
1237 CALL_USED_REGISTERS initializer. Calculate CLOBBERED_REGS register
1238 set from GENERAL_REGS also for 32bit targets. Do not change call
1239 used register set for TARGET_64BIT_MS_ABI separately.
1240
1241 2012-08-13 Richard Guenther <rguenther@suse.de>
1242
1243 * basic-block.h (struct basic_block): Remove loop_depth
1244 member, move flags and index members next to each other.
1245 * cfgloop.h (bb_loop_depth): New inline function.
1246 * cfghooks.c (split_block): Do not set loop_depth.
1247 (duplicate_block): Likewise.
1248 * cfgloop.c (flow_loop_nodes_find): Likewise.
1249 (flow_loops_find): Likewise.
1250 (add_bb_to_loop): Likewise.
1251 (remove_bb_from_loops): Likewise.
1252 * cfgrtl.c (force_nonfallthru_and_redirect): Likewise.
1253 * gimple-streamer-in.c (input_bb): Do not stream loop_depth.
1254 * gimple-streamer-out.c (output_bb): Likewise.
1255 * bt-load.c: Include cfgloop.h.
1256 (migrate_btr_defs): Use bb_loop_depth.
1257 * cfg.c (dump_bb_info): Likewise.
1258 * final.c (compute_alignments): Likewise.
1259 * ira.c (update_equiv_regs): Likewise.
1260 * tree-ssa-copy.c (init_copy_prop): Likewise.
1261 * tree-ssa-dom.c (loop_depth_of_name): Likewise.
1262 * tree-ssa-forwprop.c: Include cfgloop.h.
1263 (forward_propagate_addr_expr): Use bb_loop_depth.
1264 * tree-ssa-pre.c (insert_into_preds_of_block): Likewise.
1265 * tree-ssa-sink.c (select_best_block): Likewise.
1266 * ipa-inline-analysis.c: Include cfgloop.h.
1267 (estimate_function_body_sizes): Use bb_loop_depth.
1268 * Makefile.in (tree-ssa-forwprop.o): Depend on $(CFGLOOP_H).
1269 (ipa-inline-analysis.o): Likewise.
1270 (bt-load.o): Likewise.
1271
1272 2012-08-13 Ganesh Gopalasubramanian <Ganesh.Gopalasubramanian@amd.com>
1273 Jakub Jelinek <jakub@redhat.com>
1274
1275 PR driver/54210
1276 * config/i386/driver-i386.c (host_detect_local_cpu): Test bit_PRFCHW
1277 bit of CPUID 0x80000001 %ecx instead of CPUID 7 %ecx.
1278 * config/i386/cpuid.h (bits_PRFCHW): Move definition to CPUID
1279 0x80000001 %ecx flags.
1280
1281 2012-08-13 Richard Guenther <rguenther@suse.de>
1282
1283 * tree-cfg.c (print_loop): Avoid ICEing for loops marked for
1284 removal and loops with multiple latches.
1285
1286 2012-08-13 Jakub Jelinek <jakub@redhat.com>
1287
1288 PR c/53968
1289 * tree.c (integer_pow2p): Avoid undefined signed overflows.
1290 * simplify-rtx.c (neg_const_int): Likewise.
1291 * expr.c (fixup_args_size_notes): Likewise.
1292 * stor-layout.c (set_min_and_max_values_for_integral_type): Likewise.
1293 * double-int.c (mul_double_wide_with_sign): Likewise.
1294 (double_int_mask): Likewise.
1295 * tree-ssa-loop-ivopts.c (get_address_cost): Likewise.
1296
1297 2012-08-13 Richard Guenther <rguenther@suse.de>
1298
1299 PR tree-optimization/54200
1300 * tree-ssa-copyrename.c (rename_ssa_copies): Do not add
1301 PHI results to another partition if not all PHI arguments
1302 have the same partition.
1303
1304 2012-08-12 Jan Hubicka <jh@suse.cz>
1305
1306 * tree-pass.h (write_summary, write_optimization_summary): Remove
1307 set and vset arguments.
1308 * ipa-cp.c (ipcp_write_summary): Remove set and vset arugments.
1309 (write_node_summary_p): Likewise; use the encoder.
1310 (ipa_reference_write_optimization_summary): Likewise.
1311 * lto-cgraph.c (output_cgraph_opt_summary): Use encoder.
1312 (lto_symtab_encoder_new): Initialize in_partition field.
1313 (lto_symtab_encoder_delete): Destroy in_partition field.
1314 (LCC_NOT_FOUND): Move to lto-streamer.h
1315 (lto_symtab_encoder_deref): Likewise.
1316 (lto_symtab_encoder_in_partition_p,
1317 lto_set_symtab_encoder_in_partition): New functions.
1318 (referenced_from_other_partition_p): Rewrite to use encoder.
1319 (reachable_from_other_partition_p): Likewise.
1320 (referenced_from_this_partition_p): Likewise.
1321 (reachable_from_this_partition_p): Likewise.
1322 (lto_output_node): Likewise.
1323 (lto_output_varpool_node): Likewise.
1324 (output_refs): Likewise.
1325 (compute_ltrans_boundary): Initialize in_partition fileds of
1326 the encoder.
1327 (output_symtab): Likewise.
1328 (input_refs): Match the changes in output_refs.
1329 (output_cgraph_opt_summary_p): Remove set argument.
1330 (output_node_opt_summary): Replace set by encoder.
1331 (output_cgraph_opt_summary): Remove set argument; use
1332 the encoder.
1333 * ipa-pure-const.c (pure_const_write_summary): Remove set and vset
1334 arguments; use the encoder.
1335 * lto-streamer-out.c (lto_output): Remove set and vset argument; use
1336 the encoder.
1337 (produce_symtab): Likewise.
1338 * ipa-inline.h (inline_write_summary): Remove set and vset arguments.
1339 * ipa-inline-analysis.c (inline_write_summary): Likewise.
1340 * ipa-prop.c (ipa_prop_write_jump_functions): Remove set argument;
1341 use encoder.
1342 * ipa-prop.h (ipa_prop_write_jump_functions): Likewise.
1343 * passes.c (ipa_write_summaries_2): Remove set and vset arguments.
1344 (ipa_write_summaries_1): Update.
1345 (ipa_write_optimization_summaries_1): Likewise.
1346 (ipa_write_optimization_summaries): Likewise.
1347 * lto-streamer.h (lto_symtab_encoder_t): Add in_partition.
1348 (lto_symtab_encoder_iterator): New type.
1349 (lto_symtab_encoder_deref): Make inline.
1350 (output_symtab, referenced_from_other_partition_p,
1351 reachable_from_other_partition_p, referenced_from_this_partition_p,
1352 reachable_from_this_partition_p): Update.
1353 (lsei_end_p, lsei_next, lsei_node, lsei_cgraph_node,
1354 lsei_varpool_node): New inline functions.
1355 (LCC_NOT_FOUND): New macro.
1356 (lto_symtab_encoder_deref, lsei_start, lsei_next_in_partition,
1357 lsei_start_in_partition, lsei_next_function_in_partition,
1358 lsei_start_function_in_partition, lsei_next_variable_in_partition,
1359 lsei_start_variable_in_partition): New inline functions.
1360
1361 2012-08-12 Oleg Endo <olegendo@gcc.gnu.org>
1362
1363 * config/sh/sh.md (prefetch): Simplify expander. Fix condition to
1364 allow SH3.
1365 (*prefetch_media): Move insn below expander.
1366 (*prefetch): Fix condition to allow SH3.
1367
1368 2012-08-12 Oleg Endo <olegendo@gcc.gnu.org>
1369
1370 PR target/51244
1371 * config/sh/sh.md: Add splits for inverted compare and branch
1372 opportunities.
1373 (*cmpeqsi_t): New insn.
1374 (cmpgtsi_t, cmpgesi_t): Swap r and N alternatives.
1375 (cmpgeusi_t): Use satisfies_constraint_Z. Emit sett insn in
1376 replacement insn list and not in the preparation statements.
1377 (clrt, sett): Add mt_group attribute.
1378
1379 2012-08-12 Marc Glisse <marc.glisse@inria.fr>
1380
1381 PR middle-end/54193
1382 * gimple-pretty-print.c (dump_ternary_rhs): Handle 4 arguments.
1383
1384 2012-08-12 Oleg Endo <olegendo@gcc.gnu.org>
1385
1386 PR target/39423
1387 * config/sh/predicates.md (mem_index_disp_operand): Check for
1388 arith_reg_operand instead of REG_P.
1389
1390 2012-08-11 Bernd Schmidt <bernds@codesourcery.com>
1391
1392 * reload1.c (replaced_subreg, gen_reload): Add
1393 SECONDARY_MEMORY_NEEDED ifdefs as necessary.
1394
1395 2012-08-11 Jan Hubicka <jh@suse.cz>
1396
1397 * lto-section-in.c (lto_section_name): Do not use "symtab" as part of
1398 symtab_node sectoin name; it confuses plugin.
1399
1400 2012-08-11 Uros Bizjak <ubizjak@gmail.com>
1401
1402 * config/alpha/alpha.c (alpha_stdarg_optimize_hook): Shift DECL_UID
1403 index in the va_list_vars bitmap by num_ssa_names.
1404
1405 2012-08-11 Uros Bizjak <ubizjak@gmail.com>
1406
1407 * config/i386/sse.md (xop integer multiply/add insns): Use
1408 register_operand for operand 3 predicate.
1409 (xop_phadd<u>bq): Fix vec_select selectors.
1410
1411 2012-08-11 Martin Jambor <mjambor@suse.cz>
1412
1413 PR fortran/48636
1414 * ipa-inline.h (condition): New fields offset, agg_contents and by_ref.
1415 * ipa-inline-analysis.c (agg_position_info): New type.
1416 (add_condition): New parameter aggpos, also store agg_contents, by_ref
1417 and offset.
1418 (dump_condition): Also dump aggregate conditions.
1419 (evaluate_conditions_for_known_args): Also handle aggregate
1420 conditions. New parameter known_aggs.
1421 (evaluate_properties_for_edge): Gather known aggregate contents.
1422 (inline_node_duplication_hook): Pass NULL known_aggs to
1423 evaluate_conditions_for_known_args.
1424 (unmodified_parm): Split into unmodified_parm and unmodified_parm_1.
1425 (unmodified_parm_or_parm_agg_item): New function.
1426 (set_cond_stmt_execution_predicate): Handle values passed in
1427 aggregates.
1428 (set_switch_stmt_execution_predicate): Likewise.
1429 (will_be_nonconstant_predicate): Likewise.
1430 (estimate_edge_devirt_benefit): Pass new parameter known_aggs to
1431 ipa_get_indirect_edge_target.
1432 (estimate_calls_size_and_time): New parameter known_aggs, pass it
1433 recrsively to itself and to estimate_edge_devirt_benefit.
1434 (estimate_node_size_and_time): New vector known_aggs, pass it o
1435 functions which need it.
1436 (remap_predicate): New parameter offset_map, use it to remap aggregate
1437 conditions.
1438 (remap_edge_summaries): New parameter offset_map, pass it recursively
1439 to itself and to remap_predicate.
1440 (inline_merge_summary): Also create and populate vector offset_map.
1441 (do_estimate_edge_time): New vector of known aggregate contents,
1442 passed to functions which need it.
1443 (inline_read_section): Stream new fields of condition.
1444 (inline_write_summary): Likewise.
1445 * ipa-cp.c (ipa_get_indirect_edge_target): Also examine the aggregate
1446 contents. Let all local callers pass NULL for known_aggs.
1447
1448 2012-08-11 Jan Hubicka <jh@suse.cz>
1449
1450 * lto-cgraph.c (output_cgraph): Rename to ...
1451 (output_symtab): ... this one. Update for LTO_section_symtab_nodes.
1452 (input_cgraph): Rename to ...
1453 (input_symtab): ... this one. Update for LTO_section_symtab_nodes.
1454 * lto-streamer-out.c (create_output_block): Do not set
1455 section_type.
1456 (produce_asm): Likewise.
1457 (lto_output_toplevel_asms): Likewise.
1458 (produce_asm_for_decls): Likewise.
1459 (lto_output): Use output_symtab.
1460 * lto-section-in.c (lto_section_name): Update.
1461 * lto-section-out.c (lto_destroy_simple_output_block): Remove
1462 section_type.
1463 * lto-streamer.h (enum lto_section_type): Remove LTO_section_varpool;
1464 rename LTO_section_cgraph to LTO_section_symtab_nodes.
1465 (struct lto_header): Remove section_type.
1466
1467 2012-08-11 Jan Hubicka <jh@suse.cz>
1468
1469 * cgraph.h (vector types for symtab_node): Add.
1470 * ipa-reference.c (ipa_reference_write_optimization_summary): Update
1471 for new symtab encoder.
1472 (ipa_reference_read_optimization_summary): Likewise.
1473 * lto-cgraph.c (output_varpool): Remove.
1474 (input_cgraph_opt_summary): Take symtab nodes vector as argument.
1475 (LTO_cgraph_tags): Rename to ...
1476 (LTO_symtab_tags): ... this one; add LTO_symtab_variable.
1477 (lto_cgraph_encoder_new): Rename to ...
1478 (lto_symtab_encoder_new): ... this on.
1479 (lto_cgraph_encoder_encode): Rename to ...
1480 (lto_symtab_encoder_encode): ... this one.
1481 (lto_cgraph_encoder_delete): Rename to ...
1482 (lto_symtab_encoder_delete): ... this one.
1483 (lto_cgraph_encoder_deref): Rename to ...
1484 (lto_symtab_encoder_deref): ... this one.
1485 (lto_cgraph_encoder_encode_body_p): Rename to ...
1486 (lto_symtab_encoder_encode_body_p): ... this one.
1487 (lto_varpool_encoder_new, lto_varpool_encoder_delete,
1488 lto_varpool_encoder_encode, lto_varpool_encoder_lookup,
1489 lto_varpool_encoder_deref): Remove.
1490 (lto_varpool_encoder_encode_initializer_p): Rename to ...
1491 (lto_symtab_encoder_encode_initializer_p): ... this one.
1492 (lto_set_varpool_encoder_encode_initializer): Rename to ...
1493 (lto_set_symtab_encoder_encode_initializer): ... this one.
1494 (lto_output_edge): Update.
1495 (lto_output_node): Update.
1496 (lto_output_varpool_node): Update; stream out LTO_symtab_variable tag.
1497 (lto_output_ref): Drop varpool_encoder; update.
1498 (add_node_to): Update.
1499 (add_references): Update.
1500 (output_outgoing_cgraph_edges): Update.
1501 (output_refs): Update.
1502 (compute_ltrans_boundary): Update.
1503 (output_cgraph): Update; output varpools too.
1504 (input_overwrite_node): Update.
1505 (output_varpool): Remove.
1506 (input_node): Update.
1507 (input_ref): Update.
1508 (input_edge): Update.
1509 (input_cgraph_1): Update; input varpool too; unify fixup code.
1510 (input_varpool_1): Remove.
1511 (input_refs): Update.
1512 (input_cgraph): Update.
1513 (output_node_opt_summary): Update.
1514 (input_cgraph_opt_section): Update.
1515 (input_cgraph_opt_summary): Update.
1516 * ipa-pure-const.c (pure_const_write_summary): Update.
1517 (pure_const_read_summary): Update.
1518 * lto-streamer-out.c (lto_write_tree): Update.
1519 (lto_output): Likewise.
1520 (produce_symtab): Update.
1521 (produce_asm_for_decls): Update.
1522 * ipa-inline-analysis.c (inline_read_section): Update.
1523 (inline_write_summary): Update.
1524 * ipa-prop.c (ipa_write_node_info): Update.
1525 (ipa_prop_read_section): Update.
1526 * lto-streamer.h (lto_cgraph_encoder_d): Rename to ...
1527 (lto_symtab_encoder_d): ... this one; add initializer.
1528 (lto_cgraph_encoder_t): Rename to ...
1529 (lto_symtab_encoder_t): ... this one.
1530 (lto_cgraph_encoder_size): Rename to ...
1531 (lto_symtab_encoder_size): ... this one.
1532 (lto_varpool_encoder_d): ... remove.
1533 (lto_varpool_encoder_t): Remove.
1534 (lto_out_decl_state): Remove cgraph_node_encoder, varpool_node_encoder
1535 add symtab_node_encoder.
1536 (lto_file_decl_data): Likewise.
1537 (lto_cgraph_encoder_deref, lto_cgraph_encoder_lookup,
1538 lto_cgraph_encoder_new, lto_cgraph_encoder_encode,
1539 lto_cgraph_encoder_delete, lto_cgraph_encoder_encode_body_p,
1540 lto_varpool_encoder_encode_body_p, lto_varpool_encoder_deref,
1541 lto_varpool_encoder_lookup, lto_varpool_encoder_new,
1542 lto_varpool_encoder_encode, lto_varpool_encoder_delete,
1543 lto_varpool_encoder_encode_initializer_p): Remove.
1544 (lto_symtab_encoder_deref, lto_symtab_encoder_lookup,
1545 lto_symtab_encoder_t, lto_symtab_encoder_encode,
1546 lto_symtab_encoder_delete, lto_symtab_encoder_encode_body_p,
1547 lto_symtab_encoder_encode_initializer_p): New.
1548
1549 2012-08-11 Uros Bizjak <ubizjak@gmail.com>
1550
1551 * config/i386/i386.md (isa): Add fma and fma4.
1552 (enabled): Handle fma and fma4.
1553 * config/i386/sse.md (*fma_fmadd_<mode>): Merge *fma4_fmadd_<mode>.
1554 (*fma_fmsub_<mode>): Merge *fma4_fmsub_<mode>.
1555 (*fma_fnmadd_<mode>): Merge *fma4_fnmadd_<mode>.
1556 (*fma_fnmsub_<mode>): Merge *fma4_fnmsub_<mode>.
1557 (*fma_fmaddsub_<mode>): Merge *fma4_fmaddsub_<mode>.
1558 (*fma_fmsubadd_<mode>): Merge *fma4_fmsubadd_<mode>.
1559
1560 2012-08-10 Uros Bizjak <ubizjak@gmail.com>
1561
1562 * config/i386/sse.md (*fma_fmadd_<mode>, *fma_fmsub_<mode>,
1563 *fma_fnmadd_<mode>, *fma_fnmsub_<mode>, *fma_fmaddsub_<mode>,
1564 *fma_fmsubadd_<mode>): Move FMA3 insn patterns before FMA4 patterns.
1565
1566 2012-08-10 Uros Bizjak <ubizjak@gmail.com>
1567
1568 * config/i386/i386.md (simple LEA peephole2s): Add zero-extend
1569 variants of PLUS and MULT simple LEA patterns. Disable PLUS
1570 patterns for TARGET_OPT_AGU.
1571
1572 2012-08-10 Richard Guenther <rguenther@suse.de>
1573
1574 * Makefile.in (OBJS): Remove matrix-reorg.o.
1575 (matrix-reorg.o): Remove dependence rule.
1576 (GTFILES): Remove matrix-reorg.c.
1577 * matrix-reorg.c: Remove.
1578 * passes.c (init_optimization_passes): Do not schedule
1579 pass_ipa_matrix_reorg.
1580 * tree-pass.h (pass_ipa_matrix_reorg): Remove.
1581 * common.opt (fipa-matrix-reorg): Stub out.
1582 * doc/invoke.texi (fipa-matrix-reorg): Remove documentation.
1583
1584 2012-08-10 Richard Guenther <rguenther@suse.de>
1585
1586 PR middle-end/54219
1587 * fold-const.c (fold_ternary_loc): Do not reverse the mask
1588 when canonicalizing it when folding VEC_PERM_EXPR.
1589
1590 2012-08-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
1591
1592 PR middle-end/54211
1593 * gimple-ssa-strength-reduction.c (analyze_candidates_and_replace):
1594 Use cand_type to determine whether pointer arithmetic will be generated.
1595
1596 2012-08-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
1597
1598 * doc/sourcebuild.texi: Document long_neq_int effective target.
1599
1600 2012-08-10 Richard Guenther <rguenther@suse.de>
1601
1602 PR tree-optimization/54109
1603 * tree-ssa-forwprop.c
1604 (forward_propagate_addr_into_variable_array_index): Remove.
1605 (forward_propagate_addr_expr_1): Adjust.
1606
1607 2012-08-10 Richard Guenther <rguenther@suse.de>
1608
1609 * tree-cfg.c (dump_function_to_file): Make sure to dump
1610 anonymous SSA names when there are no local decls.
1611
1612 2012-08-10 Steven Bosscher <steven@gcc.gnu.org>
1613
1614 * tree-ssa-pre.c (alloc_expression_id): Fix use of VEC_reserve.
1615 * tree-into-ssa.c (get_ssa_name_ann): Likewise.
1616 (mark_phi_for_rewrite): Likewise.
1617 (compute_global_livein): Use VEC_reserve outside the innermost
1618 loop and VEC_quick_push instead of VEC_safe_push in that loop.
1619 (update_ssa): Re-organize to avoid unnecessary sbitmap_zero'ing
1620 of new_ssa_names and old_ssa_names. Allocate phis_to_rewrite to
1621 the correct initial size.
1622
1623 2012-08-10 Richard Guenther <rguenther@suse.de>
1624
1625 * tree-ssa-pre.c (pretemp, storetemp, prephitemp): Remove.
1626 (need_creation): Remove.
1627 (get_representative_for): Use anonymous named SSA names.
1628 (create_expression_by_pieces): Likewise.
1629 (insert_into_preds_of_block): Likewise.
1630 (init_pre): Do not init removed vars.
1631 (fini_pre): Do not free need_creation.
1632 * tree-ssa-forwprop.c (simplify_bitwise_binary): Use anonymous
1633 SSA names.
1634 * tree-ssa-loop-manip.c (create_iv): Likewise.
1635 * value-prof.c (gimple_divmod_fixed_value): Likewise.
1636 (gimple_mod_pow2): Likewise.
1637 (gimple_mod_subtract): Likewise.
1638 (gimple_ic): Likewise.
1639 (gimple_stringop_fixed_value): Likewise.
1640 * tree-ssa-phiopt.c (condstoretemp): Remove.
1641 (tree_ssa_phiopt_worker): Use anonymous named SSA names.
1642 (conditional_replacement): Likewise.
1643 (abs_replacement): Likewise.
1644 (cond_store_replacement): Likewise.
1645 (cond_if_else_store_replacement_1): Likewise.
1646 * tree-ssa-loop-im.c (rewrite_reciprocal): Likewise.
1647 (rewrite_bittest): Likewise.
1648 * tree-ssa-reassoc.c (build_and_add_sum): Get type from callers
1649 and build anonymous SSA names.
1650 (undistribute_ops_list): Adjust.
1651 (eliminate_redundant_comparison): Use anonymous SSA names.
1652 (rewrite_expr_tree_parallel): Likewise.
1653 (get_reassoc_pow_ssa_name): Remove.
1654 (attempt_builtin_powi): Adjust.
1655 (reassociate_bb): Likewise.
1656 * tree-ssa-strlen.c (get_string_length): Use anonymous SSA names.
1657 * tree-switch-conversion.c (emit_case_bit_tests): Likewise.
1658 (build_arrays): Likewise.
1659 * tree-tailcall.c (adjust_return_value_with_ops): Likewise.
1660 (create_tailcall_accumulator): Likewise.
1661 * tree-vect-generic.c (expand_vector_divmod): Likewise.
1662 * tree-profile.c (gcov_type_tmp_var): Remove.
1663 (gimple_init_edge_profiler): Do not initialize it and use anonymous
1664 SSA names.
1665 (gimple_gen_ic_profiler): Likewise.
1666 (tree_profiling): Adjust.
1667 * tree-sra.c (build_ref_for_offset): Use anonymous SSA names.
1668 * tree-ssa-math-opts.c (execute_cse_sincos_1): Likewise.
1669 (powi_as_mults_1): Likewise.
1670 (powi_as_mults): Likewise.
1671 (build_and_insert_call): Adjust.
1672 (build_and_insert_binop): Likewise.
1673 (build_and_insert_ref): Likewise.
1674 (build_and_insert_cast): Likewise.
1675 (gimple_expand_builtin_pow): Likewise.
1676 (gimple_expand_builtin_cabs): Likewise.
1677 (execute_optimize_bswap): Use anonymous SSA names.
1678 (convert_mult_to_widen): Likewise.
1679 (convert_plusminus_to_widen): Likewise.
1680 * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
1681 * tree-ssa-propagate.c (update_call_from_tree): Likewise.
1682 * tree-if-conv.c (ifc_temp_var): Likewise.
1683 * tree-loop-distribution.c (generate_memset_builtin): Likewise.
1684 * tree-parloops.c (take_address_of): Likewise.
1685 * tree-vect-data-refs.c (vect_permute_store_chain): Likewise.
1686 (vect_permute_load_chain): Likewise.
1687 * tree-vect-loop-manip.c (vect_create_cond_for_align_checks): Likewise.
1688 * tree-vect-patterns.c (vect_recog_temp_ssa_var): Likewise.
1689 (vect_handle_widen_op_by_const): Likewise.
1690 (vect_operation_fits_smaller_type): Likewise.
1691 (vect_recog_over_widening_pattern): Likewise.
1692 * tree-vect-stmts.c (vect_init_vector): Likewise.
1693 * tree-vrp.c (simplify_truth_ops_using_ranges): Likewise.
1694 (simplify_float_conversion_using_ranges): Likewise.
1695
1696 2012-08-10 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
1697
1698 * config/i386/i386.c (ix86_init_mmx_sse_builtins): Fix
1699 target mask of __builtin_ia32_rdseed_di_step builtin.
1700
1701 2012-08-10 Richard Guenther <rguenther@suse.de>
1702
1703 PR tree-optimization/54027
1704 * tree-vrp.c (extract_range_from_binary_expr_1): Merge RSHIFT_EXPR
1705 and LSHIFT_EXPR handling, force -fwrapv for the multiplication used
1706 to handle LSHIFT_EXPR with a constant.
1707
1708 2012-08-10 Richard Guenther <rguenther@suse.de>
1709
1710 * tree.h (SSA_NAME_VAR): Return NULL_TREE if an IDENTIFIER_NODE
1711 is recorded as var.
1712 (SSA_NAME_IDENTIFIER): Return the IDENTIFIER_NODE of the SSA_NAME
1713 or its SSA_NAME_VAR.
1714 (SET_SSA_NAME_VAR_OR_IDENTIFIER): New setter.
1715 * tree-ssanames.c (make_ssa_name_fn): Handle creating anonymous
1716 SSA names by passing a type instead of a variable decl.
1717 (release_ssa_name): Use SET_SSA_NAME_VAR_OR_IDENTIFIER.
1718 (copy_ssa_name_fn): Handle anonymous SSA names.
1719 (replace_ssa_name_symbol): Use SET_SSA_NAME_VAR_OR_IDENTIFIER.
1720 * tree-flow-inline.h (make_temp_ssa_name): New inline function.
1721 * tree-pretty-print.c (dump_generic_node): Use SSA_NAME_IDENTIFIER,
1722 dump SSA names without a name as <anon>.
1723 * cfgexpand.c (expand_used_vars): Assing anonymous SSA names we are
1724 going to expand a decl.
1725 (gimple_expand_cfg): Assign all SSA names of a partition the
1726 decl we created for its leader.
1727 * tree-ssa.c (target_for_debug_bind): Handle SSA_NAMEs.
1728 (verify_ssa_name): Handle anonymous SSA names.
1729 (verify_def): Likewise.
1730 * tree-predcom.c (eliminate_temp_copies): Likewise.
1731 * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Likewise.
1732 * tree-ssa-live.c (var_map_base_init): Compute conflicts for
1733 anonymous SSA names with the same type.
1734 (mark_all_vars_used_1): Handle anonymous SSA names.
1735 (verify_live_on_entry): Likewise.
1736 * tree-ssa-coalesce.c (abnormal_corrupt): Remove.
1737 (create_outofssa_var_map): Adjust with respect to conflicts we
1738 compute for anonymous SSA names. Do not restrict abnormal
1739 coalescing.
1740 (coalesce_partitions): Do not restrict abnormal coalescing.
1741 Assert we only ever coalesce variables we computed conflicts for.
1742 * tree-ssa-ter.c (process_replaceable): Do not restrict TER
1743 of anonymous names.
1744 * expr.c (expand_expr_real_1): Handle anonymous SSA names
1745 expanded from IVOPTs by creating a raw REG here.
1746 * tree-cfg.c (replace_ssa_name): Handle anonymous SSA names.
1747 (dump_function_to_file): Dump anonymous SSA names alongside
1748 with their types in the variable list.
1749 (verify_gimple_return): Guard use of SSA_NAME_VAR.
1750 * tree-into-ssa.c (mark_for_renaming): Handle a NULL symbol.
1751 (rewrite_into_ssa): Make SSA names anonymous.
1752 * tree-ssa-structalias.c (alias_get_name): Rewrite.
1753 * tree-ssa-uninit.c (ssa_undefined_value_p): Handle anonymous
1754 SSA names.
1755 (warn_uninitialized_phi): Likewise.
1756 * tree-ssa-loop-ivopts.c (prepare_decl_rtl): Defer expanding
1757 anonymous SSA names to the expander.
1758 (determine_iv_cost): Anonymous SSA names are artificial.
1759 * tree-ssa-loop-manip.c (tree_transform_and_unroll_loop):
1760 Handle anonymous SSA names.
1761 * lto-streamer-out.c (output_ssa_names): Stream SSA_NAME_VAR
1762 or if NULL, the type of the SSA name.
1763 * tree-inline.c (remap_ssa_name): Handle anonymous SSA names,
1764 remap names as anonymous where appropriate.
1765 (insert_init_stmt): Pass SSA names down to insert_init_debug_bind.
1766 * tree-ssa-uncprop.c (uncprop_into_successor_phis): Adjust
1767 according to what we create conflicts for in out-of-SSA
1768 coalescing.
1769 * tree-parloops.c (separate_decls_in_region_name): Handle
1770 anonymous SSA names.
1771 (add_field_for_name): Likewise.
1772 * tree.c (get_name): Handle SSA names.
1773 * tree-ssa-loop-im.c (gen_lsm_tmp_name): Defer to get_name for
1774 SSA_NAMEs.
1775 * tree-vect-loop-manip.c (adjust_debug_stmts): Use
1776 virtual_operand_p.
1777 * tree-sra.c (create_access_replacement): Give up generating
1778 a DECL_DEBUG_EXPR for SSA names in the memory reference.
1779 (replace_removed_params_ssa_names): Guard use of SSA_NAME_VAR.
1780 * tree-complex.c (get_component_ssa_name): Handle anonymous
1781 SSA names.
1782 (set_component_ssa_name): Likewise.
1783 * tree-ssa-sccvn.c (visit_reference_op_load): Likewise.
1784 * tree-object-size.c (collect_object_sizes_for): Handle
1785 uninitialized SSA names properly.
1786 * ipa-inline-analysis.c (eliminated_by_inlining_prob): Guard use of
1787 SSA_NAME_VAR.
1788 * ipa-split.c (test_nonssa_use): Likewise.
1789 (consider_split): Likewise.
1790 (mark_nonssa_use): Likewise.
1791
1792 2012-08-09 Jan Hubicka <jh@suse.cz>
1793
1794 PR middle-end/54146
1795 * ipa-inline-transform.c (inline_call): Add UPDATE_OVERALL_SUMMARY
1796 parameter; honnor it.
1797 * ipa-inline.c (recursive_inlining): Update call
1798 of inline_call.
1799 (inline_small_functions): Likewise.
1800 (ipa_inline): Likewise.
1801 (inline_always_inline_functions): Likewise.
1802 (early_inline_small_functions): Likewise.
1803 (flatten_function): Do separate update of summary info.
1804 * ipa-inline.h (inline_update_overall_summary): Declare.
1805 (inline_call): Update.
1806 * ipa-inline-analysis.c (inline_merge_summary): Break out
1807 updating code to ...
1808 (inline_update_overall_summary): Likewise.
1809
1810 2012-08-09 Richard Henderson <rth@redhat.com>
1811
1812 * config/s390/s390.c (s390_expand_insv): Use VOIDmode in gen_rtx_SET.
1813
1814 * config/s390/s390.c (s390_expand_cs_hqi): Copy val to a temp before
1815 performing the compare for the restart loop.
1816
1817 2012-08-09 DJ Delorie <dj@redhat.com>
1818
1819 * config/rl78/rl78.c (rl78_alloc_physical_registers): Check for
1820 SET before extracting SET_SRC.
1821 (rl78_remove_unused_sets): Check for REG before extractnig REGNO.
1822
1823 2012-08-09 Oleg Endo <olegendo@gcc.gnu.org>
1824
1825 PR target/54089
1826 * config/sh/sh-protos (shift_insns_rtx): Delete.
1827 (sh_ashlsi_clobbers_t_reg_p): Add.
1828 * config/sh/sh.c (shift_insns, shift_amounts, ext_shift_insns,
1829 ext_shift_amounts): Merge arrays of ints to array of structs.
1830 Adapt usage of arrays throughout the file.
1831 (shift_insns_rtx): Delete unused function.
1832 (sh_ashlsi_clobbers_t_reg_p): New function.
1833 * config/sh/sh.md (ashlsi3): Emit ashlsi3_n_clobbers_t insn if the
1834 final shift sequence will clobber T_REG.
1835 (ashlsi3_n): Split only if the final shift sequence will not
1836 clobber T_REG.
1837 (ashlsi3_n_clobbers_t): New insn_and_split.
1838
1839 2012-08-09 Steven Bosscher <steven@gcc.gnu.org>
1840
1841 * calls.c (mem_overlaps_already_clobbered_arg_p): Use SBITMAP_SIZE
1842 instead of looking at sbitmap n_bits member directly.
1843 * gcse.c (hoist_code): Likewise.
1844 * sched-rgn.c (split_edges): Likewise.
1845 * tree-into-ssa.c (is_old_name, is_new_name, add_new_name_mapping,
1846 update_ssa): Likewise.
1847
1848 2012-08-09 Uros Bizjak <ubizjak@gmail.com>
1849
1850 * config/i386/i386.h (LIMIT_RELOAD_CLASS): Return preferred
1851 single unit register class for classes that contain registers form
1852 multiple units.
1853 (REG_CLASS_CONTENTS): Add missing "frame" register to FLOAT_INT_REGS,
1854 INT_SSE_REGS and FLOAT_INT_SSE_REGS register classes.
1855
1856 2012-08-09 Martin Jambor <mjambor@suse.cz>
1857
1858 * cgraph.h (cgraph_indirect_call_info): Field anc_offse renamd to
1859 offset, updated all users. New field agg_contents.
1860 * ipa-prop.h (jump_func_type): Removed IPA_JF_CONST_MEMBER_PTR.
1861 (ipa_pass_through_data): New field agg_preserved.
1862 (ipa_ancestor_jf_data): Likewise.
1863 (ipa_member_ptr_cst): Removed.
1864 (ipa_agg_jf_item): New type.
1865 (ipa_agg_jump_function): Likewise.
1866 (ipa_jump_func): New field agg. Removed field member_cst.
1867 (ipa_get_jf_pass_through_agg_preserved): New function.
1868 (ipa_get_jf_ancestor_agg_preserved): Likewise.
1869 (ipa_get_jf_member_ptr_pfn): Removed.
1870 (ipa_find_agg_cst_for_param): Declare.
1871 (ipa_load_from_parm_agg): Likewise.
1872 * ipa-prop.c (param_analysis_info): Fields modified and
1873 visited_statements rename to parm_modified and parm_visited_statements
1874 respectively, added fields ref_modified, ref_visited_statements,
1875 pt_modified and pt_visited_statements.
1876 (ipa_print_node_jump_functions_for_edge): Do not dump const member
1877 functions. Dump agg_preserved flags and aggregate jump functions.
1878 (ipa_set_jf_simple_pass_through): Set also agg_preserved.
1879 (ipa_set_ancestor_jf): Likewise.
1880 (ipa_set_jf_arith_pass_through): Clear agg_preserved.
1881 (ipa_set_jf_member_ptr_cst): Removed.
1882 (is_parm_modified_before_stmt): Logic reversed, renamed to
1883 parm_preserved_before_stmt_p. Cache visited bitmap only for
1884 naked DECL parameters. All callers updated.
1885 (load_from_unmodified_param): Allow NULL parms_ainfo.
1886 (parm_ref_data_preserved_p): New function.
1887 (parm_ref_data_pass_through_p): Likewise.
1888 (ipa_load_from_parm_agg_1): Likewise.
1889 (ipa_load_from_parm_agg): Likewise.
1890 (compute_complex_assign_jump_func): Check if aggregate contents are
1891 preserved.
1892 (compute_complex_ancestor_jump_func): Likewise.
1893 (compute_scalar_jump_functions): Removed.
1894 (type_like_member_ptr_p): Also check field position are known and sane.
1895 (compute_pass_through_member_ptrs): Removed.
1896 (determine_cst_member_ptr): Likewise.
1897 (ipa_known_agg_contents_list): New type.
1898 (determine_known_aggregate_parts): New function.
1899 (compute_cst_member_ptr_arguments): Removed.
1900 (ipa_compute_jump_functions_for_edge): Compute all kinds of jump
1901 functions (scalar, aggregate and member pointer).
1902 (ipa_get_member_ptr_load_param): Incorporate into
1903 ipa_get_stmt_member_ptr_load_param, also pass back an offset.
1904 (ipa_note_param_call): Clear agg_contents.
1905 (ipa_analyze_indirect_call_uses): Also look for simple pointers loaded
1906 from aggregates. In such cases, store offset of the called field.
1907 (ipa_analyze_node): Initialize new fields of param_analysis_info.
1908 (update_jump_functions_after_inlining): Handle aggregate contents.
1909 (ipa_find_agg_cst_for_param): New function.
1910 (try_make_edge_direct_simple_call): Handle called aggregate values.
1911 (update_indirect_edges_after_inlining): Make sure aggregate preserving
1912 jump functions comply with type compatibility requirements.
1913 (ipa_edge_duplication_hook): Copy also aggregate jump functions.
1914 (ipa_write_jump_function): Stream agg_preserved flags and aggregate
1915 jump functions. Do not stream member pointer constant jump functions.
1916 (ipa_read_jump_function): Likewise.
1917 (ipa_write_indirect_edge_info): Stream new cgraph_indirect_call_info
1918 fields.
1919 (ipa_read_indirect_edge_info): Likewise.
1920
1921 2012-08-09 Oleg Endo <olegendo@gcc.gnu.org>
1922
1923 PR target/39423
1924 * config/sh/predicates.md (mem_index_disp_operand): New predicate.
1925 * config/sh/sh.md (*movsi_index_disp): Rewrite insns to use the new
1926 mem_index_disp_operand predicate.
1927
1928 2012-08-09 Oleg Endo <olegendo@gcc.gnu.org>
1929
1930 PR target/51244
1931 * config/sh/sh.md: Add negc extu sequence peephole.
1932 (movrt, movnegt, movrt_negc, nott): Use t_reg_operand predicate.
1933 (*movrt_negc): New insn.
1934 * config/sh/sync.md (atomic_test_and_set): Pass gen_t_reg_rtx to
1935 gen_movnegt.
1936 * config/sh/sh.c (expand_cbranchsi4, sh_emit_scc_to_t,
1937 sh_emit_compare_and_branch, sh_emit_compare_and_set): Use
1938 get_t_reg_rtx.
1939 (sh_expand_t_scc): Pass gen_t_reg_rtx to gen_movnegt.
1940
1941 2012-08-09 Oleg Endo <olegendo@gcc.gnu.org>
1942
1943 PR target/50751
1944 * config/sh/sh.md (*extendqisi2_compact_reg, *extendhisi2_compact_reg):
1945 Use arith_reg_operand predicate instead of register_operand.
1946 * config/sh/predicates.md (movsrc_no_disp_mem_operand): Accept
1947 only mem, simplify.
1948
1949 2012-08-09 Uros Bizjak <ubizjak@gmail.com>
1950
1951 * config/alpha/alpha.c (alpha_pad_noreturn): Rename to ...
1952 (alpha_pad_function_end): ... this. Also insert NOP between
1953 sibling call and GP load.
1954 (alpha_reorg): Update call to alpha_pad_function_end. Expand comment.
1955
1956 2012-08-09 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
1957
1958 * config/i386/adxintrin.h: Remove guarding __ADX__ check.
1959 * config/i386/x86intrin.h: Likewise.
1960 * config/i386/i386.c (ix86_init_mmx_sse_builtins): Remove
1961 OPTION_MASK_ISA_ADX from needed options for
1962 __builtin_ia32_addcarryx_u32 and __builtin_ia32_addcarryx_u64.
1963 (ix86_expand_builtin): Use add<mode>3_carry in expanding of
1964 IX86_BUILTIN_ADDCARRYX32 and IX86_BUILTIN_ADDCARRYX64.
1965
1966 2012-08-09 Andrey Belevantsev <abel@ispras.ru>
1967
1968 PR rtl-optimization/53701
1969 * sel-sched.c (vinsn_vec_has_expr_p): Clarify function comment.
1970 Process not only expr's vinsns but all old vinsns from expr's
1971 history of changes.
1972 (update_and_record_unavailable_insns): Clarify comment.
1973
1974 2012-08-09 Bernd Schmidt <bernds@codesourcery.com>
1975
1976 * reload.c (find_valid_class_1): New static function.
1977 (push_reload): Use it when reloading a SYMBOL_REG as the inner
1978 of a subreg. Keep better track of needed classes for the
1979 secondary memory case.
1980 * config/i386/i386.h (LIMIT_RELOAD_CLASS): Limit INT_SSE_REGS to
1981 GENERAL_REGS.
1982 * reload1.c (replaced_subreg): New static function.
1983 (gen_reload): Use it when deciding whether to use secondary
1984 memory.
1985
1986 2012-08-09 Richard Guenther <rguenther@suse.de>
1987
1988 * tree.h (SSA_VAR_P): Simplify.
1989 * tree-ssanames.c (make_ssa_name_fn): Strengthen assert.
1990 * fold-const.c (fold_comparison): Check for default def first
1991 before checking for PARM_DECL.
1992 * tree-complex.c (get_component_ssa_name): Likewise.
1993 * tree-inline.c (remap_ssa_name): Likewise.
1994 * tree-ssa-loop-ivopts.c (parm_decl_cost): Likewise.
1995 * tree-ssa-structalias.c (get_fi_for_callee): Likewise.
1996 (find_what_p_points_to): Likewise.
1997 * tree-ssa-operands.c (add_stmt_operand): Simplify.
1998
1999 2012-08-08 Joseph Myers <joseph@codesourcery.com>
2000
2001 * simplify-rtx.c (simplify_binary_operation_1): Do not simplify
2002 IOR to a constant if one operand has side effects.
2003
2004 2012-08-08 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
2005
2006 * builtins.c (expand_builtin_atomic_compare_exchange): Pass old
2007 value operand as MEM to expand_atomic_compare_and_swap.
2008
2009 * config/s390/s390.md ("atomic_compare_and_swap<mode>"): Accept
2010 nonimmediate_operand for old value; generate load and store if
2011 needed.
2012 * config/s390/s390.c (s390_expand_cs_hqi): Accept any operand
2013 as vtarget.
2014
2015 2012-08-08 Steven Bosscher <steven@gcc.gnu.org>
2016
2017 PR middle-end/54146
2018 * gimpify.c (gimplify_body): Only verify_gimple_in_seq with
2019 checking enabled.
2020 * tree-ssa-loop-manip.c (add_exit_phis_var): Assert that var is
2021 a gimple_reg if checking is enabled.
2022 (find_uses_to_rename_stmt): Only look at non-virtual USE operands.
2023 * tree-into-ssa (compute_global_livein): Change the worklist
2024 type from an array to a VEC.
2025
2026 2012-08-08 Richard Guenther <rguenther@suse.de>
2027
2028 * tree-ssa-operands.h (virtual_operand_p): Declare.
2029 * tree-ssa-operands.c (virtual_operand_p): New predicate.
2030 * gimple.c (is_gimple_reg): Use virtual_operand_p.
2031 * tree-into-ssa.c (prepare_block_for_update): Likewise.
2032 * tree-vect-loop-manip.c (adjust_debug_stmts): Likewise.
2033
2034 2012-08-08 Richard Guenther <rguenther@suse.de>
2035
2036 * tree-call-cdce.c (check_pow): Simplify.
2037 (gen_conditions_for_pow_int_base): Likewise.
2038 * tree-ssa-dom.c (propagate_rhs_into_lhs): Do not handle
2039 virtual operands here.
2040 * tree-ssa-operands.c (get_name_decl): Remove unused function.
2041 * gimplify.c (gimple_regimplify_operands): Remove dead code.
2042 * tree-vrp.c (get_value_range): Move SSA_NAME_VAR access.
2043 * tree-parloops.c (create_phi_for_local_result): Use copy_ssa_name.
2044 * value-prof.c (gimple_ic): Use duplicate_ssa_name.
2045 (gimple_stringop_fixed_value): Likewise.
2046 * tree.c (needs_to_live_in_memory): Remove SSA name handling.
2047 * tree-stdarg.c (find_va_list_reference): Store SSA_NAME_VERSIONs
2048 in the bitmap alongside shifted DECL_UIDs.
2049 (va_list_counter_struct_op): Likewise.
2050 (va_list_ptr_read): Likewise.
2051 (va_list_ptr_write): Likewise.
2052 (check_va_list_escapes): Likewise.
2053 (check_all_va_list_escapes): Likewise.
2054 (execute_optimize_stdarg): Likewise.
2055 * tree-outof-ssa.c (insert_backedge_copies): Use copy_ssa_name.
2056
2057 2012-08-08 Richard Sandiford <rdsandiford@googlemail.com>
2058 H.J. Lu <hongjiu.lu@intel.com>
2059
2060 PR rtl-optimization/54157
2061 * combine.c (gen_lowpart_for_combine): Don't return identity
2062 for CONST or symbolic reference.
2063
2064 2012-08-08 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
2065
2066 * common/config/i386/i386-common.c (OPTION_MASK_ISA_ADX_SET): New.
2067 (OPTION_MASK_ISA_ADX_UNSET): Likewise.
2068 (ix86_handle_option): Handle madx option.
2069 * config.gcc (i[34567]86-*-*): Add adxintrin.h.
2070 (x86_64-*-*): Likewise.
2071 * config/i386/adxintrin.h: New header.
2072 * config/i386/driver-i386.c (host_detect_local_cpu): Detect ADCX/ADOX
2073 support.
2074 * config/i386/i386-builtin-types.def
2075 (UCHAR_FTYPE_UCHAR_UINT_UINT_PUNSIGNED): New function type.
2076 (UCHAR_FTYPE_UCHAR_ULONGLONG_ULONGLONG_PULONGLONG): Likewise.
2077 * config/i386/i386-c.c: Define __ADX__ if needed.
2078 * config/i386/i386.c (ix86_target_string): Define -madx option.
2079 (PTA_ADX): New.
2080 (ix86_option_override_internal): Handle new option.
2081 (ix86_valid_target_attribute_inner_p): Add OPT_madx.
2082 (ix86_builtins): Add IX86_BUILTIN_ADDCARRYX32,
2083 IX86_BUILTIN_ADDCARRYX64.
2084 (ix86_init_mmx_sse_builtins): Define corresponding built-ins.
2085 (ix86_expand_builtin): Handle these built-ins.
2086 (ix86_expand_args_builtin): Handle new function types.
2087 * config/i386/i386.h (TARGET_ADX): New.
2088 * config/i386/i386.md (adcx<mode>3): New define_insn.
2089 * config/i386/i386.opt (madx): New.
2090 * config/i386/x86intrin.h: Include adxintrin.h.
2091
2092 2012-08-08 Nick Clifton <nickc@redhat.com>
2093
2094 * config/rl78/rl78.c: Include tree-pass.h.
2095
2096 2012-08-08 Steven Bosscher <steven@gcc.gnu.org>
2097
2098 PR middle-end/54146
2099 * ira.c (init_live_subregs): Take live_subregs_used as a bitmap.
2100 (build_insn_chain): Make live_subregs_used a bitmap.
2101 Use SBITMAP_SIZE to ignore the paradoxical bytes of subregs.
2102 Use sbitmap_free to free the live_subreg sbitmaps.
2103
2104 PR middle-end/54146
2105 * ifcvt.c: Include pointer-set.h.
2106 (cond_move_process_if_block): Change type of then_regs and
2107 else_regs from alloca'd array to pointer_sets.
2108 (check_cond_move_block): Update for this change.
2109 (cond_move_convert_if_block): Likewise.
2110 * Makefile.in: Fix dependencies for ifcvt.o.
2111
2112 2012-08-07 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
2113
2114 * gimple-ssa-strength-reduction.c (struct incr_info_d): New struct.
2115 (incr_vec): New static var.
2116 (incr_vec_len): Likewise.
2117 (address_arithmetic_p): Likewise.
2118 (stmt_cost): Remove dead assignment.
2119 (dump_incr_vec): New function.
2120 (cand_abs_increment): Likewise.
2121 (lazy_create_slsr_reg): Likewise.
2122 (incr_vec_index): Likewise.
2123 (count_candidates): Likewise.
2124 (record_increment): Likewise.
2125 (record_increments): Likewise.
2126 (unreplaced_cand_in_tree): Likewise.
2127 (optimize_cands_for_speed_p): Likewise.
2128 (lowest_cost_path): Likewise.
2129 (total_savings): Likewise.
2130 (analyze_increments): Likewise.
2131 (ncd_for_two_cands): Likewise.
2132 (nearest_common_dominator_for_cands): Likewise.
2133 (profitable_increment_p): Likewise.
2134 (insert_initializers): Likewise.
2135 (introduce_cast_before_cand): Likewise.
2136 (replace_rhs_if_not_dup): Likewise.
2137 (replace_one_candidate): Likewise.
2138 (replace_profitable_candidates): Likewise.
2139 (analyze_candidates_and_replace): Handle candidates with SSA-name
2140 strides.
2141
2142 2012-08-07 Steven Bosscher <steven@gcc.gnu.org>
2143
2144 * cfg.c (debug_bb): Do not set TDF_BLOCKS.
2145 * cfghooks.c (dump_bb): Honor ~TDF_BLOCKS.
2146 * pretty-print.c (pp_base_flush): Do not add a newline, and do not
2147 clear pp_needs_newline.
2148 * pretty-print.h (pp_newline_and_flush): New macro with the behavior
2149 of pp_base_flush before the above change.
2150 * langhooks.c (lhd_print_error_function): Use pp_newline_and_flush
2151 instead of pp_flush.
2152 * diagnostic.c (diagnostic_finish): Likewise.
2153 (diagnostic_report_diagnostic): Likewise.
2154 (verbatim): Likewise.
2155 (error_recursion): Likewise.
2156 * tree-pretty-print.c (print_generic_stmt): Likewise.
2157 (print_generic_stmt_indented): LIkewise.
2158 * gimple-pretty-print.c (print_gimple_stmt): Likewise.
2159 (print_gimple_seq): Likewise.
2160 (gimple_dump_bb_buff): Likewise.
2161
2162 2012-08-07 Uros Bizjak <ubizjak@gmail.com>
2163
2164 PR debug/54177
2165 * var-tracking.c (var_lowpart): Exit early for matched modes.
2166
2167 2012-08-07 Richard Henderson <rth@redhat.com>
2168
2169 * config/s390/s390.c (s390_emit_compare_and_swap): Update for
2170 atomic_compare_and_swapsi_internal name change.
2171 (s390_expand_insv): Try RISBG last, not requiring operands in
2172 registers but forcing them there. Try a limited form of ICM.
2173 (s390_two_part_insv): New.
2174 (s390_expand_cs_hqi): Use it. Update for atomic optabs.
2175 * config/s390/s390.md (UNSPEC_MOVA): New.
2176 (TDSI): Remove mode iterator.
2177 (DGPR, DINT, TDI): New mode iterators.
2178 (td): New mode attribute.
2179 (mem_signal_fence): New.
2180 (mem_thread_fence): Rename from memory_barrier; update for model arg.
2181 (mem_thread_fence_1): Rename from *memory_barrier.
2182 (atomic_load<DINT>, atomic_store<DINT>): New expanders.
2183 (atomic_loaddi_1, atomic_loadti_1): New.
2184 (atomic_storedi_1, atomic_storeti_1): New.
2185 (sync_compare_and_swap<TDSI>, sync_compare_and_swap<HQI>): Remove.
2186 (atomic_compare_and_swap<DGPR>, atomic_compare_and_swap<HQI>): New.
2187 (atomic_compare_and_swap<DGPR>_internal): New.
2188 (*sync_compare_and_swap<DW>, *sync_compare_and_swap<GPR>): Remove.
2189 (*atomic_compare_and_swap<TDI>_1): New.
2190 (*atomic_compare_and_swapdi_2, *atomic_compare_and_swapsi_3): New.
2191 (sync_<ATOMIC_Z196><GPR>, sync_old_<ATOMIC_Z196><GPR>): Remove.
2192 (atomic_fetch_<ATOMIC_Z196><GPR>): New.
2193 (atomic_fetch_<ATOMC_Z196><GPR>_iaf): New.
2194 (sync_<ATOMIC><HQI>, sync_old_<ATOMIC><HQI>): Remove.
2195 (sync_new_<ATOMIC><HQI>): Remove.
2196 (atomic_<ATOMIC><HQI>, atomic_fetch_<ATOMIC><HQI>): New.
2197 (atomic_<ATOMIC>_fetch<HQI>): New.
2198 (sync_lock_test_and_set<HQI>): Remove.
2199 (atomic_exchange<HQI>): New.
2200
2201 2012-08-07 Paul Brook <paul@codesourcery.com>
2202 Sandra Loosemore <sandra@codesourcery.com>
2203
2204 * except.c (switch_to_exception_section): Place tables for
2205 DECL_ONE_ONLY functions in comdat groups.
2206
2207 2012-08-07 Richard Guenther <rguenther@suse.de>
2208
2209 * tree-flow.h (copy_ssa_name_fn): New function.
2210 (duplicate_ssa_name_fn): Likewise.
2211 * tree-flow-inline.h (copy_ssa_name): New function.
2212 (duplicate_ssa_name): Likewise.
2213 * tree-ssanames.c (copy_ssa_name_fn): New function.
2214 (duplicate_ssa_name): Rename to ...
2215 (duplicate_ssa_name_fn): ... this and adjust.
2216 * tree-tailcall.c (update_accumulator_with_ops): Use copy_ssa_name.
2217 * tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard1):
2218 Likewise.
2219 (slpeel_update_phi_nodes_for_guard2): Likewise.
2220 (slpeel_tree_peel_loop_to_edge): Likewise.
2221 (vect_loop_versioning): Likewise.
2222 * tree-parloops.c (transform_to_exit_first_loop): Likewise.
2223 (create_parallel_loop): Likewise.
2224 * ipa-split.c (split_function): Likewise.
2225 * tree-vect-loop.c (vect_is_simple_reduction_1): Likewise.
2226 (vect_create_epilog_for_reduction): Likewise.
2227 * tree-vect-data-refs.c (bump_vector_ptr): Likewise.
2228 (vect_setup_realignment): Likewise.
2229 * tree-vect-stmts.c (vectorizable_load): Likewise.
2230 * tree-switch-conversion.c (build_one_array): Likewise.
2231 (gen_def_assigns): Likewise.
2232 * tree-cfg.c (gimple_make_forwarder_block): Likewise.
2233 * graphite-sese-to-poly.c (rewrite_close_phi_out_of_ssa): Call
2234 create_zero_dim_array with the SSA name.
2235 (rewrite_phi_out_of_ssa): Likewise.
2236 (rewrite_cross_bb_scalar_dependence): Likewise. Use copy_ssa_name.
2237
2238 2012-08-07 Richard Guenther <rguenther@suse.de>
2239
2240 * tree-dfa.c (set_ssa_default_def): Clear the SSA_NAME_DEFAULT_DEF
2241 bit of the old name when we clear the slot.
2242 * tree-ssa-live.c (remove_unused_locals): Release any default
2243 def associated with an unused var.
2244 * tree-ssa-copy.c (may_propagate_copy_into_asm): Always return true.
2245
2246 2012-08-07 Richard Guenther <rguenther@suse.de>
2247
2248 * tree-into-ssa.c (rewrite_stmt): Remove clobbers for variables
2249 we rewrite into SSA form.
2250 (rewrite_enter_block): Adjust.
2251 * gimple-iterator.c (gsi_replace): Also allow replacement with
2252 a stmt without a lhs.
2253 * tree-ssa-live.c (remove_unused_locals): Remove code handling
2254 clobbers of SSA names.
2255 * tree-nested.c (convert_local_reference_stmt): Remove clobbers
2256 for variables we access through the local chain.
2257 * tree-cfg.c (verify_gimple_assign_single): Verify clobbers
2258 clobber full decls only.
2259
2260 2012-08-07 Richard Guenther <rguenther@suse.de>
2261
2262 * gimple.h (gimple_phi_set_result): Adjust SSA_NAME_DEF_STMT.
2263 * tree-phinodes.c (make_phi_node): Allow a NULL var.
2264 * tree-into-ssa.c (insert_phi_nodes_for): Simplify.
2265 * tree-complex.c (update_phi_components): Likewise.
2266 * tree-ssa-loop-manip.c (create_iv): Likewise.
2267 (add_exit_phis_edge): Likewise.
2268 (split_loop_exit_edge): Likewise.
2269 (tree_transform_and_unroll_loop): Likewise.
2270 * value-prof.c (gimple_ic): Likewise.
2271 (gimple_stringop_fixed_value): Likewise.
2272 * tree-tailcall.c (tree_optimize_tail_calls_1): Likewise.
2273 * omp-low.c (expand_parallel_call): Likewise.
2274 (expand_omp_for_static_chunk): Likewise.
2275 (expand_omp_atomic_pipeline): Likewise.
2276 * tree-parloops.c (create_phi_for_local_result): Likewise.
2277 (transform_to_exit_first_loop): Likewise.
2278 * tree-vect-data-refs.c (vect_setup_realignment): Likewise.
2279 * graphite-scop-detection.c (canonicalize_loop_closed_ssa): Likewise.
2280 * tree-predcom.c (initialize_root_vars): Likewise.
2281 (initialize_root_vars_lm): Likewise.
2282 * sese.c (sese_add_exit_phis_edge): Likewise.
2283 * gimple-streamer-in.c (input_phi): Likewise.
2284 * tree-inline.c (copy_phis_for_bb): Likewise.
2285 * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
2286 * tree-cfg.c (gimple_make_forwarder_block): Likewise.
2287 (gimple_duplicate_bb): Likewise.
2288
2289 2012-08-07 Nick Clifton <nickc@redhat.com>
2290
2291 * config/mn10300/mn10300.c (mn10300_expand_prologue): Report
2292 stack usage if requested.
2293
2294 2012-08-06 Cary Coutant <ccoutant@google.com>
2295
2296 * cgraphunit.c (assemble_thunk): Add source line info.
2297 * final.c (final): Check for non-null cfg pointer.
2298
2299 2012-08-06 Sandra Loosemore <sandra@codesourcery.com>
2300 Maxim Kuvyrkov <maxim@codesourcery.com>
2301 Julian Brown <julian@codesourcery.com>
2302
2303 * config/mips/24k.md (r24k_unknown_store): Delete special handling
2304 for cprestore.
2305 (r24k_int_load, r24k_int_arith, r24k_int_mul3, r24k_int_mfhilo)
2306 (r24k_int_cop, r24k_int_multi)
2307 (r24kf2_1_fcvt_f2i, r24kf2_1_fxfer)
2308 (r24kf1_1_fcvt_f2i, r24kf1_1_fxfer): Use mips_store_data_bypass_p
2309 instead of store_data_bypass_p.
2310 * config/mips/74k.md (r74k_int_store): Delete special handling for
2311 cprestore.
2312 (r74k_int_load, r74k_int_logical, r74k_int_arith, r74k_int_cmove):
2313 Use mips_store_data_bypass_p instead of store_data_bypass_p.
2314
2315 2012-08-06 Marc Glisse <marc.glisse@inria.fr>
2316
2317 PR tree-optimization/51938
2318 PR tree-optimization/52005
2319 * tree-ssa-ifcombine.c (ifcombine_ifandif): New parameters for
2320 inverted conditions.
2321 (ifcombine_iforif): Remove, merge code into ifcombine_ifandif.
2322 (tree_ssa_ifcombine_bb): Update calls to the above. Detect !a&&b
2323 and !a||b patterns.
2324
2325 2012-08-06 Olivier Hainque <hainque@adacore.com>
2326
2327 * tree-emutls.c (new_emutls_decl): When a var_section is requested by
2328 the target, attach the new decl to that, not to the template section.
2329
2330 2012-08-06 Tom de Vries <tom@codesourcery.com>
2331
2332 * tree-switch-conversion.c (emit_case_bit_tests): Generate MINUS_EXPR in
2333 unsigned type.
2334
2335 2012-08-05 Venkataramanan Kumar <venkataramanan.kumar@amd.com>
2336
2337 * doc/invoke.texi: Document AMD btver2.
2338 * doc/extend.texi: Document AMD btver1 and btver2.
2339
2340 2012-08-04 Sandra Loosemore <sandra@codesourcery.com>
2341 Richard Sandiford <rdsandiford@googlemail.com>
2342
2343 * config/mips/mips.c (mips_option_override): Check -fpic
2344 for compatibility with -mabicalls and ABI.
2345
2346 2012-08-04 Catherine Moore <clm@codesourcery.com>
2347 Sandra Loosemore <sandra@codesourcery.com>
2348
2349 * config/mips/xlr.md (ir_xlr_alu_clz): New insn_reservation.
2350 (ir_xlr_alu): Remove clz.
2351 * config/mips/mips-cpus.def (xlr): Set PTF_AVOID_BRANCHLIKELY.
2352
2353 2012-08-04 Richard Earnshaw <rearnsha@arm.com>
2354
2355 * arm.c (arm_gen_constant): Use SImode when preparing operands for
2356 gen_extzv_t2.
2357
2358 2012-08-04 Uros Bizjak <ubizjak@gmail.com>
2359
2360 * config/i386/i386.h (QI_REGNO_P): New define.
2361 (ANY_QI_REGNO_P): Ditto.
2362 (GENERAL_REGNO_P): Use IN_RANGE macro.
2363 (QI_REG_P): Use QI_REGNO_P.
2364 (ANY_QI_REG_P): Use GENERAL_REGNO_P and QI_REGNO_P.
2365 (HARD_REGNO_CALLER_SAVE_MODE): Use QI_REGNO_P.
2366 * config/i386/i386.c (ix86_hard_regno_mode_ok): Ditto.
2367 (x86_extended_QIreg_mentioned_p): Ditto. Also check if
2368 register is a general register.
2369
2370 2012-08-03 Uros Bizjak <ubizjak@gmail.com>
2371
2372 * config/i386/sync.md (*atomic_fetch_add_cmp<mode>): Use
2373 incdec_operand predicate to return INC or DEC insn mnemonic.
2374 Add %K operand modifier.
2375 (atomic_add<mode>): Use incdec_operand predicate to
2376 return INC or DEC insn mnemonic.
2377 (atomic_dec<mode>): Ditto.
2378
2379 2012-08-03 Michael Matz <matz@suse.de>
2380
2381 PR tree-optimization/54146
2382 * cfgexpand.c (add_scope_conflicts_1): Use bitmap_ior_into.
2383 (add_scope_conflicts): Iterate in RPO order.
2384 (add_stack_protection_conflicts): Iterate over the other triangle.
2385 (fini_vars_expansion): Clear stack_vars_sorted.
2386
2387 2012-08-03 Marc Glisse <marc.glisse@inria.fr>
2388
2389 PR tree-optimization/30318
2390 * double-int.c (mul_double_wide_with_sign): New function.
2391 (mul_double_with_sign): Call the new function.
2392 * double-int.h (mul_double_wide_with_sign): Declare the new function.
2393 * tree-vrp.c (extract_range_from_binary_expr_1) [MULT_EXPR]:
2394 Handle integer types that wrap on overflow.
2395 (quad_int_cmp): New helper function.
2396 (quad_int_pair_sort): Likewise.
2397
2398 2012-08-03 Richard Guenther <rguenther@suse.de>
2399
2400 * tree-vect-loop-manip.c (vect_can_advance_ivs_p): Query
2401 is_gimple_reg on the SSA name, not its variable.
2402 (vect_update_ivs_after_vectorizer): Likewise.
2403 * tree-ssa-copyrename.c (rename_ssa_copies): Likewise.
2404 * tree-if-conv.c (if_convertible_phi_p): Likewise.
2405 (predicate_scalar_phi): Likewise.
2406 * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Likewise.
2407 (vect_analyze_scalar_cycles_1): Likewise.
2408 * tree-ssa-live.c (register_ssa_partition_check): Likewise.
2409 * tree-outof-ssa.c (eliminate_useless_phis): Likewise.
2410 * tree-ssa-reassoc.c (phi_rank): Likewise.
2411 * tree-parloops.c (separate_decls_in_region_name): Use
2412 replace_ssa_name_symbol.
2413 * tree-predcom.c (base_names_in_chain_on): Likewise.
2414 * matrix-reorg.c (update_type_size): Query the type of the SSA name,
2415 not its variable.
2416 * gimple-ssa-strength-reduction.c (create_mul_ssa_cand): Likewise.
2417 (create_mul_imm_cand): Likewise.
2418 (create_add_ssa_cand): Likewise.
2419 (create_add_imm_cand): Likewise.
2420 (slsr_process_add): Likewise.
2421 * tree-inline.c (remap_ssa_name): Do not set the type of the
2422 new SSA_NAME.
2423 * tree-ssa-structalias.c (get_constraint_for_ssa_var): Clarify assert.
2424 Check for default def first.
2425
2426 2012-08-04 Steven Bosscher <steven@gcc.gnu.org>
2427
2428 * cfgrtl.c (print_rtl_with_bb): Do not print a newline between insns.
2429
2430 * sched-vis.c (print_pattern): Handle SEQUENCE also.
2431
2432 2012-08-02 Richard Henderson <rth@redhat.com>
2433
2434 Revert:
2435 PR 34548
2436 * function.h (struct rtl_data): Add max_dynamic_stack_alignment.
2437 * cfgexpand.c (gimple_expand_cfg): Initialise it.
2438 * explow.c (allocate_dynamic_stack_space): Set it. Simplify
2439 alignment requirements given the known alignment of dynamic_offset.
2440 * function.c (instantiate_virtual_regs): Align dtnamic_offset.
2441
2442 2012-08-02 Kenneth Zadeck <zadeck@naturalbridge.com>
2443
2444 * cfgexpand.c (expand_debug_locations): Encapsulate test for
2445 CONST_DOUBLE in macro.
2446 * combine.c (try_combine, gen_lowpart_for_combine): Ditto.
2447 * cprop.c (implicit_set_cond_p): Ditto.
2448 * cselib.c (rtx_equal_for_cselib_1): Ditto.
2449 * expmed.c (expand_mult): Ditto.
2450 * expr.c (convert_modes): Ditto.
2451 * ira-costs.c (record_reg_classes): Ditto.
2452 * ira-lives.c (single_reg_class): Ditto.
2453 * optabs.c (expand_copysign_absneg, expand_copysign): Ditto.
2454 * print-rtl.c (print_rtx): Ditto.
2455 * recog.c (simplify_while_replacing, const_double_operand)
2456 (asm_operand_ok, constrain_operands): Ditto.
2457 * reg-stack.c (subst_stack_regs_pat): Ditto.
2458 * reload.c (find_reloads, find_equiv_reg): Ditto.
2459 * rtlanal.c (replace_rtx): Remove test.
2460 * rtlanal.c (constant_pool_constant_p, split_double): Encapsulate
2461 test for CONST_DOUBLE in macro.
2462 * simplify-rtx.c (mode_signbit_p, avoid_constant_pool_reference)
2463 (simplify_unary_operation_1, simplify_const_unary_operation)
2464 (simplify_binary_operation_1, simplify_const_binary_operation)
2465 (simplify_relational_operation_1)
2466 (simplify_const_relational_operations)
2467 (implify_subreg): Ditto.
2468 * varasm.c (output_constant_pool_2): Ditto.
2469 * rtl.h (CONST_DOUBLE_AS_INT_P, CONST_DOUBLE_AS_FLOAT_P): New macros.
2470 * rtl.def (CONST_DOUBLE): Updated comments.
2471
2472 2012-08-02 Richard Sandiford <rdsandiford@googlemail.com>
2473
2474 PR target/51931
2475 * config/mips/mips-protos.h (mips_strip_unspec_address): Declare.
2476 * config/mips/mips.c (mips_strip_unspec_address): Make extern.
2477 (mips16_rewrite_pool_constant): Make a copy of the pool constant
2478 before adding to a PC-relative table.
2479 (mips16_lay_out_constants): Add a SPLIT_P parameter.
2480 (mips16_load_branch_target, mips16_split_long_branches): New functions.
2481 (mips_reorg): Update call to mips16_lay_out_constants.
2482 Call mips16_split_long_branches.
2483 * config/mips/predicates.md (pc_or_label_operand): Delete.
2484 * config/mips/mips.md (length): Add a calculation for MIPS16 branches.
2485 Move the extended_mips16 handling further down.
2486 (*branch_equality<mode>_mips16): Replace use pc_or_label_operand
2487 with explicit label_ref and pc. Follow the usual operand numbering.
2488 (*branch_equality<mode>_mips16_inverted): New pattern.
2489 (*jump_mips16): Add length attribute.
2490 (indirect_jump_and_restore_<mode>): New pattern.
2491 (consttable_int): Call mips_strip_unspec_address on the operand.
2492
2493 2012-08-02 Richard Sandiford <rdsandiford@googlemail.com>
2494
2495 * recog.c (split_insn): Copy the original SET_SRC before using
2496 it as a note.
2497
2498 2012-08-02 Richard Sandiford <rdsandiford@googlemail.com>
2499
2500 * reorg.c (dbr_schedule): Delete REG_BR_PRED loop.
2501
2502 2012-08-02 Marc Glisse <marc.glisse@inria.fr>
2503
2504 PR tree-optimization/53805
2505 * fold-const.c (invert_tree_comparison): Invert ORDERED_EXPR and
2506 UNORDERED_EXPR even for trapping floating point.
2507
2508 2012-08-02 H.J. Lu <hongjiu.lu@intel.com>
2509
2510 PR middle-end/53321
2511 PR middle-end/53865
2512 * ipa-inline-analysis.c (inline_free_summary): Return if
2513 inline_edge_summary_vec is NULL.
2514
2515 * ipa-split.c (execute_split_functions): Check if a function
2516 is inlinable only if inline_edge_summary_vec != NULL.
2517
2518 * ipa.c (symtab_remove_unreachable_nodes): Restore
2519 cgraph_propagate_frequency call when something was changed.
2520 (free_inline_summary): New function.
2521 (pass_ipa_free_inline_summary): New pass.
2522
2523 * passes.c (init_optimization_passes): Add
2524 pass_ipa_free_inline_summary before pass_ipa_tree_profile.
2525
2526 * timevar.def (TV_IPA_FREE_INLINE_SUMMARY): New.
2527
2528 * tree-pass.h (pass_ipa_free_inline_summary): New.
2529
2530 2012-08-02 Richard Earnshaw <rearnsha@arm.com>
2531
2532 * arm.c (arm_gen_constant): Use UBFX for some AND operations when
2533 available.
2534
2535 2012-08-02 Richard Guenther <rguenther@suse.de>
2536
2537 * tree-into-ssa.c (struct common_info_d): New struct.
2538 (struct var_info_d, struct ssa_name_info): Use it.
2539 (get_ssa_name_ann): Adjust.
2540 (get_phi_state, set_phi_state): Remove.
2541 (get_common_info): New function.
2542 (get_current_def, set_current_def): Adjust.
2543 (get_def_blocks_for): Take a common info as param.
2544 (set_def_block): Call get_common_info once.
2545 (set_livein_block): Likewise.
2546 (find_def_blocks_for): Adjust.
2547 (insert_phi_nodes): Likewise.
2548 (register_new_def): Call get_common_info once.
2549 (get_reaching_def): Likewise.
2550 (rewrite_debug_stmt_uses): Likewise.
2551 (rewrite_leave_block): Likewise.
2552 (dump_currdefs): Likewise.
2553 (debug_var_infos_r): Adjust.
2554 (register_new_update_single): Call get_common_info once.
2555 (maybe_replace_use_in_debug_stmt): Likewise.
2556 (rewrite_update_leave_block): Likewise.
2557 (mark_use_interesting): Adjust.
2558 (create_new_def_for): Likewise.
2559 (update_ssa): Likewise.
2560
2561 2012-08-02 Michael Matz <matz@suse.de>
2562
2563 * tree-ssa-live.c (set_is_used): Return a bool.
2564 (mark_all_vars_used): Don't take data argument.
2565 (mark_all_vars_used_1): Adjust calls to above, merge handling
2566 of local and global vars.
2567 (remove_unused_scope_block_p): Don't take global_unused_vars,
2568 merge handling of local and global vars.
2569 (remove_unused_locals): Don't allocate/fill/pass global_unused_vars,
2570 use is_used_p for local and global vars.
2571
2572 2012-08-02 Richard Guenther <rguenther@suse.de>
2573
2574 * tree-flow.h (make_rename_temp): Remove.
2575 * tree-dfa.c (make_rename_temp): Likewise.
2576 * cgraphunit.c (thunk_adjust, assemble_thunk): Use create_tmp_reg
2577 instead of make_rename_temp.
2578 * omp-low.c (expand_omp_for_generic, expand_omp_for_static_nochunk,
2579 expand_omp_atomic_pipeline): Likewise.
2580 * trans-mem.c (tm_log_emit_save_or_restores, build_tm_load,
2581 build_tm_store, expand_call_tm, expand_transaction,
2582 ipa_tm_insert_gettmclone_call): Likewise.
2583 * tree-complex.c (expand_complex_div_wide): Likewise.
2584 * tree-mudflap.c (mf_decl_cache_locals, mf_build_check_statement_for):
2585 Likewise.
2586 * tree-ssa-loop-im.c (execute_sm_if_changed_flag_set, execute_sm):
2587 Likewise.
2588 * tree-ssa-math-opts.c (insert_reciprocals): Likewise.
2589 * value-prof.c (gimple_divmod_fixed_value, gimple_mod_pow2,
2590 gimple_mod_subtract): Likewise.
2591
2592 2012-08-02 Richard Guenther <rguenther@suse.de>
2593
2594 * tree-flow.h (set_default_def): Rename to ...
2595 (set_ssa_default_def): ... this. Take a struct function argument.
2596 (gimple_default_def): Rename to ...
2597 (ssa_default_def): ... this.
2598 (get_or_create_ssa_default_def): New function.
2599 * tree-dfa.c: Likewise.
2600 (dump_variable): Adjust.
2601 * ipa-prop.c (ipa_analyze_params_uses): Adjust, properly check
2602 for used parameters.
2603 * ipa-split.c (consider_split): Adjust, avoid repeated default-def
2604 lookups.
2605 (split_function): Likewise.
2606 * lto-streamer-in.c (input_ssa_names): Adjust.
2607 * omp-low.c (expand_omp_taskreg): Likewise.
2608 * tree-cfg.c (replace_ssa_name): Adjust, no need to push/pop cfun.
2609 * tree-complex.c (init_parameter_lattice_values): Adjust.
2610 (get_component_ssa_name): Likewise.
2611 (update_parameter_components): Likewise.
2612 * tree-inline.c (remap_ssa_name): Likewise.
2613 (setup_one_parameter): Likewise.
2614 (initialize_inlined_parameters): Likewise.
2615 (declare_return_variable): Likewise.
2616 (expand_call_inline): Likewise.
2617 (tree_function_versioning): Likewise.
2618 * tree-into-ssa.c (get_default_def_for): Remove.
2619 (get_reaching_def): Use get_or_create_ssa_default_def instead.
2620 * tree-predcom.c (replace_ref_with): Adjust.
2621 * tree-sra.c (get_repl_default_def_ssa_name): Likewise.
2622 (is_unused_scalar_param): Likewise.
2623 (ptr_parm_has_direct_uses): Likewise.
2624 (sra_ipa_reset_debug_stmts): Likewise.
2625 * tree-ssa-coalesce.c (create_outofssa_var_map): Adjust.
2626 * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Likewise.
2627 * tree-ssa-live.c (verify_live_on_entry): Likewise.
2628 * tree-ssa-math-opts.c (execute_cse_reciprocals): Likewise,
2629 avoid repeated default def lookups.
2630 * tree-ssa-sccvn.c (run_scc_vn): Likewise.
2631 * tree-tailcall.c (arg_needs_copy_p): Adjust.
2632 (tree_optimize_tail_calls_1): Likewise.
2633
2634 2012-08-02 Richard Guenther <rguenther@suse.de>
2635
2636 PR tree-optimization/50672
2637 Revert
2638 2012-08-01 Richard Guenther <rguenther@suse.de>
2639
2640 * tree-ssa-tail-merge.c (release_last_vdef): Remove.
2641 (replace_block_by): Adjust.
2642
2643 2012-08-02 Richard Guenther <rguenther@suse.de>
2644
2645 * tree-dfa.c (referenced_var_lookup): Remove.
2646 (find_referenced_vars): Remove.
2647 (pass_referenced_vars): Likewise.
2648 (make_rename_temp): Do not add referenced vars.
2649 (dump_referenced_vars): Remove.
2650 (debug_referenced_vars): Likewise.
2651 (dump_dfa_stats): Do not dump referenced var stats.
2652 (find_vars_r): Remove.
2653 (find_referenced_vars_in): Likewise.
2654 (referenced_var_check_and_insert): Likewise.
2655 (add_referenced_var_1): Likewise.
2656 (remove_referenced_var): Likewise.
2657 * tree-flow.h (referenced_var_lookup): Likewise.
2658 (struct gimple_df): Remove referenced_vars member.
2659 (typedef referenced_var_iterator): Remove.
2660 (FOR_EACH_REFERENCED_VAR): Likewise.
2661 (num_referenced_vars): Likewise.
2662 (debug_referenced_vars, dump_referenced_vars): Likewise.
2663 (add_referenced_var_1, add_referenced_var): Likewise.
2664 (remove_referenced_var): Likewise.
2665 (find_referenced_vars_in): Likewise.
2666 * tree-flow-inline.h (gimple_referenced_vars): Remove.
2667 (first_referenced_var): Likewise.
2668 (end_referenced_vars_p): Likewise.
2669 (next_referenced_var): Likewise.
2670 * cfgexpand.c (update_alias_info_with_stack_vars): Remove assert.
2671 * gimple-pretty-print.c (pp_points_to_solution): Dump UIDs
2672 unconditionally.
2673 * tree-into-ssa.c (dump_decl_set): Likewise.
2674 (pass_build_ssa): Do not require PROP_referenced_vars.
2675 * tree-ssa.c (target_for_debug_bind): Virtual operands are
2676 not suitable, but all register type vars are.
2677 (init_tree_ssa): Do not allocate referenced vars.
2678 (delete_tree_ssa): Do not free referenced vars.
2679 * cgraphunit.c (init_lowered_empty_function): Do not set
2680 PROP_referenced_vars.
2681 (assemble_thunk): Do not add referenced vars.
2682 * gimple-fold.c (canonicalize_constructor_val): Likewise.
2683 (gimplify_and_update_call_from_tree): Likewise.
2684 * gimple-streamer-in.c (input_bb): Likewise.
2685 * passes.c (init_optimization_passes): Do not run
2686 pass_referenced_vars.
2687 (dump_properties): Do not dump PROP_referenced_vars.
2688 * tree-inline.c (remap_decl): Do not add referenced vars.
2689 (remap_gimple_op_r): Likewise.
2690 (copy_tree_body_r): Likewise.
2691 (copy_bb): Likewise.
2692 (setup_one_parameter): Likewise.
2693 (declare_return_variable): Likewise.
2694 (copy_decl_for_dup_finish): Likewise.
2695 (copy_arguments_for_versioning): Likewise.
2696 (tree_function_versioning): Likewise.
2697 * tree-pass.h (PROP_referenced_vars): Remove.
2698 (pass_referenced_vars): Likewise.
2699 * tree-profile.c (gimple_gen_edge_profiler): Do not add
2700 referenced vars.
2701 (gimple_gen_interval_profiler): Likewise.
2702 (gimple_gen_pow2_profiler): Likewise.
2703 (gimple_gen_one_value_profiler): Likewise.
2704 (gimple_gen_ic_profiler): Likewise.
2705 (gimple_gen_average_profiler): Likewise.
2706 (gimple_gen_ior_profiler): Likewise.
2707 * tree-ssa-live.c (remove_unused_locals): Do not touch referenced vars.
2708 * tree-cfg.c (replace_ssa_name): Do not add referenced vars.
2709 (move_stmt_op): Likewise.
2710 * tree-ssa-operands.c (create_vop_var): Likewise.
2711 * gimple-low.c (record_vars_into): Likewise.
2712 * gimplify.c (gimple_regimplify_operands): Likewise.
2713 (force_gimple_operand_1): Likewise.
2714 * omp-low.c (expand_omp_for_generic): Likewise.
2715 (expand_omp_for_static_chunk): Likewise.
2716 (expand_omp_atomic_pipeline): Likewise.
2717 * graphite-clast-to-gimple.c (graphite_create_new_loop): Likewise.
2718 (translate_clast_assignment): Likewise.
2719 * graphite-sese-to-poly.c (create_zero_dim_array): Likewise.
2720 (handle_scalar_deps_crossing_scop_limits): Likewise.
2721 * ipa-prop.c (ipa_modify_formal_parameters): Likewise.
2722 * ipa-split.c (split_function): Likewise.
2723 * matrix-reorg.c (transform_access_sites): Likewise.
2724 * trans-mem.c (tm_log_add): Likewise.
2725 (ipa_tm_insert_gettmclone_call): Likewise.
2726 * tree-complex.c (create_one_component_var): Likewise.
2727 * tree-if-conv.c (ifc_temp_var): Likewise.
2728 * tree-parloops.c (take_address_of): Likewise.
2729 (initialize_reductions): Likewise.
2730 (separate_decls_in_region_name): Likewise.
2731 (create_call_for_reduction_1): Likewise.
2732 (separate_decls_in_region): Likewise.
2733 * tree-predcom.c (predcom_tmp_var): Likewise.
2734 (reassociate_to_the_same_stmt): Likewise.
2735 * tree-sra.c (build_ref_for_offset): Likewise.
2736 (create_access_replacement): Likewise.
2737 (get_replaced_param_substitute): Likewise.
2738 (sra_ipa_reset_debug_stmts): Likewise.
2739 * tree-ssa-loop-im.c (rewrite_reciprocal): Likewise.
2740 (rewrite_bittest): Likewise.
2741 * tree-ssa-loop-ivopts.c (create_new_iv): Likewise.
2742 * tree-ssa-loop-manip.c (create_iv): Likewise.
2743 (tree_transform_and_unroll_loop): Likewise.
2744 * tree-ssa-math-opts.c (powi_as_mults): Likewise.
2745 (build_and_insert_call): Likewise.
2746 (gimple_expand_builtin_cabs): Likewise.
2747 (execute_optimize_bswap): Likewise.
2748 * tree-ssa-phiopt.c (conditional_replacement): Likewise.
2749 (abs_replacement): Likewise.
2750 (cond_store_replacement): Likewise.
2751 (cond_if_else_store_replacement_1): Likewise.
2752 * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
2753 * tree-ssa-pre.c (get_representative_for): Likewise.
2754 (create_expression_by_pieces): Likewise.
2755 (insert_into_preds_of_block): Likewise.
2756 * tree-ssa-propagate.c (update_call_from_tree): Likewise.
2757 * tree-ssa-reassoc.c (undistribute_ops_list): Likewise.
2758 (eliminate_redundant_comparison): Likewise.
2759 (rewrite_expr_tree_parallel): Likewise.
2760 (get_reassoc_pow_ssa_name): Likewise.
2761 * tree-ssa-strlen.c (get_string_length): Likewise.
2762 * tree-switch-conversion.c (emit_case_bit_tests): Likewise.
2763 (build_arrays): Likewise.
2764 * tree-tailcall.c (adjust_return_value_with_ops): Likewise.
2765 (create_tailcall_accumulator): Likewise.
2766 * tree-vect-data-refs.c (vect_get_new_vect_var): Likewise.
2767 (vect_create_addr_base_for_vector_ref): Likewise.
2768 (vect_permute_store_chain): Likewise.
2769 (vect_permute_load_chain): Likewise.
2770 * tree-vect-generic.c (expand_vector_divmod): Likewise.
2771 * tree-vect-loop-manip.c (set_prologue_iterations): Likewise.
2772 (vect_build_loop_niters): Likewise.
2773 (vect_generate_tmps_on_preheader): Likewise.
2774 (vect_update_ivs_after_vectorizer): Likewise.
2775 (vect_gen_niters_for_prolog_loop): Likewise.
2776 (vect_do_peeling_for_alignment): Likewise.
2777 (vect_create_cond_for_align_checks): Likewise.
2778 * tree-vect-patterns.c (vect_recog_temp_ssa_var): Likewise.
2779 (vect_handle_widen_op_by_const): Likewise.
2780 (vect_operation_fits_smaller_type): Likewise.
2781 (vect_recog_over_widening_pattern): Likewise.
2782 * tree-vect-stmts.c (vect_init_vector): Likewise.
2783
2784 2012-08-01 Alexandre Oliva <aoliva@redhat.com>
2785
2786 PR debug/52983
2787 * valtrack.c (dead_debug_insert_temp): Use cleanup_auto_inc_dec.
2788
2789 2012-08-01 Alexandre Oliva <aoliva@redhat.com>
2790
2791 PR debug/52983
2792 * valtrack.c (cleanup_auto_inc_dec): Implement unconditionally,
2793 falling back to copy_rtx on non-autoinc machines.
2794 (propagate_for_debug_subst): Always use cleanup_auto_inc_dec.
2795
2796 2012-08-01 Alexandre Oliva <aoliva@redhat.com>
2797
2798 PR debug/52983
2799 * valtrack.h, valtrack.c: New.
2800 * Makefile.in (VALTRACK_H): New.
2801 (OBJS): Add valtrack.o.
2802 (valtrack.o): New.
2803 (cselib.o, dce.o, df-problems.o, combine.o): Add VALTRACK_H.
2804 * combine.c: Include valtrack.h.
2805 (make_compound_operation): Publish.
2806 (cleanup_auto_inc_dec): Move to valtrack.c.
2807 (struct rtx_subst_pair, propagate_for_debug_subst): Likewise.
2808 (propagate_for_debug): Likewise. Add this_basic_block parameter.
2809 Adjust all callers.
2810 * cselib.c: Include valtrack.h.
2811 * dce.c: Likewise.
2812 * df-problems.c: Likewise.
2813 (dead_debug_init, dead_debug_reset_uses): Move to valtrack.c.
2814 (dead_debug_finish, dead_debug_add): Likewise.
2815 (dead_debug_insert_temp): Likewise.
2816 * df.h (struct dead_debug_use): Move to valtrack.h.
2817 (struct dead_debug, enum debug_temp_where): Likewise.
2818 (dead_debug_init, dead_debug_reset_uses): Move to valtrack.h.
2819 (dead_debug_finish, dead_debug_add): Likewise.
2820 (dead_debug_insert_temp): Likewise.
2821 * rtl.h (make_compound_operation): Declare.
2822
2823 2012-08-01 Catherine Moore <clm@codesourcery.com>
2824 Sandra Loosemore <sandra@codesourcery.com>
2825
2826 * config/mips/mips-cpus.def (34kn): New.
2827 * config/mips/mips.h (MIPS_ARCH_FLOAT_SPEC): Add 34kn.
2828 (BASE_DRIVER_SELF_SPECS): Do not imply -mdsp for the 34kn.
2829 * config/mips/mips-tables.opt: Regenerate.
2830 * doc/invoke.texi (MIPS Options): Document -march=34kn.
2831
2832 2012-08-01 Richard Henderson <rth@redhat.com>
2833
2834 * expmed.h (NUM_MODE_PARTIAL_INT): New.
2835 (NUM_MODE_VECTOR_INT, NUM_MODE_IP_INT, NUM_MODE_IPV_INT): New.
2836 (struct expmed_op_cheap): Size one array on NUM_MODE_IPV_INT.
2837 (struct expmed_op_costs): Likewise.
2838 (struct target_expmed): Size x_convert_cost on NUM_MODE_IP_INT.
2839 (expmed_mode_index): New.
2840 (expmed_op_cheap_ptr, expmed_op_cost_ptr): Use expmed_mode_index.
2841 (convert_cost_ptr): Likewise.
2842 * expmed.c (struct init_expmed_rtl): Rename convert to trunc.
2843 (init_expmed_one_conv): Split out from ...
2844 (init_expmed_one_mode): ... here. Iterate conversions over
2845 partial integer modes too.
2846 (init_expmed): Iterate over partial integer modes too.
2847
2848 2012-08-01 Richard Henderson <rth@redhat.com>
2849
2850 * config/m32c/m32c.c (TARGET_INIT_LIBFUNCS): Remove.
2851 (m32c_init_libfuncs): Remove.
2852 * config/m32c/cond.md (cstore<QHPSI>4_16): Rename from cstore<QHPSI>4.
2853 (cstore<QHPSI>4): New expander.
2854
2855 2012-08-01 Richard Guenther <rguenther@suse.de>
2856
2857 * tree-flow-inline.h (referenced_var): Remove.
2858 * tree-ssa-coalesce.c (create_outofssa_var_map): Remove duplicate
2859 checking code.
2860 * tree-sra.c (candidates): New global hashtable.
2861 (candidate): New function.
2862 (sra_initialize): Initialize candidates.
2863 (sra_deinitialize): Free candidates.
2864 (disqualify_candidate): Remove candidate from candidates.
2865 (maybe_add_sra_candidate): New function.
2866 (find_var_candidates): Walk over all local decls and parameters,
2867 add candidates to candidates hashtable.
2868 (find_param_candidates): Add candidates to candidates hashtable.
2869 (analyze_all_variable_accesses): Use candidate instead of
2870 referenced_var.
2871
2872 2012-08-01 Tom de Vries <tom@codesourcery.com>
2873
2874 * tree-vrp.c (find_case_label_ranges): New function.
2875 (vrp_visit_switch_stmt, simplify_switch_using_ranges): Use
2876 find_case_label_ranges instead of find_case_label_range. Handle second
2877 range.
2878
2879 2012-08-01 Michael Matz <matz@suse.de>
2880
2881 * tree-complex.c (init_parameter_lattice_values): Don't call var_ann.
2882 * tree-dfa.c (struct dfa_stats_d): Remove num_var_anns member.
2883 (dump_dfa_stats): Don't dump stats about var anns.
2884 (collect_dfa_stats): Don't collect them.
2885 (add_referenced_var_1): Don't set var annotation pointers.
2886 (remove_referenced_var): Ditto, and only remove it it's in the
2887 hash table.
2888
2889 * tree-flow-inline.h (var_ann): Remove.
2890 * tree-flow.h (struct var_ann_d, var_ann_t): Remove.
2891
2892 * tree-inline.c (remapped_type): Remove.
2893 (can_be_nonlocal): Most variable will be considered live here,
2894 return false earlier.
2895 (remap_decls): Don't call var_ann, all variables will be considered
2896 referenced here.
2897 (copy_debug_stmt): Ditto, and use is_global_var.
2898
2899 * tree-into-ssa.c (rewrite_debug_stmt_uses): Use get_current_def to
2900 determine if a variable was referred to, not var_ann.
2901 * tree-ssa-live.c (remove_unused_scope_block_p): Don't check var_ann.
2902 (remove_unused_locals): Ditto.
2903 * tree-ssa.c (delete_tree_ssa): Don't free/clear var ann pointers.
2904 * tree-tailcall.c (arg_needs_copy_p): Don't check var_ann.
2905 * tree.c (copy_node_stat): Don't clear var ann pointer.
2906 * tree.h (tree_result_decl, tree_parm_decl, tree_var_decl): Remove
2907 ann member.
2908 (DECL_VAR_ANN_PTR): Remove.
2909
2910 2012-08-01 Michael Matz <matz@suse.de>
2911
2912 * tree-flow.h (struct var_ann_d): Rename used member.
2913 (set_is_used): Don't declare.
2914 * tree-flow-inline.h (clear_is_used): Remove.
2915 (set_is_used, is_used_p): Move to ...
2916 * tree-ssa-live.c (set_is_used, is_used_p): ... here, and use
2917 on the side bitmap.
2918 (usedvars): New bitmap.
2919 (dump_scope_block): Don't dump unusedness.
2920 (remove_unused_locals): Allocate and free usedvars.
2921 * tree-nrv.c (tree_nrv): Don't clear used flags here.
2922
2923 2012-08-01 Michael Matz <matz@suse.de>
2924
2925 * tree-flow.h (struct var_ann_d): Remove base_var_processed and
2926 base_index members.
2927 * tree-ssa-live.h (struct _var_map): Remove basevars member.
2928 (VAR_ANN_BASE_INDEX): Remove.
2929 * tree-ssa-live.c (var_map_base_init): Use a hash table instead
2930 of var annotation to compress index space. Don't deal with above
2931 removed members.
2932 (var_map_base_fini): Don't free basevars.
2933 (init_var_map): Don't clear basevars.
2934
2935 2012-08-01 Bill Schmidt <wschmidt@linux.ibm.com>
2936
2937 * gimple-ssa-strength-reduction.c (struct slsr_cand_d): Change
2938 base_name to base_expr.
2939 (struct cand_chain_d): Likewise.
2940 (base_cand_hash): Likewise.
2941 (base_cand_eq): Likewise.
2942 (record_potential_basis): Likewise.
2943 (alloc_cand_and_find_basis): Likewise.
2944 (create_mul_ssa_cand): Likewise.
2945 (create_mul_imm_cand): Likewise.
2946 (create_add_ssa_cand): Likewise.
2947 (create_add_imm_cand): Likewise.
2948 (slsr_process_cast): Likewise.
2949 (slsr_process_copy): Likewise.
2950 (dump_candidate): Likewise.
2951 (base_cand_dump_callback): Likewise.
2952 (unconditional_cands_with_known_stride_p): Likewise.
2953 (cand_increment): Likewise.
2954
2955 2012-08-01 Bill Schmidt <wschmidt@linux.ibm.com>
2956
2957 PR tree-optimization/46556
2958 * gimple-ssa-strength-reduction.c (enum cand_kind): Add CAND_REF.
2959 (base_cand_map): Change to hash table.
2960 (base_cand_hash): New function.
2961 (base_cand_free): Likewise.
2962 (base_cand_eq): Likewise.
2963 (lookup_cand): Change base_cand_map to hash table.
2964 (find_basis_for_candidate): Likewise.
2965 (base_cand_from_table): Exclude CAND_REF.
2966 (restructure_reference): New function.
2967 (slsr_process_ref): Likewise.
2968 (find_candidates_in_block): Call slsr_process_ref.
2969 (dump_candidate): Handle CAND_REF.
2970 (base_cand_dump_callback): New function.
2971 (dump_cand_chains): Change base_cand_map to hash table.
2972 (replace_ref): New function.
2973 (replace_refs): Likewise.
2974 (analyze_candidates_and_replace): Call replace_refs.
2975 (execute_strength_reduction): Change base_cand_map to hash table.
2976
2977 2012-08-01 Uros Bizjak <ubizjak@gmail.com>
2978
2979 * config/i386/i386.c (ix86_address_subreg_operand): Reject
2980 stack pointer.
2981 (ix86_print_operand_address): Assert that parts.base and parts.index
2982 are non-NULL after call to simplify_subreg.
2983
2984 2012-08-01 Richard Guenther <rguenther@suse.de>
2985
2986 * doc/tree-ssa.texi: Remove pieces mentioning mark_sym_for_renaming.
2987
2988 2012-08-01 Richard Guenther <rguenther@suse.de>
2989
2990 * graphite-clast-to-gimple.c (translate_clast_user): Rename
2991 virtual operands.
2992 * sese.c (graphite_copy_stmts_from_block): Do not rename virtual
2993 operands here.
2994 * tree-call-cdce.c (tree_call_cdce): Use
2995 mark_virtual_operands_for_renaming.
2996 * tree-eh.c (sink_clobbers): Simplify.
2997 * tree-flow.h (mark_sym_for_renaming): Remove.
2998 (mark_virtual_operands_for_renaming): New function.
2999 * tree-if-conv.c (tree_if_conversion): Use
3000 mark_virtual_operands_for_renaming.
3001 * tree-inline.c (update_ssa_across_abnormal_edges): Likewise.
3002 * tree-into-ssa.c (mark_sym_for_renaming): Remove.
3003 (mark_virtual_operands_for_renaming): New function.
3004 * tree-loop-distribution.c (tree_loop_distribution): Use
3005 mark_virtual_operands_for_renaming.
3006 * tree-ssa-dce.c (mark_virtual_operand_for_renaming): Do not
3007 update stmts, use mark_virtual_operands_for_renaming.
3008 * tree-ssa-tail-merge.c (release_last_vdef): Remove.
3009 (replace_block_by): Adjust.
3010 (tail_merge_optimize): Use mark_virtual_operands_for_renaming.
3011 * tree-tailcall.c (tree_optimize_tail_calls_1): Use
3012 mark_virtual_operands_for_renaming.
3013 * tree-vect-slp.c (vect_slp_transform_bb): Likewise.
3014 * tree-vectorizer.c (vectorize_loops): Likewise.
3015
3016 2012-08-01 Richard Guenther <rguenther@suse.de>
3017
3018 * tree-flow.h (struct gimple_df): Remove syms_to_rename member,
3019 add ssa_renaming_needed and rename_vops flags.
3020 (SYMS_TO_RENAME): Remove.
3021 (symbol_marked_for_renaming): Likewise.
3022 (mark_virtual_ops_for_renaming): Likewise.
3023 * tree-into-ssa.c (symbols_to_rename_set, symbols_to_rename):
3024 New globals.
3025 (mark_for_renaming, marked_for_renaming): New functions.
3026 (symbol_marked_for_renaming): Remove.
3027 (dump_currdefs): Adjust.
3028 (maybe_replace_use): Likewise.
3029 (maybe_replace_use_in_debug_stmt): Likewise.
3030 (maybe_register_def): Likewise.
3031 (rewrite_update_phi_arguments): Likewise.
3032 (rewrite_update_enter_block): Likewise.
3033 (fini_ssa_renamer): Clear update SSA status here ...
3034 (delete_update_ssa): ... not here. Free rename set.
3035 (prepare_block_for_update): Compute which decls need renaming.
3036 (dump_update_ssa): Adjust.
3037 (mark_sym_for_renaming): Adjust update SSA status for virtuals.
3038 (need_ssa_update_p): Adjust.
3039 (insert_updated_phi_nodes_for): Likewise.
3040 (update_ssa): Likewise.
3041 * tree-ssa-operands.c (finalize_ssa_defs): Adjust update SSA status
3042 for virtual and real operands.
3043 (finalize_ssa_uses): Likewise.
3044 * tree-ssanames.c (init_ssanames): Adjust.
3045 * tree-ssa.c (maybe_rewrite_mem_ref_base, maybe_optimize_var,
3046 execute_update_addresses_taken): Add bitmap to keep track of which
3047 candidates are suitable for rewriting and later renaming by SSA update.
3048 * matrix-reorg.c (transform_access_sites): Do not rename all defs.
3049 * tree-dfa.c (make_rename_temp): Do not mark real operands for
3050 renaming.
3051 * cgraphunit.c (assemble_thunk): Likewise.
3052 * gimplify.c (gimple_regimplify_operands): Likewise.
3053 (force_gimple_operand_1): Likewise.
3054 * ipa-prop.c (ipa_modify_formal_parameters): Likewise.
3055 * tree-inline.c (declare_return_variable): Likewise.
3056 * tree-parloops.c (separate_decls_in_region_stmt): Do not call
3057 mark_virtual_ops_for_renaming.
3058 (create_stores_for_reduction): Likewise.
3059 (create_loads_and_stores_for_name): Likewise.
3060 * tree-predcom.c (mark_virtual_ops_for_renaming): Remove.
3061 (initialize_root_vars_lm): Do not call mark_virtual_ops_for_renaming.
3062 (execute_load_motion): Likewise.
3063 (remove_stmt): Likewise.
3064 (execute_pred_commoning_chain): Likewise.
3065 * tree-sra.c (create_access_replacement): Do not rename real operands.
3066 (get_unrenamed_access_replacement): Unify with ...
3067 (get_access_replacement): ... this.
3068 (get_repl_default_def_ssa_name): Adjust.
3069 * tree-ssa-loop-im.c (move_computations_stmt): Manually update
3070 virtual SSA form.
3071 (rewrite_mem_ref_loc): Do not call mark_virtual_ops_for_renaming.
3072 * tree-ssa-loop-prefetch.c (emit_mfence_after_loop): Likewise.
3073
3074 2012-07-31 DJ Delorie <dj@redhat.com>
3075
3076 * config/s390/s390.c (s390_option_override): Disable DWARF 3/4
3077 extensions for TPF, unless specifically selected.
3078
3079 2012-08-01 Alan Modra <amodra@gmail.com>
3080
3081 PR target/54131
3082 * config/rs6000/rs6000.c (mem_operand_gpr): Don't limit range
3083 of lo_sum offsets. Comment. Assert mode at least word size
3084 rather than bypassing powerpc64 word offset check.
3085
3086 2012-07-31 Bill Schmidt <wschmidt@linux.ibm.com>
3087
3088 * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost): Revise
3089 costs for vec_perm and vec_promote_demote down to more natural values.
3090 (struct _rs6000_cost_data): New data structure.
3091 (rs6000_density_test): New function.
3092 (rs6000_init_cost): Change to use rs6000_cost_data.
3093 (rs6000_add_stmt_cost): Likewise.
3094 (rs6000_finish_cost): Perform density test when vectorizing a loop.
3095
3096 2012-07-31 Steven Bosscher <steven@gcc.gnu.org>
3097
3098 * sched-vis.c (print_exp): Handle FMA explicitly. Simplify handling
3099 of RTX_UNARY function-like operations. Print unknown expression
3100 RTX classes as pseudo-functions.
3101 (print_pattern): Simplify return pattern printing.
3102 (dump_insn_slim): Print the value of notes as a pattern for proper
3103 printing of CFA notes.
3104
3105 2012-07-31 Dehao Chen <dehao@google.com>
3106
3107 * predict.c (tree_estimate_probability_driver): Normalize the
3108 loop when initializing the loop optimizer.
3109
3110 2012-07-31 Richard Guenther <rguenther@suse.de>
3111
3112 * tree-flow.h (struct var_ann_d): Remove need_phi_state
3113 and current_def members.
3114 * tree-into-ssa.c (struct def_blocks_d): Remove var member.
3115 (def_blocks): Remove.
3116 (struct var_info_d): New.
3117 (var_infos): New hashtable.
3118 (struct ssa_name_info): Add def_blocks member.
3119 (get_ssa_name_ann): Adjust.
3120 (get_var_info): New function.
3121 (get_phi_state, set_phi_state, get_current_def,
3122 set_current_def, get_def_blocks_for, find_def_blocks_for): Adjust.
3123 (insert_phi_nodes_compare_def_blocks): Rename to ...
3124 (insert_phi_nodes_compare_var_infos): ... this and adjust.
3125 (insert_phi_nodes): Adjust.
3126 (dump_tree_ssa, dump_tree_ssa_stats): Adjust.
3127 (def_blocks_hash, def_blocks_eq, def_blocks_free): Remove.
3128 (debug_def_blocks_r): Rename to ...
3129 (debug_var_infos_r): ... this and adjust.
3130 (var_info_hash): New function.
3131 (var_info_eq): Likewise.
3132 (rewrite_blocks): Adjust.
3133 (init_ssa_renamer): Likewise.
3134 (fini_ssa_renamer): Likewise.
3135 (delete_update_ssa): Likewise.
3136 (update_ssa): Likewise.
3137 * tree-ssanames.c (release_dead_ssa_names): Do not clear current defs.
3138
3139 2012-07-31 Bill Schmidt <wschmidt@linux.ibm.com>
3140
3141 PR tree-optimization/53773
3142 * tree-vectorizer.h (struct _loop_vec_info): Add operands_swapped.
3143 (LOOP_VINFO_OPERANDS_SWAPPED): New macro.
3144 * tree-vect-loop.c (new_loop_vec_info): Initialize
3145 LOOP_VINFO_OPERANDS_SWAPPED field.
3146 (destroy_loop_vec_info): Restore canonical form.
3147 (vect_is_slp_reduction): Set LOOP_VINFO_OPERANDS_SWAPPED field.
3148 (vect_is_simple_reduction_1): Likewise.
3149
3150 2012-07-31 Steven Bosscher <steven@gcc.gnu.org>
3151
3152 * sched-vis.c (dump_insn_slim): Print print_rtx_head at the
3153 start of each new line.
3154 * final.c (final_scan_insn): If the final dump is requested as
3155 slim RTL, dump slim RTL to the assembly file also.
3156
3157 2012-07-31 Andrey Belevantsev <abel@ispras.ru>
3158
3159 PR target/53975
3160
3161 * sel-sched-ir.c (has_dependence_note_reg_use): Clarify comment.
3162
3163 Revert
3164 2011-08-04 Sergey Grechanik <mouseentity@ispras.ru>
3165
3166 * sel-sched-ir.c (has_dependence_note_reg_use): Call ds_full_merge
3167 only if producer writes to the register given by regno.
3168
3169 2012-07-31 Nick Clifton <nickc@redhat.com>
3170
3171 * config/stormy16/stormy16.c (xstormy16_expand_prologue): Add
3172 support for reporting stack usage.
3173
3174 * config/frv/frv.c (QUAD): Fix typo.
3175 (frv_expand_prologue): Report stack usage.
3176
3177 2012-07-31 Steven Bosscher <steven@gcc.gnu.org>
3178
3179 PR pch/53880
3180 * gengtype.c (struct walk_type_data): Add have_this_obj field.
3181 (walk_type): For functions that take a this_obj argument and
3182 that process fields with a GTY((length)) argument, write the
3183 test that write_types_local_process_field will write also at the
3184 head of the loop, effectively unswitching the loop.
3185 (write_func_for_structure, write_local_func_for_structure): Clear
3186 have_this_obj before calling walk_type.
3187 (write_local_func_for_structure): Set have_this_obj before walk_type.
3188 (write_array): Set have_this_obj for output of local pointer walking
3189 functions but not for marker functions.
3190 (write_types_local_process_field): Assert have_this_obj is set.
3191
3192 * rtl.h (simplify_using_condition): Adjust prototype using bitmap
3193 from coretypes.h.
3194
3195 2012-07-30 Nathan Froyd <froydnj@gcc.gnu.org>
3196
3197
3198 * defaults.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete.
3199 * targhooks.c (default_mode_dependent_address_p): Delete code
3200 for GO_IF_MODE_DEPENDENT_ADDRESS.
3201 * system.h (GO_IF_MODE_DEPENDENT_ADDRESS): Poison.
3202 * doc/tm.texi.in (GO_IF_MODE_DEPENDENT_ADDRESS): Delete documention.
3203 * doc/tm.texi: Regenerate.
3204 * config/alpha.h (GO_IF_MODE_DEPENDENT_ADDRESS): Move code to...
3205 * config/alpha.c (alpha_mode_dependent_address_p): ...here. New
3206 function.
3207 (TARGET_MODE_DEPENDENT_ADDRESS_P): Define.
3208 * config/cr16/cr16.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete.
3209 * config/mep/mep.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete.
3210 * config/vax/vax-protos.h (vax_mode_dependent_address_p): Delete.
3211 * config/vax/vax.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete.
3212 * config/vax/vax.c (vax_mode_dependent_address_p): Make static.
3213 Take a const_rtx.
3214 (TARGET_MODE_DEPENDENT_ADDRESS_P): Define.
3215
3216 2012-07-30 Nathan Froyd <froydnj@gcc.gnu.org>
3217
3218 * expmed.h (NUM_MODE_VECTOR_INT): Define.
3219 (struct expmed_op_cheap, struct expmed_op_costs): New structures.
3220 (struct target_expmed): Convert x_mul_highpart_cost and
3221 x_mul_widen_cost fields to be indexed by integer modes.
3222 Convert x_sdiv_pow2_cheap and x_smod_pow2_cheap fields to be
3223 of type struct expmed_op_cheap. Convert other cost fields to be
3224 of type struct_expmed_op_costs.
3225 (mul_widen_cost_ptr, mul_highpart_cost_ptr): Adjust for new
3226 indexing of respective fields.
3227 (expmed_op_cheap_ptr): New function.
3228 (sdiv_pow2_cheap_ptr, smod_pow2_cheap_ptr): Call it.
3229 (expmed_op_cost_ptr): New function.
3230 (add_cost_ptr, neg_cost_ptr, shift_cost_ptr, shiftadd_cost_ptr,
3231 shiftsub0_cost_ptr, shiftsub1_cost_ptr, mul_cost_ptr,
3232 sdiv_cost_ptr, udiv_cost_ptr): Call it.
3233
3234 2012-07-30 Sandra Loosemore <sandra@codesourcery.com>
3235 Julian Brown <julian@codesourcery.com>
3236
3237 * doc/invoke.texi (MIPS Options): Document -mno-float.
3238 * config/mips/mips.h (MIPS_ARCH_FLOAT_SPEC): Make it know
3239 about -mno-float.
3240
3241 2012-07-30 Joseph Myers <joseph@codesourcery.com>
3242
3243 * doc/sourcebuild.texi (Subdirectories): Document common subdirectory.
3244
3245 2012-07-30 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
3246
3247 PR middle-end/53823
3248 * expmed.c (expand_mult): Skip synth_mult for constant double op1 except
3249 for special cases. Don't initialize coeff and is_neg.
3250
3251 2012-07-30 Ulrich Weigand <ulrich.weigand@linaro.org>
3252 Richard Earnshaw <rearnsha@arm.com>
3253
3254 * target.def (vector_alignment): New target hook.
3255 * doc/tm.texi.in (TARGET_VECTOR_ALIGNMENT): Document new hook.
3256 * doc/tm.texi: Regenerate.
3257 * targhooks.c (default_vector_alignment): New function.
3258 * targhooks.h (default_vector_alignment): Add prototype.
3259 * stor-layout.c (layout_type): Use targetm.vector_alignment.
3260 * config/arm/arm.c (arm_vector_alignment): New function.
3261 (TARGET_VECTOR_ALIGNMENT): Define.
3262
3263 * tree-vect-data-refs.c (vect_update_misalignment_for_peel): Use
3264 vector type alignment instead of size.
3265 * tree-vect-loop-manip.c (vect_do_peeling_for_loop_bound): Use
3266 element type size directly instead of computing it from alignment.
3267 Fix variable naming and comment.
3268
3269 2012-07-30 Kirill Yukhin <kirill.yukhin@intel.com>
3270 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
3271
3272 * common/config/i386/i386-common.c (OPTION_MASK_ISA_RDSEED_SET): New.
3273 (OPTION_MASK_ISA_RDSEED_UNSET): Likewise.
3274 (ix86_handle_option): Handle mrdseed option.
3275 * config.gcc (i[34567]86-*-*): Add rdseedintrin.h.
3276 (x86_64-*-*): Likewise.
3277 * config/i386/prfchwintrin.h: New header.
3278 * config/i386/cpuid.h (bit_RDSEED): New.
3279 * config/i386/driver-i386.c (host_detect_local_cpu): Detect
3280 RDSEED support.
3281 * config/i386/i386-c.c: Define __RDSEED__ if needed.
3282 * config/i386/i386.c (ix86_target_string): Define -mrdseed option.
3283 (PTA_RDSEED): New.
3284 (ix86_option_override_internal): Handle new option.
3285 (ix86_valid_target_attribute_inner_p): Add OPT_mrdseed.
3286 (ix86_builtins): Add enum entries for RDSEED* builtins.
3287 (ix86_init_mmx_sse_builtins): Define new builtins.
3288 (ix86_expand_builtin): Expand RDSEED* builtins.
3289 * config/i386/i386.h (TARGET_RDSEED): New.
3290 * config/i386/i386.md (rdseed<mode>_1): New.
3291 * config/i386/i386.opt (mrdseed): New.
3292 * config/i386/x86intrin.h: Include rdseedintrin.h.
3293
3294 2012-07-30 Richard Guenther <rguenther@suse.de>
3295
3296 * tree-into-ssa.c (mark_def_sites): Also process virtual operands.
3297 (rewrite_stmt): Likewise.
3298 (rewrite_enter_block): Likewise.
3299 (pass_build_ssa): Do not update virtual SSA form during TODO.
3300 (mark_symbol_for_renaming): Do nothing if we are not in SSA form.
3301 * lto-streamer-in.c (lto_read_body): Set in_ssa_p earlier.
3302
3303 2012-07-30 Oleg Endo <olegendo@gcc.gnu.org>
3304
3305 PR target/39423
3306 * config/gcc/sh/sh.md (*movsi_index_disp, *movhi_index_disp): New
3307 insns.
3308
3309 2012-07-30 Oleg Endo <olegendo@gcc.gnu.org>
3310
3311 PR target/51244
3312 * config/sh/sh.md (mov_neg_si_t): Move to Scc instructions section.
3313 Use t_reg_operand predicate. Add split for negated case.
3314 (ashrsi2_31): Pass get_t_reg_rtx to gen_mov_neg_si_t.
3315 * config/sh/sh.c (expand_ashiftrt): Likewise.
3316
3317 2012-07-30 Oleg Endo <olegendo@gcc.gnu.org>
3318
3319 PR target/54089
3320 * config/sh/sh.md (ashlsi3_d): Invoke gen_shifty_op directly instead
3321 of trying to emit ashlsi3_n.
3322
3323 2012-07-30 Laurynas Biveinis <laurynas.biveinis@gmail.com>
3324 Steven Bosscher <steven@gcc.gnu.org>
3325
3326 * gengtype.c (adjust_field_type): Diagnose duplicate "length"
3327 option applications and option being applied to arrays of atomic types.
3328 (walk_type): Allow "atomic" option on strings too.
3329 * dwarf2out.h (struct dw_vec_struct): Use the "atomic" GTY option
3330 for the array field.
3331 * vec.h: Describe the atomic object "A" type of the macros in
3332 the header comment.
3333 (VEC_T_GTY_ATOMIC, DEF_VEC_A, DEF_VEC_ALLOC_A): Define.
3334 * emit-rtl.c (locations_locators_vals): use the atomic object vector.
3335 * doc/gty.texi: Clarify that GTY option "length" is only for
3336 arrays of non-atomic objects. Fix typo in the description of the
3337 "atomic" option.
3338
3339 2012-07-27 Uros Bizjak <ubizjak@gmail.com>
3340
3341 * config/i386/i386.c (ix86_avoid_lea_for_addr): Handle
3342 zero-extended addresses. Return false if the address has less
3343 than two components.
3344 (ix86_split_lea_for_addr): Unconditionally convert target and
3345 all address operands to requested mode.
3346 * config/i386/i386.md (*lea<mode>): Recover operands from curr_insn.
3347 Pass SImode to ix86_split_lea_for_addr when splitting zero-extended
3348 address.
3349 (zero-extended add splitter): New splitter to conditionally split
3350 non-destructive adds.
3351 (*zero_extendsidi2_rex64): Conditionally emit leal instead of movl.
3352
3353 2012-07-28 Alan Modra <amodra@gmail.com>
3354
3355 PR target/54093
3356 * config/rs6000/rs6000.c (rs6000_secondary_reload): Limit 32-bit
3357 multi-gpr reload to cases where predicate passes. Do the same for
3358 64-bit multi-gpr reload.
3359
3360 2012-07-27 Nathan Froyd <froydnj@gcc.gnu.org>
3361
3362 * expmed.h (alg_hash, alg_hash_used_p, sdiv_pow2_cheap,
3363 smod_pow2_cheap, zero_cost, add_cost, neg_cost, shift_cost)
3364 shiftadd_cost, shiftsub0_cost, shiftsub1_cost, mul_cost,
3365 sdiv_cost, udiv_cost, mul_widen_cost, mul_highpart_cost): Delete
3366 macro definitions and re-purpose as inline functions.
3367 (alg_hash_entry_ptr, set_alg_hash_used_p, sdiv_pow2_cheap_ptr,
3368 set_sdiv_pow2_cheap, smod_pow2_cheap_ptr, set_smod_pow2_cheap,
3369 zero_cost_ptr, set_zero_cost, add_cost_ptr, set_add_cost,
3370 neg_cost_ptr, set_neg_cost, shift_cost_ptr, set_shift_cost,
3371 shiftadd_cost_ptr, set_shiftadd_cost, shiftsub0_cost_ptr,
3372 set_shiftsub0_cost, shiftsub1_cost_ptr, set_shiftsub1_cost,
3373 mul_cost_ptr, set_mul_cost, sdiv_cost_ptr, set_sdiv_cost,
3374 udiv_cost_ptr, set_udiv_cost, mul_widen_cost_ptr,
3375 set_mul_widen_cost, mul_highpart_cost_ptr, set_mul_highpart_cost):
3376 New functions.
3377 (convert_cost_ptr): New function, split out from...
3378 (set_convert_cost, convert_cost): ...here.
3379 * expmed.c, tree-ssa-loop-ivopts.c: Update for new functions.
3380 * gimple-ssa-strength-reduction.c: Likewise.
3381
3382 2012-07-20 Ryan Mansfield <rmansfield@qnx.com>
3383
3384 * gcc.c (main): Move GCC_DRIVER_HOST_INITIALIZATION after
3385 diagnostic_initialize.
3386
3387 2012-07-27 Oleg Endo <olegendo@gcc.gnu.org>
3388
3389 PR target/54089
3390 * config/sh/sh.c (shiftcosts): Remove case where first operand
3391 is a const_int. Move COSTS_N_INSNS usage into caller ...
3392 (sh_rtx_costs) ... here. Return false when shiftcosts cannot be
3393 calculated instead of MAX_COST.
3394
3395 2012-07-27 Richard Guenther <rguenther@suse.de>
3396
3397 * tree-cfg.c (gimple_can_merge_blocks_p): Do more fine-grained
3398 check whether SSA form is not up-to-date.
3399 * tree-flow.h (name_mappings_registered_p): Remove.
3400 * tree-into-ssa.c (struct repl_map_d): Remove.
3401 (repl_tbl): Likewise.
3402 (struct ssa_name_info): Add repl_set member.
3403 (update_ssa_obstack): New static global.
3404 (get_ssa_name_ann): Initialize repl_set.
3405 (clear_ssa_name_info): Assert age did not wrap.
3406 (repl_map_hash, repl_map_eq, repl_map_free): Remove.
3407 (names_replaced_by): Adjust.
3408 (add_to_repl_tbl): Likewise.
3409 (dump_tree_ssa_stats): Likewise.
3410 (init_update_ssa): Initialize update_ssa_obstack.
3411 (delete_update_ssa): Free update_ssa_obstack.
3412 (name_mappings_registered_p): Remove.
3413 (update_ssa): Adjust.
3414
3415 2012-07-27 Segher Boessenkool <segher@kernel.crashing.org>
3416
3417 * config/rs6000/constraints.md: Delete "q" constraint.
3418 * config/rs6000/dfp.md (movsd_hardfloat, movsd_softfloat):
3419 Delete the "q" alternative.
3420 * config/rs6000/predicates.md (gpc_reg_operand): Adjust.
3421 * config/rs6000/rs6000.c (rs6000_debug_reg_global)
3422 (rs6000_init_hard_regno_mode_ok, rs6000_dbx_register_number):
3423 adjust to MQ_REGNO removal.
3424 * config/rs6000/rs6000.h (FIRST_PSEUDO_REGISTER): Adjust
3425 comment.
3426 (REG_ALLOC_ORDER): Adjust comment. Remove MQ from alloc order.
3427 (enum reg_class): Adjust comment. Delete MQ_REGS.
3428 (REG_CLASS_CONTENTS): Adjust.
3429 (REGISTER_NAMES, ADDITIONAL_REGISTER_NAMES): Adjust comment.
3430 * config/rs6000/rs6000.md: Delete MQ_REGNO.
3431 (movsi_internal1, movsi_internal1_single, movhi_internal,
3432 movqi_internal, movcc_internal1, movsf_hardfloat,
3433 movsf_softfloat): Delete the "q" alternative.
3434 (ctr<mode>_internal1, ctr<mode>_internal2, ctr<mode>_internal5,
3435 ctr<mode>_internal6): Delete "q" constraint.
3436
3437 2012-07-27 Richard Guenther <rguenther@suse.de>
3438
3439 * tree-into-ssa.c (def_blocks_p): New typedef.
3440 (insert_phi_nodes_compare_def_blocks): New function.
3441 (insert_phi_nodes): Do not walk over referenced vars, instead
3442 walk over recorded def_blocks, record relevant ones and sort
3443 them to avoid repeated hashtable lookups.
3444
3445 2012-07-27 Richard Guenther <rguenther@suse.de>
3446
3447 * doc/invoke.texi (min-virtual-mappings, virtual-mappings-ratio):
3448 Remove param documentation.
3449 * params.def (PARAM_MIN_VIRTUAL_MAPPINGS,
3450 PARAM_VIRTUAL_MAPPINGS_TO_SYMS_RATIO): Remove.
3451 * tree-flow.h (mark_set_for_renaming): Remove.
3452 * tree-into-ssa.c (struct update_ssa_stats_d): Remove.
3453 (add_new_name_mapping): Remove bookkeeping code.
3454 (dump_update_ssa): Remove stats dumping code.
3455 (init_update_ssa): Remove stats allocation code.
3456 (delete_update_ssa): Remove stats freeing code.
3457 (mark_set_for_renaming): Remove.
3458 (switch_virtuals_to_full_rewrite_p): Likewise.
3459 (switch_virtuals_to_full_rewrite): Likewise.
3460 (update_ssa): Do not call switch_virtuals_to_full_rewrite.
3461
3462 2012-07-27 Marek Polacek <polacek@redhat.com>
3463
3464 * cgraphunit.c: Rename varpool_finalize_variable to
3465 varpool_finalize_decl in a comment.
3466
3467 2012-07-27 Segher Boessenkool <segher@kernel.crashing.org>
3468
3469 * common/config/rs6000/rs6000-common.c (rs6000_handle_option):
3470 Delete code for -mno-power, -mpower, and -mpower2.
3471 * config/rs6000/aix43.h (NON_POWERPC_MASKS): Delete.
3472 (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
3473 with -maix64.
3474 (ASM_CPU_SPEC): Delete support for POWER and POWER2.
3475 * config/rs6000/aix51.h (NON_POWERPC_MASKS): Delete.
3476 (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
3477 with -maix64.
3478 (ASM_CPU_SPEC): Delete support for POWER and POWER2.
3479 * config/rs6000/aix52.h (NON_POWERPC_MASKS): Delete.
3480 (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
3481 with -maix64.
3482 (TARGET_POWER): Delete.
3483 * config/rs6000/aix53.h (NON_POWERPC_MASKS): Delete.
3484 (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
3485 with -maix64.
3486 (TARGET_POWER): Delete.
3487 * config/rs6000/aix61.h (NON_POWERPC_MASKS): Delete.
3488 (SUBTARGET_OVERRIDE_OPTIONS): Delete check for POWER together
3489 with -maix64.
3490 (TARGET_POWER): Delete.
3491 * config/rs6000/darwin.h (TARGET_POWER): Delete.
3492 * config/rs6000/driver-rs6000.c (struct asm_names): Delete
3493 support for -mpower, -mpower2, and -mno-power.
3494 * config/rs6000/rs6000-c.c (rs6000_target_modify_macros):
3495 Likewise.
3496 (rs6000_cpu_cpp_builtins): Likewise.
3497 * config/rs6000/rs6000-cpus.def: Likewise.
3498 * config/rs6000/rs6000-tables.opt: Regenerate.
3499 * config/rs6000/rs6000.c (POWER_MASKS): Delete.
3500 (rs6000_option_override_internal): Adjust.
3501 (rs6000_conditional_register_usage): Adjust.
3502 (rs6000_emit_move): Adjust.
3503 (rs6000_common_init_builtins): Adjust.
3504 (rs6000_init_libfuncs): Adjust.
3505 (rs6000_output_function_prologue): Adjust.
3506 (rs6000_adjust_cost): Adjust.
3507 (struct rs6000_opt_masks): Delete MASK_POWER and MASK_POWER2.
3508 * config/rs6000/rs6000.h (ASM_CPU_SPEC): Delete support for
3509 POWER and POWER2.
3510 (TARGET_DEFAULT): Adjust.
3511 (PROCESSOR_POWER): Delete.
3512 (SHIFT_COUNT_TRUNCATED): Adjust.
3513 * config/rs6000/rs6000.md (extendqisi2): Delete POWER support.
3514 (extendqisi2_power): Delete.
3515 (extendqisi2_no_power): Adjust.
3516 (extendqihi2, extendqihi2_power, extendqihi2_no_power):
3517 Likewise.
3518 (sminsi3, smaxsi3, uminsi3, umaxsi3): Adjust.
3519 (anonymous doz insn patterns): Delete.
3520 (abssi2): Adjust.
3521 (abssi2_power): Delete.
3522 (abssi2_nopower): Adjust.
3523 (nabs_power, nabs_nopower): Likewise.
3524 (mulsi3, mulsi3_mq, mulsi3_no_mq, mulsi3_mq_internal1):
3525 Likewise. Delete anonymous post-reload splitter.
3526 (mulsi3_no_mq_internal1): rename to...
3527 (mulsi3_internal1): New define_insn.
3528 (mulsi3_mq_internal2, mulsi3_no_mq_internal2, mulsi3_internal2):
3529 Likewise.
3530 (divmodsi4, divmodsi4_internal, udiv<mode>3, udivsi3_mq,
3531 udivsi3_no_mq, udivsi3, div<mode>3, divsi3_mq, div<mode>3_no_mq,
3532 udivmodsi4_normal, udivmodsi4_tests, udivmodsi4): Likewise.
3533 (mulh_call, mull_call, divss_call, divus_call, quoss_call,
3534 quous_call): Likewise.
3535 (maskir_internal1, maskir_internal2, maskir_internal3,
3536 maskir_internal4, maskir_internal5, maskir_internal6,
3537 maskir_internal7, maskir_internal8): Delete.
3538 (ashlsi3, ashlsi3_power, ashlsi3_no_power): Adjust.
3539 (anonymous sl insn patterns): Delete.
3540 (lshrsi3, lshrsi3_power, lshrsi3_no_power): Adjust.
3541 (lshrsi3_64): Adjust.
3542 (anonymous sr insn patterns): Delete.
3543 (anonymous rrib insn patterns): Delete.
3544 (ashrsi3, ashrsi3_power, ashrsi3_no_power): Adjust.
3545 (anonymous sra insn patterns): Delete.
3546 (sqrtsf2, sqrtdf2, sqrtdf2_fpr): Adjust.
3547 (fix_trunc<mode>si2, fix_trunc<mode>si2_internal,
3548 fctiwz_<mode>): Adjust.
3549 (mulsidi3, mulsidi3_mq, mulsidi3_no_mq, umulsidi3, umulsidi3_mq,
3550 umulsidi3_no_mq, smulsi3_highpart, smulsi3_highpart_mq,
3551 smulsi3_highpart_no_mq, umulsi3_highpart, umulsi3_highpart_mq,
3552 umulsi3_highpart_no_mq): Adjust.
3553 (ashldi3_power, lshrdi3_power, ashrdi3_power): Delete.
3554 (ashrdi3_no_power, ashldi3, ashldi3_internal1,
3555 lshrdi3_internal1): Adjust.
3556 (fix_trunctfsi2, fix_trunctfsi2_fprs): Adjust.
3557 (movti_power): Delete.
3558 (movti_string): Adjust.
3559 (stmsi8, stmsi7, stmsi6, stmsi5, stmsi4, stmsi3): Adjust.
3560 (stmsi8_power, stmsi7_power, stmsi6_power, stmsi5_power,
3561 stmsi4_power, stmsi3_power): Delete.
3562 (anonymous movmemsi insn patterns): Adjust.
3563 (lfq_power2, stfq_power2): Delete.
3564 (eq<mode>, eq<mode>_compare): Adjust.
3565 (eqsi_power): Delete.
3566 (ne0si): Adjust.
3567 (anonymous le, lt, ge, gt insn patterns): Delete.
3568 * config/rs6000/rs6000.opt (mpower, mno-power, mpower2): Delete.
3569 * config/rs6000/sysv4.h (TARGET_POWER): Delete.
3570 * config/rs6000/t-aix43 (MULTILIB_OPTIONS, MULTILIB_DIRNAMES,
3571 MULTILIB_MATCHES): Adjust.
3572 * doc/invoke.texi (RS/6000 and PowerPC Options): Delete
3573 -mpower, -mno-power, -mpower2, -mno-power2 documentation.
3574 Delete -mcpu=power and -mcpu=power2 documentation.
3575
3576 2012-07-27 Segher Boessenkool <segher@kernel.crashing.org>
3577
3578 * config/rs6000/601.md: New file.
3579 * config/rs6000/aix43.h (ASM_CPU_SPEC): Delete support for
3580 RIOS CPUs.
3581 * config/rs6000/aix51.h (ASM_CPU_SPEC): Likewise.
3582 * config/rs6000/driver-rs6000.c (detect_processor_aix,
3583 struct asm_names): Likewise.
3584 * config/rs6000/rios1.md: Delete file.
3585 * config/rs6000/rios2.md: Delete file.
3586 * config/rs6000/rs6000-cpus.def: Delete definitions for RIOS
3587 CPUs.
3588 * config/rs6000/rs6000-opts.h (enum processor_type): Delete
3589 PROCESSOR_RIOS1 and PROCESSOR_RIOS2.
3590 * config/rs6000/rs6000-tables.opt: Regenerated.
3591 * config/rs6000/rs6000.c (struct rios1_cost, struct rios2_cost):
3592 Delete.
3593 (rs6000_option_override_internal): Delete support for RIOS CPUs.
3594 (rs6000_conditional_register_usage): Adjust comment.
3595 (rs6000_issue_rate):Delete support for RIOS CPUs.
3596 * config/rs6000/rs6000.h (ASM_CPU_SPEC): Delete support for
3597 RIOS CPUs.
3598 (PROCESSOR_POWER): Change to PROCESSOR_PPC601.
3599 (PROCESSOR_DEFAULT): Change to PROCESSOR_PPC603.
3600 * config/rs6000/rs6000.md (define_attr "cpu"): Delete rios1
3601 and rios2.
3602 (include "rios1.md", include "rios2.md"): Delete.
3603 (include "601.md"): New.
3604 * config/rs6000/rs6000.opt (enum rs6000_cpu): Default to
3605 PROCESSOR_PPC603.
3606 * config/rs6000/t-aix43 (MULTILIB_MATCHES): Delete support
3607 for RIOS CPUs.
3608 * config/rs6000/t-rs6000 (MD_INCLUDES): Delete rios1.md and
3609 rios2.md . Add 601.md .
3610
3611 2012-07-26 Richard Henderson <rth@redhat.com>
3612
3613 * doc/extend.texi (attribute): Document hot/cold for labels.
3614 * predict.c (tree_estimate_probability_bb): Handle hot/cold
3615 attributes on user labels.
3616 * predict.def (PRED_HOT_LABEL, PRED_COLD_LABEL): New.
3617
3618 2012-07-26 Andrew Jenner <andrew@codesourcery.com>
3619 Sandra Loosemore <sandra@codesourcery.com>
3620
3621 * cse.c (find_comparison_args): Check for cycles of any length.
3622
3623 2012-07-26 Nick Clifton <nickc@redhat.com>
3624
3625 * config/mn10300/mn10300.c (REG_SAVE_BYTES): Delete.
3626 (mn10300_get_live_callee_saved_regs): If requested return a count
3627 of the number of bytes in the mask.
3628 (mn10300_expand_prologue): Add argument to invocation of
3629 mn10300_get_live_callee_regs.
3630 (mn10300_expand_epilogue): Compute reg_save_bytes by calling
3631 mn10300_get_live_callee_saved_regs.
3632 (mn10300_initial_offset): Likewise.
3633 * config/mn10300/mn10300-protos.h (mn10300_get_live_callee_saved_regs):
3634 Update prototype.
3635 * config/mn10300/mn10300.md (return_ret): Add argument to
3636 invocation of mn10300_get_live_callee_saved_regs.
3637
3638 2012-07-26 Steven Bosscher <steven@gcc.gnu.org>
3639
3640 PR regression/54084
3641 * sel-sched-ir.c (cmp_v_in_regset_pool): Clarify logic, fix
3642 pointer difference check.
3643
3644 2012-07-26 Bill Schmidt <wschmidt@linux.ibm.com>
3645
3646 * tree-ssa-loop-ivopts.c (mbc_entry_hash): Remove.
3647 (mbc_entry_eq): Likewise.
3648 (mult_costs): Likewise.
3649 (cost_tables_exist): Likewise.
3650 (initialize_costs): Likewise.
3651 (finalize_costs): Likewise.
3652 (tree_ssa_iv_optimize_init): Remove call to initialize_costs.
3653 (add_regs_cost): Remove.
3654 (multiply_regs_cost): Likewise.
3655 (add_const_cost): Likewise.
3656 (extend_or_trunc_reg_cost): Likewise.
3657 (negate_reg_cost): Likewise.
3658 (struct mbc_entry): Likewise.
3659 (multiply_by_const_cost): Likewise.
3660 (get_address_cost): Change add_regs_cost calls to add_cost lookups;
3661 change multiply_by_const_cost to mult_by_coeff_cost.
3662 (force_expr_to_var_cost): Likewise.
3663 (difference_cost): Change multiply_by_const_cost to mult_by_coeff_cost.
3664 (get_computation_cost_at): Change add_regs_cost calls to add_cost
3665 lookups; change multiply_by_const_cost to mult_by_coeff_cost.
3666 (determine_iv_cost): Change add_regs_cost calls to add_cost lookups.
3667 (tree_ssa_iv_optimize_finalize): Remove call to finalize_costs.
3668 * tree-ssa-address.c (expmed.h): New #include.
3669 (most_expensive_mult_to_index): Change multiply_by_const_cost to
3670 mult_by_coeff_cost.
3671 * gimple-ssa-strength-reduction.c (expmed.h): New #include.
3672 (stmt_cost): Change to use mult_by_coeff_cost, mul_cost, add_cost,
3673 neg_cost, and convert_cost instead of IVOPTS interfaces.
3674 (execute_strength_reduction): Remove calls to initialize_costs and
3675 finalize_costs.
3676 * expmed.c (struct init_expmed_rtl): Add convert rtx_def.
3677 (init_expmed_one_mode): Initialize convert rtx_def; initialize
3678 x_convert_cost for related modes.
3679 (mult_by_coeff_cost): New function.
3680 * expmed.h (NUM_MODE_INT): New #define.
3681 (struct target_expmed): Add x_convert_cost matrix.
3682 (set_convert_cost): New inline function.
3683 (convert_cost): Likewise.
3684 (mult_by_coeff_cost): New extern decl.
3685 * tree-flow.h (initialize_costs): Remove decl.
3686 (finalize_costs): Likewise.
3687 (multiply_by_const_cost): Likewise.
3688 (add_regs_cost): Likewise.
3689 (multiply_regs_cost): Likewise.
3690 (add_const_cost): Likewise.
3691 (extend_or_trunc_reg_cost): Likewise.
3692 (negate_reg_cost): Likewise.
3693 * Makefile.in (gimple-ssa-strength-reduction.o): Update dependencies.
3694 (tree-ssa-address.o): Update dependencies.
3695
3696 2012-07-26 Steven Bosscher <steven@gcc.gnu.org>
3697
3698 * bitmap.h: Add explanation of sparse set as linked-list bitmap.
3699 * sbitmap.h: Add explanation about non-sparse sets as simple bitmap.
3700 (TEST_BIT): Make a static inline function for stronger type checking.
3701 (SET_BIT): Don't handle sbitmaps with popcount.
3702 (RESET_BIT): Likewise.
3703 (SET_BIT_WITH_POPCOUNT): New, like SET_BIT but with popcount.
3704 (RESET_BIT_WITH_POPCOUNT): New, like RESET_BIT but with popcount.
3705 * ebitmap.c (ebitmap_clear_bit): Use SET_BIT_WITH_POPCOUNT and
3706 RESET_BIT_WITH_POPCOUNT on wordmask bitmaps.
3707 (ebitmap_set_bit, ebitmap_and_into, ebitmap_and, ebitmap_ior_into,
3708 ebitmap_and_compl_into, ebitmap_and_compl): Likewise.
3709 * sparseset.h: Add explanation of sparse set representation.
3710
3711 2012-07-26 Richard Guenther <rguenther@suse.de>
3712
3713 PR tree-optimization/54098
3714 * tree-vrp.c (vrp_visit_phi_node): Iterate once more if the
3715 original range was UNDEFINED.
3716
3717 2012-07-26 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
3718
3719 * config/arm/neon.ml (ops): Fix regexp for vld1Q_dups64 and
3720 vld1Q_dupu64 tests.
3721
3722 2012-07-26 Oleg Endo <olegendo@gcc.gnu.org>
3723
3724 PR target/51244
3725 * config/sh/sh.opt (mzdcbranch): New option.
3726 * doc/invoke.texi: Document it.
3727 * config/sh/sh.md (negsi_cond): Use TARGET_ZDCBRANCH as condition
3728 instead of TARGET_HARD_SH4.
3729 * config/sh/sh.c (sh_option_override): Set TARGET_ZDCBRANCH as default
3730 for TARGET_HARD_SH4.
3731
3732 2012-07-25 Oleg Endo <olegendo@gcc.gnu.org>
3733
3734 PR target/54089
3735 * config/sh/predicates.md (shift_count_operand): Handle not-SHMEDIA
3736 case.
3737 (p27_shift_count_operand, not_p27_shift_count_operand): New predicates.
3738 * config/sh/sh.md (ashlsi3): Remove parallel and T_REG clobber
3739 from expander. Do not emit shift insn for not-SHMEDIA case.
3740 (ashlsi3_std): Replace with ...
3741 (ashlsi3_k, ashlsi3_d): ... these new insns.
3742 * config/sh/sh.c (gen_ashift): Make static. Add sanity checks.
3743 Emit ashlsi3_k insn instead of ashlsi3_std in ASHIFT case.
3744 (gen_ashift_hi): Make static.
3745 * config/sh/sh-protos.h (gen_ashift, gen_ashift_hi): Remove forward
3746 declaration.
3747
3748 2012-07-25 Bharathi Seshadri <bseshadr@cisco.com>
3749 Jim Wilson <jimwilso@cisco.com>
3750
3751 * config/arm/bpabi.h (BE8_LINK_SPEC): Set according to
3752 TARGET_BIG_ENDIAN_DEFAULT.
3753
3754 2012-07-25 Eric Botcazou <ebotcazou@adacore.com>
3755
3756 * gimple-low.c (lower_try_catch): New function.
3757 (lower_stmt) <GIMPLE_TRY>: Use it to lower GIMPLE_TRY_CATCH.
3758 <GIMPLE_CATCH>: Delete.
3759 <GIMPLE_EH_FILTER>: Likewise.
3760
3761 2012-07-25 Eric Botcazou <ebotcazou@adacore.com>
3762
3763 * expr.c (expand_expr_real_1): Do not expand operand #1 and #2
3764 of BIT_FIELD_REF for ignored results.
3765 * fold-const.c (fold_ternary_loc) <BIT_FIELD_REF>: Check that the
3766 CONSTRUCTOR has vector type before using vector accessors on it.
3767 * gimplify.c (gimplify_compound_lval): Do not gimplify operand #1 and
3768 #2 of BIT_FIELD_REF.
3769 (gimplify_expr) <BIT_FIELD_REF>: Likewise.
3770 * tree-nested.c (convert_nonlocal_reference_op) <BIT_FIELD_REF>: Do
3771 not process operand #1 and #2.
3772 (convert_local_reference_op): Likewise.
3773 * tree-ssa-pre.c (create_component_ref_by_pieces_1): Remove superfluous
3774 breaks throughout.
3775 <BIT_FIELD_REF>: Reuse operand #1 and #2 directly.
3776 * tree.c (stabilize_reference) <BIT_FIELD_REF>: Do not stabilize
3777 operand #1 and #2.
3778 (UPDATE_FLAGS): Do not consider operand #2 of BIT_FIELD_REF.
3779 (build6_stat): Delete.
3780 * tree.h (build6_stat, build6, build6_stat_loc, build6_loc): Likewise.
3781
3782 2012-07-25 Marc Glisse <marc.glisse@inria.fr>
3783
3784 PR tree-optimization/30318
3785 * tree-vrp.c (extract_range_from_binary_expr_1) [PLUS_EXPR]:
3786 Handle __int128.
3787 [MINUS_EXPR]: Merge with PLUS_EXPR.
3788
3789 2012-07-25 Sandra Loosemore <sandra@codesourcery.com>
3790 Paul Brook <paul@codesourcery.com>
3791
3792 PR target/53633
3793 * target.def (warn_func_return): New hook.
3794 * doc/tm.texi.in (TARGET_WARN_FUNC_RETURN): New hook.
3795 * doc/tm.texi: Regenerate.
3796 * doc/sourcebuild.texi (Effective-Target Keywords): Document
3797 naked_functions.
3798 * ipa-pure-const.c (warn_function_noreturn): Check
3799 targetm.warn_func_return.
3800 * tree-cfg.c (execute_warn_function_return): Likewise.
3801 * config/spu/spu.c (spu_warn_func_return): New.
3802 (TARGET_WARN_FUNC_RETURN): Define.
3803 * config/rx/rx.c (rx_warn_func_return): New.
3804 (TARGET_WARN_FUNC_RETURN): Define.
3805 * config/avr/avr.c (avr_warn_func_return): New.
3806 (TARGET_WARN_FUNC_RETURN): Define.
3807 * config/arm/arm.c (arm_warn_func_return): New.
3808 (TARGET_WARN_FUNC_RETURN): Define.
3809 * config/mcore/mcore.c (mcore_warn_func_return): New.
3810 (TARGET_WARN_FUNC_RETURN): Define.
3811 (saved_warn_return_type, saved_warn_return_type_count): Remove.
3812 (mcore_reorg, mcore_handle_naked_attribute): Remove warn_return hack.
3813
3814 2012-07-25 Siddhesh Poyarekar <siddhesh@redhat.com>
3815
3816 * final.c [ASSEMBLER_DIALECT](do_assembler_dialects): New
3817 function to implement assembler dialects.
3818 (output_asm_insn): Use do_assembler_dialects.
3819 (asm_fprintf): Likewise.
3820
3821 2012-07-25 Richard Henderson <rth@redhat.com>
3822
3823 PR bootstrap/54092
3824 * libfuncs.h: Don't include optabs.h.
3825 (struct libfunc_entry): Use "int" for op, mode1, mode2 members.
3826 * optabs.c (hash_libfunc): Don't cast members to int.
3827 * Makefile.in (LIBFUNCS_H): Don't include OPTABS_H.
3828
3829 2012-07-25 Dodji Seketeli <dodji@redhat.com>
3830
3831 * basic-block.c: Fix typo in comment.
3832
3833 2012-07-25 Kirill Yukhin <kirill.yukhin@intel.com>
3834 Michael Zolotukhin <michael.v.zolotukhin@intel.com>
3835
3836 * common/config/i386/i386-common.c (OPTION_MASK_ISA_PRFCHW_SET): New.
3837 (OPTION_MASK_ISA_PRFCHW_UNSET): Likewise.
3838 (ix86_handle_option): Handle mprfchw option.
3839 * config.gcc (i[34567]86-*-*): Add prfchwintrin.h.
3840 (x86_64-*-*): Likewise.
3841 * config/i386/prfchwintrin.h: New header.
3842 * config/i386/cpuid.h (bit_PRFCHW): New.
3843 (bit_BMI): Formatting fix.
3844 (bit_HLE): Likewise.
3845 (bit_RTM): Likewise.
3846 * config/i386/driver-i386.c (host_detect_local_cpu): Detect
3847 PREFETCHW support.
3848 * config/i386/i386-c.c: Define __PRFCHW__ if needed.
3849 * config/i386/i386.c (ix86_target_string): Define
3850 -mprfchw option. Formatting fixes.
3851 (PTA_HLE): Formatting fix.
3852 (PTA_PRFCHW): New.
3853 (ix86_option_override_internal): Handle new option.
3854 (ix86_valid_target_attribute_inner_p): Add OPT_mprfchw.
3855 * config/i386/i386.h (TARGET_PRFCHW): New.
3856 * config/i386/i386.md (prefetch): Enable for TARGET_PRFCHW.
3857 * config/i386/i386.opt (mprfchw): New.
3858 * config/i386/mm3dnow.h: Move _m_prefetchw from here to prfchwintrin.h.
3859 * config/i386/x86intrin.h: Include prfchwintrin.h.
3860
3861 2012-07-25 Sergey Melnikov <sergey.melnikov@intel.com>
3862
3863 * config/i386/i386.md (stack_protect_set): Disable the pattern
3864 for Android since Android libc (bionic) does not provide random
3865 value for stack protection guard at gs:0x14. Guard value
3866 will be provided from external symbol (default implementation).
3867 (stack_protect_set_<mode>): Likewise.
3868 (stack_protect_test): Likewise.
3869 (stack_protect_test_<mode>): Likewise.
3870 * gcc/defaults.h: Define macro TARGET_HAS_BIONIC to 0 - target does
3871 not have Bionic by default
3872 * config/linux.h: Redefine macro TARGET_HAS_BIONIC to (OPTION_BIONIC)
3873 Macro OPTION_BIONIC is defined in this file and provides Bionic
3874 accessibility status
3875
3876 2012-07-25 Steven Bosscher <steven@gcc.gnu.org>
3877
3878 * gimple-pretty-print.c (gimple_dump_bb_buff): Call pp_flush.
3879
3880 2012-07-25 Venkataramanan Kumar <venkataramanan.kumar@amd.com>
3881
3882 btver2 Enablement
3883 * config.gcc (i[34567]86-*-linux* | ...): Add btver2.
3884 (case ${target}): Add btver2.
3885 * config/i386/driver-i386.c (host_detect_local_cpu): Let
3886 -march=native recognize btver2 processors.
3887 * config/i386/i386-c.c (ix86_target_macros_internal): Add
3888 btver2 def_and_undef
3889 * config/i386/i386.c (struct processor_costs btver2_cost): New
3890 btver2 cost table.
3891 (m_BTVER2): New definition.
3892 (m_AMD_MULTIPLE): Includes m_BTVER2.
3893 (initial_ix86_tune_features): Add btver2 tune.
3894 (processor_target_table): Add btver2 entry.
3895 (static const char *const cpu_names): Add btver2 entry.
3896 (software_prefetching_beneficial_p): Add btver2.
3897 (ix86_option_override_internal): Add btver2 instruction sets.
3898 (ix86_issue_rate): Add btver2.
3899 (ix86_adjust_cost): Add btver2.
3900 * config/i386/i386.h (TARGET_BTVER2): New definition.
3901 (enum target_cpu_default): Add TARGET_CPU_DEFAULT_btver2.
3902 (enum processor_type): Add PROCESSOR_BTVER2.
3903 * config/i386/i386.md (define_attr "cpu"): Add btver2.
3904
3905 2012-07-24 Bill Schmidt <wschmidt@linux.ibm.com>
3906
3907 * doc/tm.texi: Regenerate.
3908 * targhooks.c (default_init_cost): Add prologue and epilogue costs.
3909 (default_add_stmt_cost): Likewise; also handle NULL stmt_info.
3910 (default_finish_cost): Add prologue and epilogue costs.
3911 * targhooks.h (default_add_stmt_cost): Change parameter list.
3912 (default_finish_cost): Likewise.
3913 * target.def (init_cost): Change documentation string.
3914 (add_stmt_cost): Change documentation string and parameter list.
3915 (finish_cost): Likewise.
3916 * target.h (vect_cost_model_location): New enum.
3917 * tree-vectorizer.h (struct _slp_tree): Remove cost substruct.
3918 (struct _slp_instance): Remove cost substruct; rename stmt_cost_vec
3919 to body_cost_vec.
3920 (SLP_INSTANCE_OUTSIDE_OF_LOOP_COST): Remove.
3921 (SLP_INSTANCE_STMT_COST_VEC): Rename to SLP_INSTANCE_BODY_COST_VEC.
3922 (SLP_TREE_OUTSIDE_OF_LOOP_COST): Remove.
3923 (struct _vect_peel_extended_info): Rename stmt_cost_vec to
3924 body_cost_vec.
3925 (struct _stmt_vec_info): Remove cost substruct.
3926 (STMT_VINFO_OUTSIDE_OF_LOOP_COST): Remove.
3927 (stmt_vinfo_set_outside_of_loop_cost): Remove.
3928 (builtin_vectorization_cost): New function.
3929 (vect_get_stmt_cost): Change to use builtin_vectorization_cost.
3930 (add_stmt_cost): Change parameter list.
3931 (finish_cost): Likewise.
3932 (vect_model_simple_cost): Likewise.
3933 (vect_model_store_cost): Likewise.
3934 (vect_model_load_cost): Likewise.
3935 (record_stmt_cost): Likewise.
3936 (vect_get_load_cost): Likewise.
3937 (vect_get_known_peeling_cost): Likewise.
3938 * tree-vect-loop.c (vect_get_known_peeling_cost): Change parameter
3939 list; call record_stmt_cost for prologue and epilogue costs.
3940 (vect_estimate_min_profitable_iters): Call add_stmt_cost for
3941 prologue and epilogue costs; remove computation of vec_outside_cost;
3942 return vec_prologue_cost and vec_epilogue_cost from finish_cost.
3943 (vect_model_reduction_cost): Revise call to add_stmt_cost for body
3944 costs; call add_stmt_cost for prologue and epilogue costs.
3945 (vect_model_induction_cost): Revise call to add_stmt_cost for body
3946 costs; call add_stmt_cost for prologue costs.
3947 * tree-vect-data-refs.c (vect_get_data_access_cost): Change parameter
3948 list for function and arguments for calls to vect_get_load_cost and
3949 vect_get_store_cost.
3950 (vect_peeling_hash_get_lowest_cost): Change argument list for calls to
3951 vect_get_data_access_cost and vect_get_known_peeling_cost; use
3952 temporary vectors prologue_cost_vec and epilogue_cost_vec for the
3953 latter call and discard their results; rename stmt_cost_vec to
3954 body_cost_vec; correct possible storage leak for body_cost_vec.
3955 (vect_peeling_hash_choose_best_peeling): Rename stmt_cost_vec to
3956 body_cost_vec.
3957 (vect_enhance_data_refs_alignment): Rename stmt_cost_vec to
3958 body_cost_vec; add extra dummy parameter on calls to
3959 vect_get_data_access_cost; tolerate null si->stmt; add vect_body to
3960 argument list on call to add_stmt_cost.
3961 * tree-vect-stmts.c (record_stmt_cost): Change parameter list;
3962 rename stmt_cost_vec to body_cost_vec; tolerate null stmt_info; call
3963 builtin_vectorization_cost; add "where" parameter on call to
3964 add_stmt_cost.
3965 (vect_model_simple_cost): Change parameter list; call record_stmt_cost
3966 for prologue costs; remove call to stmt_vinfo_set_outside_of_loop_cost;
3967 rename stmt_cost_vec to body_cost_vec.
3968 (vect_model_promotion_demotion_cost): Add vect_body argument to call
3969 to add_stmt_cost; call add_stmt_cost for prologue costs; remove call
3970 to stmt_vinfo_set_outside_of_loop_cost.
3971 (vect_model_store_cost): Change parameter list; call record_stmt_cost
3972 for prologue costs; add vect_body argument to call to record_stmt_cost;
3973 rename stmt_cost_vec to body_cost_vec; remove call to
3974 stmt_vinfo_set_outside_of_loop_cost.
3975 (vect_get_store_cost): Rename stmt_cost_vec to body_cost_vec; add
3976 vect_body argument to calls to record_stmt_cost.
3977 (vect_model_load_cost): Change parameter list; rename stmt_cost_vec to
3978 body_cost_vec; add vect_body argument to calls to record_stmt_cost;
3979 remove call to stmt_vinfo_set_outside_of_loop_cost.
3980 (vect_get_load_cost): Change parameter list; rename stmt_cost_vec to
3981 body_cost_vec; add vect_body argument to calls to record_stmt_cost;
3982 call record_stmt_cost for prologue costs.
3983 (vectorizable_store): Change argument list for call to
3984 vect_model_store_cost.
3985 (vectorizable_load): Change argument list for call to
3986 vect_model_load_cost.
3987 (new_stmt_vec_info): Remove assignment to
3988 STMT_VINFO_OUTSIDE_OF_LOOP_COST.
3989 * config/spu/spu.c (spu_init_cost): Add prologue and epilogue costs.
3990 (spu_add_stmt_cost): Likewise; also handle NULL stmt_info.
3991 (spu_finish_cost): Add prologue and epilogue costs.
3992 * config/i386/i386.c (i386_init_cost): Add prologue and epilogue costs.
3993 (i386_add_stmt_cost): Likewise; also handle NULL stmt_info.
3994 (i386_finish_cost): Add prologue and epilogue costs.
3995 * config/rs6000/rs6000.c (rs6000_init_cost): Add prologue and epilogue
3996 costs.
3997 (rs6000_add_stmt_cost): Likewise; also handle NULL stmt_info.
3998 (rs6000_finish_cost): Add prologue and epilogue costs.
3999 * tree-vect-slp.c (vect_free_slp_instance): Rename
4000 SLP_INSTANCE_STMT_COST_VEC to SLP_INSTANCE_BODY_COST_VEC.
4001 (vect_create_new_slp_node): Remove assignment to
4002 SLP_TREE_OUTSIDE_OF_LOOP_COST.
4003 (vect_get_and_check_slp_defs): Change parameter list; change argument
4004 lists to calls to vect_model_store_cost and vect_model_simple_cost.
4005 (vect_build_slp_tree): Change parameter list; change argument lists
4006 to calls to vect_model_load_cost, vect_get_and_check_slp_defs, and
4007 recursive self-calls; remove setting of outside_cost from
4008 SLP_TREE_OUTSIDE_OF_LOOP_COST; add vect_body argument to call to
4009 record_stmt_cost.
4010 (vect_analyze_slp_instance): Rename stmt_cost_vec to body_cost_vec;
4011 rename SLP_INSTANCE_STMT_COST_VEC to SLP_INSTANCE_BODY_COST_VEC;
4012 remove assignment to SLP_INSTANCE_OUTSIDE_OF_LOOP_COST; record SLP
4013 prologue costs.
4014 (vect_bb_vectorization_profitable_p): Rename stmt_cost_vec to
4015 body_cost_vec; handle null ci->stmt; add vect_body argument to call
4016 to add_stmt_cost; simplify calls to targetm.vectorize.
4017 builtin_vectorization_cost; return vec_prologue_cost and
4018 vec_epilogue_cost from finish_cost.
4019 (vect_update_slp_costs_according_to_vf): Rename stmt_cost_vec to
4020 body_cost_vec; add vect_body argument to call to add_stmt_cost.
4021
4022 2012-07-24 Richard Henderson <rth@redhat.com>
4023
4024 * system.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Poison.
4025 * config/cris/cris.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
4026 * config/h8300/h8300.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
4027 * config/mn10300/mn10300.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
4028 * config/rs6000/rs6000.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove
4029 comment reference.
4030 * config/v850/v850.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
4031 * config/v850/v850.md (fixuns_truncsfsi2, fixuns_truncdfsi2): New.
4032 (fix_truncsfsi2, fix_truncdfsi2): Avoid double FIX.
4033 * config/vax/vax.h (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
4034 * config/vax/vax.md (fixuns_trunc<VAXfp><VAXint>): New.
4035 * doc/tm.texi.in (FIXUNS_TRUNC_LIKE_FIX_TRUNC): Remove.
4036 * doc/tm.texi: Rebuild.
4037
4038 2012-07-24 Richard Henderson <rth@redhat.com>
4039
4040 * optabs.def: New file.
4041 * Makefile.in (OPTABS_H): Add insn-opinit.h.
4042 (MOSTLYCLEANFILES): Likewise.
4043 (insn-opinit.o): Remove reload.h
4044 (simple_rtl_generated_c): Remove insn-opinit.c.
4045 (s-opinit): New rule.
4046 (build/genopinit.o): Add optabs.def.
4047 * genopinit.c (rtx_upname): New.
4048 (optabs): Extract to optabs.def
4049 (enum optab_tag, struct optab_def_d, optabs): New.
4050 (struct pattern_d, patterns): New.
4051 (match_pattern): Split out from ...
4052 (gen_insn): ... here. Push matches on patterns vec.
4053 (pattern_cmp, optab_kind_cmp, optab_rcode_cmp): New.
4054 (header_file_name, source_file_name, handle_arg): New.
4055 (open_outfile): New.
4056 (main): Sort and emit new tables. Generate lookup_handler,
4057 raw_optab_handler, swap_optab_enable.
4058 * libfuncs.h (libfunc_entry): Change "size_t optab" to "optab op".
4059 * optabs.c (code_to_optab_): Remove.
4060 (hash_libfunc): Update for optab name change.
4061 (eq_libfunc): Likewise.
4062 (convert_optab_libfunc): Update computation of optab member;
4063 use the new convlib_def table.
4064 (optab_libfunc): Similarly.
4065 (set_optab_libfunc, set_conv_libfunc): Likewise.
4066 (sign_expand_binop): Use swap_optab_enable instead of fake optabs.
4067 (init_insn_codes, init_optab, init_optabv, init_convert_optab): Remove.
4068 (init_optabs): Don't call them; export the data to optabs.def.
4069 (gen_int_libfunc, gen_fp_libfunc): Export non-static.
4070 (gen_fixed_libfunc, gen_signed_fixed_libfunc): Likewise.
4071 (gen_unsigned_fixed_libfunc, gen_int_fp_libfunc): Likewise.
4072 (gen_intv_fp_libfunc, gen_int_fp_fixed_libfunc): Likewise.
4073 (gen_int_fp_signed_fixed_libfunc, gen_int_fixed_libfunc): Likewise.
4074 (gen_int_signed_fixed_libfunc): Likewise.
4075 (gen_int_unsigned_fixed_libfunc): Likewise.
4076 (gen_interclass_conv_libfunc, gen_int_to_fp_conv_libfunc): Likewise.
4077 (gen_ufloat_conv_libfunc): Likewise.
4078 (gen_int_to_fp_nondecimal_conv_libfunc): Likewise.
4079 (gen_fp_to_int_conv_libfunc, gen_intraclass_conv_libfunc): Likewise.
4080 (gen_trunc_conv_libfunc, gen_extend_conv_libfunc): Likewise.
4081 (gen_fract_conv_libfunc, gen_fractuns_conv_libfunc): Likewise.
4082 (gen_satfract_conv_libfunc, gen_satfractuns_conv_libfunc): Likewise.
4083 (debug_optab_libfuncs): Update for optab representation change.
4084 * optabs.h: Include insn-opinit.h.
4085 (optab, convert_optab, direct_optab): New typedefs.
4086 (struct optab_handlers, struct widening_optab_handlers): Remove.
4087 (struct optab_libcall_d): Rename from optab_d; remove code_,
4088 handlers, widening members.
4089 (struct convert_optab_libcall_d): Rename from convert_optab_d;
4090 remove code_ and handlers members.
4091 (enum optab_index, enum convert_optab_index): Remove.
4092 (enum direct_optab_index): Remove.
4093 (code_to_optab_): Fix array range.
4094 (optab_to_code): Covert to inline function.
4095 (optab_to_code_, convlib_def, normlib_def): Declare.
4096 (raw_optab_handler, swap_optab_enable): Declare.
4097 (unknown_optab): Remove; export to optabs.def
4098 (ssadd_optab, usadd_optab, sssub_optab, ussub_optab, ssmul_optab,
4099 usmul_optab, ssdiv_optab, usdiv_optab, ssneg_optab, usneg_optab,
4100 ssashl_optab, usashl_optab, add_optab, sub_optab, smul_optab,
4101 addv_optab, subv_optab, smul_highpart_optab, umul_highpart_optab,
4102 smul_widen_optab, umul_widen_optab, usmul_widen_optab,
4103 smadd_widen_optab, umadd_widen_optab, ssmadd_widen_optab,
4104 usmadd_widen_optab, smsub_widen_optab, umsub_widen_optab,
4105 ssmsub_widen_optab, usmsub_widen_optab, sdiv_optab, smulv_optab,
4106 sdivv_optab, sdivmod_optab, udiv_optab, udivmod_optab, smod_optab,
4107 umod_optab, fmod_optab, remainder_optab, ftrunc_optab, and_optab,
4108 ior_optab, xor_optab, ashl_optab, lshr_optab, ashr_optab, rotl_optab,
4109 rotr_optab, vashl_optab, vlshr_optab, vashr_optab, vrotl_optab,
4110 vrotr_optab, smin_optab, smax_optab, umin_optab, umax_optab, pow_optab,
4111 atan2_optab, fma_optab, fms_optab, fnma_optab, fnms_optab, mov_optab,
4112 movstrict_optab, movmisalign_optab, storent_optab, neg_optab,
4113 negv_optab, abs_optab, absv_optab, one_cmpl_optab, bswap_optab,
4114 ffs_optab, clz_optab, ctz_optab, clrsb_optab, popcount_optab,
4115 parity_optab, sqrt_optab, sincos_optab, sin_optab, asin_optab,
4116 cos_optab, acos_optab, exp_optab, exp10_optab, exp2_optab, expm1_optab,
4117 ldexp_optab, scalb_optab, significand_optab, logb_optab, ilogb_optab,
4118 log_optab, log10_optab, log2_optab, log1p_optab, floor_optab,
4119 ceil_optab, btrunc_optab, round_optab, nearbyint_optab, rint_optab,
4120 tan_optab, atan_optab, copysign_optab, signbit_optab, isinf_optab,
4121 cmp_optab, ucmp_optab, eq_optab, ne_optab, gt_optab, ge_optab,
4122 lt_optab, le_optab, unord_optab, strlen_optab, cbranch_optab,
4123 cmov_optab, cstore_optab, ctrap_optab, push_optab, addcc_optab,
4124 reduc_smax_optab, reduc_umax_optab, reduc_smin_optab, reduc_umin_optab,
4125 reduc_splus_optab, reduc_uplus_optab, ssum_widen_optab,
4126 usum_widen_optab, sdot_prod_optab, udot_prod_optab, vec_set_optab,
4127 vec_extract_optab, vec_init_optab, vec_shl_optab, vec_shr_optab,
4128 vec_realign_load_optab, vec_widen_umult_hi_optab,
4129 vec_widen_umult_lo_optab, vec_widen_smult_hi_optab,
4130 vec_widen_smult_lo_optab, vec_widen_umult_even_optab,
4131 vec_widen_umult_odd_optab, vec_widen_smult_even_optab,
4132 vec_widen_smult_odd_optab, vec_widen_ushiftl_hi_optab,
4133 vec_widen_ushiftl_lo_optab, vec_widen_sshiftl_hi_optab,
4134 vec_widen_sshiftl_lo_optab, vec_unpacks_hi_optab, vec_unpacks_lo_optab,
4135 vec_unpacku_hi_optab, vec_unpacku_lo_optab, vec_unpacks_float_hi_optab,
4136 vec_unpacks_float_lo_optab, vec_unpacku_float_hi_optab,
4137 vec_unpacku_float_lo_optab, vec_pack_trunc_optab, vec_pack_ssat_optab,
4138 vec_pack_usat_optab, vec_pack_sfix_trunc_optab,
4139 vec_pack_ufix_trunc_optab, powi_optab, sync_compare_and_swap_optab,
4140 sync_lock_test_and_set_optab, sync_old_add_optab, sync_old_sub_optab,
4141 sync_old_ior_optab, sync_old_and_optab, sync_old_xor_optab,
4142 sync_old_nand_optab, sync_new_add_optab, sync_new_sub_optab,
4143 sync_new_ior_optab, sync_new_and_optab, sync_new_xor_optab,
4144 sync_new_nand_optab, sext_optab, zext_optab, trunc_optab, sfix_optab,
4145 ufix_optab, sfixtrunc_optab, ufixtrunc_optab, sfloat_optab,
4146 ufloat_optab, lrint_optab, lround_optab, lfloor_optab, lceil_optab,
4147 fract_optab, fractuns_optab, satfract_optab, satfractuns_optab,
4148 vec_load_lanes_optab, vec_store_lanes_optab, vcond_optab, vcondu_optab,
4149 movcc_optab, reload_in_optab, reload_out_optab, movmem_optab,
4150 setmem_optab, cmpstr_optab, cmpstrn_optab, cmpmem_optab,
4151 sync_lock_release_optab, sync_add_optab, sync_sub_optab,
4152 sync_ior_optab, sync_and_optab, sync_xor_optab, sync_nand_optab,
4153 atomic_exchange_optab, atomic_compare_and_swap_optab,
4154 atomic_load_optab, atomic_store_optab, atomic_add_fetch_optab,
4155 atomic_sub_fetch_optab, atomic_and_fetch_optab,
4156 atomic_nand_fetch_optab, atomic_xor_fetch_optab, atomic_or_fetch_optab,
4157 atomic_fetch_add_optab, atomic_fetch_sub_optab, atomic_fetch_and_optab,
4158 atomic_fetch_nand_optab, atomic_fetch_xor_optab, atomic_fetch_or_optab,
4159 atomic_add_optab, atomic_sub_optab, atomic_and_optab,
4160 atomic_nand_optab, atomic_xor_optab, atomic_or_optab,
4161 atomic_always_lock_free_optab, atomic_is_lock_free_optab,
4162 atomic_thread_fence_optab, atomic_signal_fence_optab,
4163 vec_perm_optab, vec_perm_const_optab): Likewise.
4164 (struct target_optabs): Remove x_optab_table, x_convert_optab_table,
4165 and x_direct_optab_table members; add pat_enable.
4166 (optab_table, convert_optab_table, direct_optab_table): Remove.
4167 (optab_handler): Use raw_optab_handler.
4168 (widening_optab_handler, convert_optab_handler): Likewise.
4169 (set_optab_handler, set_widening_optab_handler): Remove.
4170 (set_convert_optab_handler, set_direct_optab_handler): Remove.
4171 (direct_optab_handler): Defer to optab_handler.
4172 * rtl.h (NON_GENERATOR_NUM_RTX_CODE): New.
4173
4174 2012-07-24 Jason Merrill <jason@redhat.com>
4175
4176 * bitmap.c (bitmap_descriptor): Adjust order of parameters to
4177 match MEM_STAT_DECL.
4178 * statistics.h (ALONE_FINAL_MEM_STAT_DECL): Correct typo.
4179
4180 2012-07-24 Richard Henderson <rth@redhat.com>
4181
4182 * optabs.h (struct optab_d): Rename code member to code_.
4183 (struct convert_optab_h): Likewise.
4184 (code_to_optab_): Rename from code_to_optab.
4185 (code_to_optab, optab_to_code): New.
4186 * dojump.c (do_compare_rtx_and_jump): Use code_to_optab.
4187 * ifcvt.c (noce_emit_move_insn): Likewise.
4188 * optabs.c (simplify_expand_binop): Use optab_to_code.
4189 (expand_simple_binop, shift_optab_p, commutative_optab_p): Likewise.
4190 (avoid_expensive_constant, expand_binop_directly): Likewise.
4191 (expand_binop, expand_simple_unop, expand_unop_direct): Likewise.
4192 (expand_unop, prepare_float_lib_cmp, expand_fixed_convert): Likewise.
4193 (have_insn_for, debug_optab_libfuncs): Likewise.
4194 (init_optab, init_optabv, init_convert_optab): Update for optab
4195 member name change.
4196
4197 * libfuncs.h: Include optabs.h.
4198 * dwarf2out.c, lto-streamer.in.c: Don't include libfuncs.h.
4199 * Makefile.in (LIBFUNCS_H): Add OPTABS_H.
4200 (lto-streamer-in.o, dwarf2out.o): Update deps.
4201
4202 * optabs.h (unknown_optab): New.
4203 * builtins.c (interclass_mathfn_icode): Use it.
4204 * dojump.c (do_compare_rtx_and_jump): Likewise.
4205 * optabs.c (optab_for_tree_code, expand_binop): Likewise.
4206 * tree-vect-generic.c (add_rshift, expand_vector_divmod): Likewise.
4207 (expand_vector_operations_1): Likewise.
4208 * tree-vect-patterns.c (vect_recog_divmod_pattern): Likewise.
4209 * tree-vect-stmts.c (supportable_narrowing_operation): Likewise.
4210
4211 2012-07-24 Steven Bosscher <steven@gcc.gnu.org>
4212
4213 * alloc-pool.c (create_alloc_pool): Fix ENABLE_CHECKING check.
4214
4215 2012-07-24 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
4216
4217 PR target/54051
4218 * config/arm/arm.c (arm_print_operand_address): Remove superfluous
4219 printing of 0.
4220 * config/arm/neon.md ("neon_vld3_lane<mode>":VD): Remove alignment
4221 specifier.
4222 ("neon_vld3_lane<mode>":VMQ): Likewise.
4223 ("neon_vld3_dup<mode>":VDX): Likewise.
4224 ("neon_vst3_lane<mode>":VD): Likewise.
4225 ("neon_vst3_lane<mode>":VMQ): Likewise.
4226
4227 2012-07-24 Roland McGrath <mcgrathr@google.com>
4228
4229 * arm.c (arm_get_frame_offsets): Don't use fixed regs for
4230 stack alignment padding.
4231
4232 2012-07-24 Uros Bizjak <ubizjak@gmail.com>
4233
4234 PR target/53961
4235 * config/i386/i386.c (ix86_legitimate_address_p): Move check for
4236 negative constant address for TARGET_X32 ...
4237 (ix86_decompose_address): ... here. Reject constant addresses
4238 that don't satisfy x86_64_immediate_operand predicate.
4239
4240 2012-07-24 Julian Brown <julian@codesourcery.com>
4241
4242 * doc/sourcebuild.texi (arm_hf_eabi): Document effective-target check.
4243
4244 2012-07-24 Steven Bosscher <steven@gcc.gnu.org>
4245
4246 * sbitmap.h (SBITMAP_ELT_BITS): Use "1u" trick as for BITMAP_WORD_BITS.
4247 Move test to check that there is a popcount function for the the number
4248 of bits in SBITMAP_ELT_BITS to sbitmap.c.
4249 * sbitmap.c: Test SBITMAP_ELT_BITS, not HOST_BITS_PER_WIDEST_FAST_INT.
4250 MEM_STAT_INFO): Define in terms of their ALONE counterparts.
4251
4252 * configure.ac (GATHER_STATISTICS): Always define, non-zero if enabled.
4253 * configure: Regenerate.
4254 * statistics.h (GATHER_STATISTICS): Error out if it is not defined.
4255 (GCC_MEM_STAT_ARGUMENTS): New define.
4256 (ALONE_MEM_STAT_DECL): Define in terms of GCC_MEM_STAT_ARGUMENTS.
4257 (ALONE_FINAL_MEM_STAT_DECL, ALONE_FINAL_PASS_MEM_STAT): New defines.
4258 (MEM_STAT_DECL, FINAL_MEM_STAT_DECL, PASS_MEM_STAT,
4259 FINAL_PASS_MEM_STAT): Define.
4260 * ggc-internal.h (ggc_record_overhead): Use FINAL_MEM_STAT_DECL.
4261 * ggc.h (ggc_record_overhead, ggc_free_overhead,
4262 ggc_prune_overhead_list): Remove internal prototypes, they are defined
4263 already in ggc-internal.h.
4264 * ggc-common.c (struct loc_descriptor): Remove #ifdef GATHER_STATISTICS
4265 wrappers.
4266 (add_statistics): Likewise.
4267 (dump_ggc_loc_statistics): Likewise. Return if GATHER_STATISTICS is 0.
4268 * ggc-zone.c (struct page_entry): Remove #ifdef GATHER_STATISTICS
4269 wrappers around "survived" and "stats" members.
4270 (alloc_large_page): Always initialize survived.
4271 (ggc_internal_alloc_zone_stat): Likewise.
4272 Remove #ifdef GATHER_STATISTICS wrappers. Record overhead if
4273 GATHER_STATISTICS is non-0.
4274 (ggc_free): Convert #ifdef GATHER_STATISTICS to if-code.
4275 (sweep_pages): Always increase survived.
4276 (ggc_collect_1): Convert #ifdef GATHER_STATISTICS to if-code.
4277 (calculate_average_page_survival): Always define.
4278 (ggc_collect): Convert #ifdef GATHER_STATISTICS to if-code.
4279 (ggc_print_statistics): Likewise.
4280 (ggc_pch_read): Likewise.
4281 * ggc-page.c (struct globals): Always define "stats" member.
4282 (ggc_internal_alloc_stat): Convert #ifdef GATHER_STATISTICS to if-code.
4283 (ggc_free): Likewise.
4284 (ggc_collec): Likewise.
4285 (ggc_print_statistics): Likewise.
4286 * bitmap.h (struct bitmap_head_def): Always define "desc" member.
4287 (bitmap_initialize_stat): Convert #ifdef GATHER_STATISTICS to if-code.
4288 * gimple.h (enum gimple_alloc_kind): Always define.
4289 (gimple_alloc_kind): Likewise.
4290 * tree-flow.h (phinodes_print_statistics): Always define.
4291 (ssanames_print_statistics): Likewise.
4292 * vec.h (vec_heap_free): Always define.
4293 (VEC_stack_alloc): Define if GATHER_STATISTICS is non-0.
4294 * alloc-pool.c (alloc_pool_descriptor): Always define.
4295 (create_alloc_pool): Convert #ifdef GATHER_STATISTICS to if-code.
4296 (empty_alloc_pool): Likewise.
4297 (pool_alloc): Likewise.
4298 (pool_free): Likewise.
4299 (dump_alloc_pool_statistics): Likewise.
4300 (print_statistics): Always define.
4301 * bitmap.c (struct bitmap_descriptor): Always define.
4302 (bitmap_register): Pass ALONE_FINAL_PASS_MEM_STAT.
4303 (register_overhead): Always define.
4304 (bitmap_element_free): Convert #ifdef GATHER_STATISTICS to if-code.
4305 (bitmap_element_allocate): Likewise.
4306 (bitmap_elt_clear_from): Likewise.
4307 (bitmap_obstack_alloc_stat): Likewise.
4308 (bitmap_gc_alloc_stat): Likewise.
4309 (bitmap_obstack_free): Likewise.
4310 (bitmap_find_bit): Likewise.
4311 (bitmap_ior_and_into): Likewise.
4312 (bitmap_print): Likewise.
4313 (dump_bitmap_statistics): Likewise. Return if GATHER_STATISTICS is 0.
4314 * gimple.c (gimple_alloc_counts, gimple_alloc_sizes): Always define.
4315 (gimple_alloc_kind_names): Likewise.
4316 (gimple_alloc_stat): Convert #ifdef GATHER_STATISTICS to if-code.
4317 (dump_gimple_statistics): Likewise. Return if GATHER_STATISTICS is 0.
4318 * rtl.c (rtx_alloc_counts, rtx_alloc_sizes, rtvec_alloc_counts,
4319 rtvec_alloc_sizes): Always define.
4320 (rvec_alloc): Convert #ifdef GATHER_STATISTICS to if-code.
4321 (rtx_alloc_stat): Likewise.
4322 (dump_rtx_statistics): Likewise. Return if GATHER_STATISTICS is 0.
4323 * tree.c (_obstack_allocated_p, tree_code_counts, tree_node_counts,
4324 tree_node_sizes, tree_node_kind_names): Always define.
4325 (record_node_allocation_statistics): Convert #ifdef GATHER_STATISTICS
4326 to if-code.
4327 (type_hash_canon): Likewise.
4328 (dump_tree_statistics): Likewise.
4329 * tree-ssanames.c (ssa_name_nodes_reused, ssa_name_nodes_created):
4330 Always define.
4331 (ssanames_print_statistics): Likewise.
4332 (make_ssa_name_fn): Convert #ifdef GATHER_STATISTICS to if-code.
4333 * tree-phinodes.c (phi_nodes_reused, phi_nodes_created): Always define.
4334 (phinodes_print_statistics): Likewise.
4335 (allocate_phi_node): Convert #ifdef GATHER_STATISTICS to if-code.
4336 * vec.c (struct vec_descriptor): Always define.
4337 (hash_descriptor, eq_descriptor, ptr_hash_entry, hash_ptr, eq_ptr,
4338 vec_descriptor, rester_overhead, free_overhead): Likewise.
4339 (cmp_statistic): Likewise.
4340 (vec_heap_free): Convert #ifdef GATHER_STATISTICS to if-code.
4341 (vec_heap_o_reserve_1): Likewise.
4342 (dump_vec_loc_statistics): Likewise.
4343
4344 2012-07-24 Richard Guenther <rguenther@suse.de>
4345
4346 PR tree-optimization/53616
4347 * tree-loop-distribution.c (ldist_gen): Do not change
4348 partition ordering when merging partitions.
4349
4350 2012-07-24 Alan Modra <amodra@gmail.com>
4351
4352 PR target/53914
4353 PR target/54009
4354 * config/rs6000/constraints.md (Y): Use mem_operand_gpr.
4355 * config/rs6000/predicates.md (word_offset_memref_operand): Delete.
4356 Adjust all rs6000_legitimate_offset_address_p calls.
4357 * config/rs6000/rs6000-protos.h (mem_operand_gpr): Declare.
4358 (rs6000_secondary_reload_gpr): Declare.
4359 (rs6000_legitimate_offset_address_p): Update prototype.
4360 (rs6000_offsettable_memref_p): Delete.
4361 (rs6000_secondary_reload_ppc64): Delete.
4362 * config/rs6000/rs6000.c (address_offset): New function.
4363 (mem_operand_gpr): Likewise.
4364 (rs6000_legitimate_offset_address_p): Add worst_case param. When
4365 not worst_case assume class of regs with least restrictive offsets.
4366 Adjust all calls.
4367 (legitimate_lo_sum_address_p): Simplify register mode tests.
4368 (rs6000_legitimize_address): Likewise. Assume best case offset
4369 addressing. Combine ELF and MACHO lo_sum code.
4370 (rs6000_mode_dependent_address): Correct offset addressing limits.
4371 (rs6000_offsettable_memref_p): Make static, add reg_mode param.
4372 Use reg_mode to help rs6000_legitimate_offset_address_p.
4373 (rs6000_secondary_reload): Use address_offset. Handle 32-bit multi
4374 gpr load/store when offset too large.
4375 (rs6000_secondary_reload_gpr): Renamed rs6000_secondary_reload_ppc64.
4376 (rs6000_split_multireg_move): Adjust rs6000_offsettable_memref_p calls.
4377 * config/rs6000/rs6000.md (movdf_hardfloat32): Use 'Y' constraint
4378 for gpr load/store. Order alternatives as r->Y,Y->r,r->r and
4379 d->m,m->d,d->d. Correct size of gpr load/store.
4380 (movdf_softfloat32): Use 'Y' constraint for gpr load/store. Order
4381 alternatives.
4382 (movti_ppc64): Likewise.
4383 (movdi_internal32): Likewise. Also disparage fprs.
4384 (movdi_mfpgpr, movdi_internal64): Likewise.
4385 (movtf_internal): Use 'm' for fpr load/store. Order alternatives.
4386 (movtf_softfloat): Order alternatives.
4387 (extenddftf2_internal): Use 'm' and 'Y' for store.
4388 (movti_power, movti_string): Use 'Y' for gpr load/store. Order.
4389 (stack_protect_setdi, stack_protect_testdi): Likewise.
4390 (movdf_hardfloat64_mfpgpr, movdf_hardfloat64): Order alternatives.
4391 (movdf_softfloat64): Likewise.
4392 (reload_<mode>_store): Adjust reload_di_store to provide
4393 reload_si_store as well.
4394 (reload_<mode>_load): Likewise.
4395
4396 2012-07-23 Oleg Endo <olegendo@gcc.gnu.org>
4397
4398 PR target/51244
4399 * config/sh/predicates.md (general_movsrc_operand,
4400 general_movdst_operand): Reject T_REG.
4401 * config/sh/sh.md (*extendqisi2_compact_reg, *extendhisi2_compact_reg,
4402 movsi_i, movsi_ie, movsi_i_lowpart, *movqi_reg_reg, *movhi_reg_reg):
4403 Remove T_REG alternatives.
4404 (*negtstsi): New insn.
4405
4406 2012-07-23 Oleg Endo <olegendo@gcc.gnu.org>
4407
4408 PR target/53511
4409 * config/sh/sh.md (mulsf3_ie): Delete.
4410 (mulsf3_i4): Rename to mulsf3_i.
4411 (mulsf3): Emit mulsf3_i insn.
4412
4413 2012-07-23 Oleg Endo <olegendo@gcc.gnu.org>
4414
4415 * config/sh/sh.md (addc1, subc1): Delete.
4416 (adddi3_compact): Use addc instead of addc1.
4417 (subdi3_compact): Use subc instead of subc1.
4418
4419 2012-07-23 Uros Bizjak <ubizjak@gmail.com>
4420
4421 * config/i386/i386-protos.h (ix86_lea_outperforms): Remove prototype.
4422 * config/i386/i386.c (ix86_lea_outperforms): Make static. Make
4423 split_cost argument signed.
4424 (ix86_avoid_lea_for_add): Cleanup.
4425 (ix86_use_lea_for_mov): Use INVALID_REGNUM instead of -1.
4426 (ix86_avoid_lea_for_addr): Ditto. Make split_cost signed.
4427 Use gen_lowpart instead of gen_rtx_SUBREG. Cleanup.
4428
4429 2012-07-23 Ulrich Weigand <ulrich.weigand@linaro.org>
4430
4431 * config/arm/arm.c (arm_reorg): Ensure all insns are split.
4432
4433 2012-07-23 Uros Bizjak <ubizjak@gmail.com>
4434
4435 PR target/53961
4436 * config/i386/i386.md (*lea): Add asserts to detect invalid addresses.
4437 * config/i386/i386.c (ix86_print_operand_address): Ditto.
4438 (ix86_decompose_address): Allow (zero_extend:DI (subreg:SI (...)))
4439 addresses. Prevent zero extensions of CONST_INT operands.
4440
4441 2012-07-23 Steven Bosscher <steven@gcc.gnu.org>
4442
4443 * sbitmap.h (struct int_list): Remove.
4444 (sbitmap_intersect_of_predsucc, sbitmap_union_of_predsucc):
4445 Remove prototypes of non-existing function.
4446 (sbitmap_intersect_of_predecessors, sbitmap_intersect_of_successors,
4447 sbitmap_union_of_predecessors, sbitmap_union_of_successors): Remove
4448 unused defines.
4449 (sbitmap_intersection_of_succs, sbitmap_intersection_of_preds,
4450 sbitmap_union_of_succs, sbitmap_union_of_preds): Move prototypes to...
4451 * basic-block.h: ... here.
4452 * sbitmap.c: Do not include basic-block.h.
4453 (sbitmap_intersection_of_succs, sbitmap_intersection_of_preds,
4454 sbitmap_union_of_succs, sbitmap_union_of_preds): Move functions to...
4455 * cfganal.c: ... here.
4456 * bt-load.c (compute_out, link_btr_uses): Update for above changes.
4457 * gcse.c (compute_code_hoist_vbeinout): Likewise.
4458 * lcm.c (compute_antinout_edge, compute_available): Likewise.
4459 * Makefile.in: Fix sbitmap.o dependencies.
4460
4461 2012-07-23 Jan-Benedict Glaw <jbglaw@lug-owl.de>
4462 Nick Clifton <nickc@redhat.com>
4463
4464 * config/frv/frv-protos.h (frv_ifcvt_machdep_init): Prototype.
4465 * config/frv/frv.c (frv_ifcvt_machdep_init): Change type of
4466 (unused) parameter to void *.
4467
4468 2012-07-23 Richard Guenther <rguenther@suse.de>
4469
4470 * tree-ssa-alias.c (dump_alias_info): Walk over local decls
4471 instead of referenced vars.
4472
4473 2012-07-23 Steven Bosscher <steven@gcc.gnu.org>
4474
4475 * coverage.c: Refer to "notes file" instead of "graph file"
4476 in all comments. Explain history of bbg prefix.
4477 * gcov-io.h: Likewise.
4478 * gcov.c: Likewise.
4479 (find_source): Likewise in fnotice.
4480 (read_graph_file): Likewise.
4481 (read_count_file): Likewise.
4482 * doc/gcov.texi: Document -fprofile-dir flag. Add "notes file"
4483 and "data file" explicitly in the explanation of the files.
4484
4485 2012-07-22 Steven Bosscher <steven@gcc.gnu.org>
4486
4487 PR tree-optimization/53881
4488 * tree-cfg.c (group_case_labels_stmt): Look up the basic block
4489 for each label and compare them instead of labels.
4490
4491 2012-07-22 Steven Bosscher <steven@gcc.gnu.org>
4492
4493 * opts.c (common_handle_option): Do not set
4494 flag_value_profile_transformations for -fprofile-generate.
4495 * profile.c (instrument_values): Use COUNTER_FOR_HIST_TYPE.
4496 (BB_TO_GCOV_INDEX): Remove.
4497 (output_location): Don't use it.
4498 (branch_prob): Likewise. Don't fiddle with the index of
4499 ENTRY_BLOCK_PTR and EXIT_BLOCK_PTR. Use clear_aux_for_blocks.
4500 (find_spanning_tree):
4501 * gcov.c (struct function_info): Document that blocks 0 and 1
4502 are the entry resp. exit blocks in gcov, too, like in GCC itself.
4503 (solve_flow_graph): Use ENTRY_BLOCK and EXIT_BLOCK for special
4504 blocks identification.
4505 (output_lines): Likewise.
4506 * value-prof.c (gimple_value_profile_transformations): Do not
4507 test flag_value_profile_transformations again.
4508 (gimple_ic_transform): Take a gimple_stmt_iterator like all other
4509 transformation functions.
4510 (gimple_values_to_profile):
4511 Don't test flag_value_profile_transformations
4512 * tree-profile.c (tree_profiling): Assert that the cgraph is in
4513 the CGRAPH_STATE_IPA_SSA state.
4514 Do not set, or look at, after_tree_profile.
4515 * function.h (struct function): Remove after_tree_profile bit.
4516 * omp-low.c (expand_omp_taskreg): Don't set after_tree_profile.
4517 * tree-inline.c (initialize_cfun): Don't copy it.
4518 * lto-streamer-out.c (output_struct_function_base): Don't stream it.
4519 * lto-streamer-in.c (input_struct_function_base): Likewise.
4520
4521 2012-07-22 Oleg Endo <olegendo@gcc.gnu.org>
4522
4523 * config/sh/sh.h (TARGET_DYNSHIFT): New macro.
4524 (SH_DYNAMIC_SHIFT_COST): Use it.
4525 * config/sh/sh.c (expand_ashiftrt, shl_sext_kind): Likewise.
4526 (sh_dynamicalize_shift_p): Add TARGET_DYNSHIFT condition.
4527 Add sanity check for input value. Add function description.
4528 * config/sh/sh.md (ashlsi3, ashlsi3_std, ashrsi3_d, lshrsi3,
4529 lshrsi3_d): Use TARGET_DYNSHIFT.
4530
4531 2012-07-22 Oleg Endo <olegendo@gcc.gnu.org>
4532
4533 * config/sh/sh.md (negc): Delete expander.
4534 (*negc): Rename insn to negc.
4535
4536 2012-07-22 Uros Bizjak <ubizjak@gmail.com>
4537
4538 PR target/53961
4539 * config/i386/i386.md (*lea): New insn pattern.
4540 (*lea_1): Remove.
4541 (*lea<mode>_2): Ditto.
4542 (*lea_{3,4,5,6}_zext): Ditto.
4543 * config/i386/predicates.md (lea_address_operand): Do not reject
4544 zero-extended address operands.
4545 * config/i386/constraints.md (j): Remove address constraint.
4546 * config/i386/i386.c (ix86_decompose_address): Allow SImode subreg
4547 of an address.
4548 (ix86_print_operand_address): Handle SImode subreg of an address.
4549 (ix86_avoid_lea_for_addr): Reject zero-extended addresses for now.
4550
4551 2012-07-22 Hans-Peter Nilsson <hp@axis.com>
4552
4553 Emit executable-stack note correctly for CRIS targets.
4554 * config/cris/cris.c (cris_file_end): New function.
4555 (TARGET_ASM_FILE_END): Define.
4556
4557 2012-07-22 Chung-Lin Tang <cltang@codesourcery.com>
4558 Maxim Kuvyrkov <maxim@codesourcery.com>
4559 NetLogic Microsystems Inc.
4560
4561 * config/mips/mips.c (mips_issue_rate): Handle XLP.
4562 * config/mips/mips.md: Include xlp.md.
4563 * config/mips/xlp.md: New file.
4564
4565 2012-07-21 Steven Bosscher <steven@gcc.gnu.org>
4566
4567 PR gcov-profile/32543
4568 * profile.c (branch_prob): Update total_num_edges_instrumented and
4569 report the number of edges to instrument.
4570
4571 2012-07-21 Oleg Endo <olegendo@gcc.gnu.org>
4572
4573 * config/sh/sh.md: Correct comment regarding clrt and sett insns.
4574
4575 2012-07-21 Andrew Pinski <apinski@cavium.com>
4576
4577 * config/mips/mips.md (*popcountdi2_trunc): New pattern
4578 to handle popcount of a truncation.
4579
4580 2012-07-21 Andrew Pinski <apinski@cavium.com>
4581
4582 * config/mips/mips-protos.h (mips_expand_ext_as_unaligned_load):
4583 Add a bool argument.
4584 * config/mips/mips.c (mips_block_move_straight): Update call to
4585 mips_expand_ext_as_unaligned_load.
4586 (mips_expand_ext_as_unaligned_load): Add unsigned_p argument.
4587 Accept DImode dest when the width is that of SImode.
4588 * config/mips/mips.md (extv): Update call to
4589 mips_expand_ext_as_unaligned_load.
4590 (extzv): Likewise.
4591
4592 2012-07-21 Andrew Pinski <apinski@cavium.com>
4593
4594 * config/mips/mips.c (mips_get_unaligned_mem): Copy *op after calling
4595 adjust_address.
4596
4597 2012-07-20 Maxim Kuvyrkov <maxim@codesourcery.com>
4598
4599 * config/mips/mips.md (define_attr sync_*): Move before "type".
4600 (define_attr "type"): New values "atomic" and "syncloop".
4601 * config/mips/sync.md (atomic_exchange<mode>, atomic_fetch_add<mode>):
4602 Set "type" attribute.
4603 * config/mips/generic.md (generic_atomic, generic_syncloop):
4604 New reservations.
4605 * gcc/config/mips/10000.md, gcc/config/mips/20kc.md,
4606 * gcc/config/mips/24k.md, gcc/config/mips/4130.md,
4607 * gcc/config/mips/4k.md, gcc/config/mips/5400.md,
4608 * gcc/config/mips/5500.md, gcc/config/mips/5k.md,
4609 * gcc/config/mips/7000.md, gcc/config/mips/74k.md,
4610 * gcc/config/mips/9000.md, gcc/config/mips/loongson2ef.md,
4611 * gcc/config/mips/loongson3a.md, gcc/config/mips/octeon.md,
4612 * gcc/config/mips/sb1.md, gcc/config/mips/sr71k.md,
4613 * gcc/config/mips/xlr.md: Handle "atomic" and "syncloop" types.
4614
4615 2012-07-20 Oleg Endo <olegendo@gcc.gnu.org>
4616
4617 * config/sh/sh.md: Group and sort shift related patterns.
4618 (ashlsi3_n, *ashlhi3_n, lshrsi3_n): Remove length attributes.
4619
4620 2012-07-20 Hans-Peter Nilsson <hp@axis.com>
4621
4622 * config/cris/cris.c (cris_asm_output_ident): Remove unused
4623 local variables section_asm_op, size, buf.
4624
4625 2012-07-20 Pat Haugen <pthaugen@us.ibm.com>
4626 Steven Bosscher <steven@gcc.gnu.org>
4627
4628 * config/rs6000/power4.md (power4-store-update): Fix reservation.
4629 (power4-three): Likewise.
4630
4631 2012-07-20 Sameera Deshpande <sameera.deshpande@arm.com>
4632 Greta Yorsh <Greta.Yorsh@arm.com>
4633
4634 * config/arm/arm.c (arm_cortex_a15_tune): New tune.
4635 * config/arm/arm-cores.def (cortex-a15): Use it.
4636
4637 2012-07-20 Sameera Deshpande <sameera.deshpande@arm.com>
4638 Greta Yorsh <Greta.Yorsh@arm.com>
4639
4640 * config/arm/arm-protos.h (tune_params): Add prefer_ldrd_strd.
4641 * config/arm/arm.c (arm_slowmul_tune): Initialize it.
4642 (arm_fastmul_tune, arm_strongarm_tune): Likewise.
4643 (arm_xscale_tune, arm_9e_tune, arm_v6t2_tune): Likewise.
4644 (arm_cortex_tune, arm_cortex_a5_tune, arm_cortex_a9_tune): Likewise.
4645 (arm_fa726te_tune): Likewise.
4646
4647 2012-07-20 Richard Guenther <rguenther@suse.de>
4648
4649 * tree-dfa.c (collect_dfa_stats): Simplify.
4650 * tree-ssa-structalias.c (compute_may_aliases): Do not dump
4651 referenced vars.
4652 * cfgexpand.c (estimated_stack_frame_size): Walk over local
4653 decls instead of referenced vars.
4654 * tree-ssa.c (delete_tree_ssa): Simplify.
4655 * tree-tailcall.c (find_tail_calls): Walk over local decls
4656 instead of referenced vars.
4657 (add_virtual_phis): Remove.
4658 (tree_optimize_tail_calls_1): Instead mark the virtual operand
4659 for renaming.
4660
4661 2012-07-20 Steven Bosscher <steven@gcc.gnu.org>
4662
4663 * basic-block.h (BB_FLAGS_TO_PRESERVE): New define.
4664 (brief_dump_cfg): Update prototype to take flags argument.
4665 (check_bb_profile): Remove prototype.
4666 * tracer.c (tracer): Update brief_dump_cfg calls.
4667 * cfghooks.c (dump_bb): Do not pass TDF_COMMENT to dump_bb_info.
4668 Call dump_bb_info before and after the cfghook dump_bb. Terminate
4669 the dump with a newline.
4670 (dump_flow_info): Do not call check_bb_profile.
4671 * cfg.c (clear_bb_flags): Update using BB_FLAGS_TO_PRESERVE.
4672 (check_bb_profile): Make static. Take indent and flags arguments.
4673 (dump_bb_info): Always dump loop depth. With TDF_DETAILS, call
4674 check_bb_profile. Print one edge per line.
4675 (brief_dump_cfg): Take a flags argument, and filter out
4676 TDF_COMMENT and TDF_DETAILS.
4677 * pretty-print.c (pp_base_newline): Set pp_needs_newline to false.
4678 * gimple-pretty-print.c (dump_gimple_bb_header): Do not use
4679 dump_bb_info here, it is already called from dump_bb. Idem for
4680 check_bb_profile.
4681 (dump_gimple_bb_footer): Likewise.
4682 (gimple_dump_bb_buff): Call pp_flush after dump_gimple_stmt to
4683 avoid broken dumps for statement histograms.
4684 (gimple_dump_bb): Handle ENTRY_BLOCK and EXIT_BLOCK. Do
4685 not call pp_flush here, the buffer should be empty.
4686 * sched-rgn.c (debug_region): Pass TDF_BLOCKS to dump_bb.
4687 * sched-vis.c (debug_bb_slim): Likewise.
4688 * tree-cfg.c (remove_bb): Pass dump_flags to dump_bb.
4689 (gimple_debug_bb): Pass TDF_BLOCKS to dump_bb.
4690 (gimple_dump_cfg): Do brief_dump_cfg with TDF_COMMENT.
4691 (dump_function_to_file): Do not call check_bb_profile on
4692 ENTRY_BLOCK and EXIT_BLOCK, check_bb_profile doesn't handle them.
4693 Use dump_bb instead of gimple_dump_bb.
4694 (print_loops_bb): Use dump_bb instead of gimple_dump_bb.
4695 * passes.c (execute_function_dump): Always call print_rtl_with_bb
4696 for RTL dumps.
4697 * cfgrtl.c (print_rtl_with_bb): Handle printing without an up-to-date
4698 CFG. With TDF_BLOCKS and TDF_DETAILS, do DF dumps at the top and
4699 bottom of each basic block.
4700
4701 2012-07-20 Richard Guenther <rguenther@suse.de>
4702
4703 PR tree-optimization/54031
4704 * tree-ssa-ccp.c (get_value_from_alignment): Use
4705 get_pointer_alignment_1.
4706
4707 2012-07-20 Richard Guenther <rguenther@suse.de>
4708
4709 * tree-inline.c (add_local_variables): Remove check_var_ann
4710 parameter and dead code.
4711 (expand_call_inline): Adjust.
4712 (tree_function_versioning): Likewise.
4713
4714 2012-07-20 Jakub Jelinek <jakub@redhat.com>
4715
4716 PR c++/28656
4717 * tree-vrp.c (nonnull_arg_p): Handle all nonnull attributes instead
4718 of just the first one.
4719
4720 2012-07-20 Richard Guenther <rguenther@suse.de>
4721
4722 * builtins.c (get_object_alignment_2): Correct offset handling
4723 when using type alignment of a MEM_REF kind base.
4724
4725 2012-07-20 Kirill Yukhin <kirill.yukhin@intel.com>
4726
4727 PR target/53877
4728 * config/i386/lzcntintrin.h (_lzcnt_u32): New.
4729 (_lzcnt_u64): Ditto.
4730
4731 2012-07-19 Eric Botcazou <ebotcazou@adacore.com>
4732
4733 * config/sparc/sparc.md (adddi3_insn_sp32): Add earlyclobber.
4734
4735 2012-07-19 Eric Botcazou <ebotcazou@adacore.com>
4736
4737 * tree-ssa-forwprop.c (combine_conversions): Punt if the RHS of the
4738 defining statement is a SSA name that occurs in abnormal PHIs.
4739
4740 2012-07-19 Eric Botcazou <ebotcazou@adacore.com>
4741
4742 * gimple-fold.c (canonicalize_constructor_val): Strip only useless type
4743 conversions.
4744
4745 2012-07-19 Jakub Jelinek <jakub@redhat.com>
4746
4747 PR rtl-optimization/53942
4748 * function.c (assign_parm_setup_reg): Avoid zero/sign extension
4749 directly from likely spilled non-fixed hard registers, move them
4750 to pseudo first.
4751
4752 2012-07-19 Steve Ellcey <sellcey@mips.com>
4753
4754 * config/mips/mips.c (mips_set_mips16_mode): Clear SYNCI_MASK in
4755 MIPS16 mode.
4756
4757 2012-07-19 Jason Merrill <jason@redhat.com>
4758
4759 PR debug/53235
4760 * dwarf2out.c (get_die_parent): New.
4761 (generate_type_signature): Use it.
4762
4763 2012-07-19 Richard Henderson <rth@redhat.com>
4764
4765 * config/ia64/vect.md (smulv4hi3_highpart): New.
4766 (umulv4hi3_highpart): New.
4767 (vec_widen_smult_even_v4hi): Rename from pmpy2_even.
4768 (vec_widen_smult_odd_v4hi): Rename from pmpy2_odd.
4769 (udot_prodv8qi, sdot_prodv8qi): Remove.
4770 (sdot_prodv4hi, udot_prodv4hi): Remove.
4771 * config/ia64/ia64.c (ia64_expand_dot_prod_v8qi): Remove.
4772 * config/ia64/ia64-protos.h: Update.
4773
4774 * tree-vect-patterns.c (vect_recog_divmod_pattern): Do not require
4775 vectors larger than UNITS_PER_WORD.
4776
4777 * expr.c (store_constructor): Initialize icode with CODE_FOR_nothing.
4778 * tree-vect-stmts.c (vectorizable_operation): Use LAST_INSN_CODE for
4779 dummy != CODE_FOR_nothing value.
4780
4781 2012-07-19 Uros Bizjak <ubizjak@gmail.com>
4782
4783 * doc/tm.texi.in (MODE_AFTER): Add entity as the first macro argument.
4784 * doc/tm.texi: Regenerate.
4785 * mode-switching.c (optimize_mode_switching): Update MODE_AFTER call.
4786 * config/sh/sh.h (MODE_AFTER): Update.
4787 * config/epiphany/epiphany.h (MODE_AFTER): Update.
4788
4789 2012-07-19 Jakub Jelinek <jakub@redhat.com>
4790
4791 PR middle-end/54017
4792 * tree-cfgcleanup.c (cleanup_omp_return): Remove.
4793 (cleanup_tree_cfg_bb): Don't call it.
4794 * omp-low.c (expand_omp_sections): Fix up the !exit_reachable case
4795 handling.
4796
4797 2012-07-19 Christian Bruel <christian.bruel@st.com>
4798
4799 PR target/54029
4800 * config/sh/sh.c (gen_far_branch): Set JUMP_LABEL for return jumps.
4801
4802 2012-07-19 Richard Guenther <rguenther@suse.de>
4803 Eric Botcazou <ebotcazou@adacore.com>
4804
4805 * tree-ssa-ccp.c (valid_lattice_transition): Clarify comment
4806 about transition from invariant to known bits.
4807 (likely_value): Addresses with UNDEFINED components are UNDEFINED.
4808
4809 2012-07-19 Richard Guenther <rguenther@suse.de>
4810
4811 PR tree-optimization/53970
4812 * tree-vect-data-refs.c (not_size_aligned): Avoid sign-compare warning.
4813
4814 2012-07-19 Tristan Gingold <gingold@adacore.com>
4815 Richard Henderson <rth@redhat.com>
4816
4817 * opts.c (finish_options): Handle UI_SEH.
4818 * expr.c (build_personality_function): Handle UI_SEH.
4819 * dwarf2out.c (dwarf2out_begin_prologue): Handle UI_SEH.
4820 * coretypes.h (unwind_info_type): Add UI_SEH.
4821 * config/i386/winnt.c (i386_pe_seh_emit_except_personality):
4822 New function.
4823 (i386_pe_seh_init_sections): Likewise.
4824 * config/i386/cygming.h (TARGET_ASM_EMIT_EXCEPT_PERSONALITY): Define.
4825 (TARGET_ASM_INIT_SECTIONS): Define.
4826 * common/config/i386/i386-common.c (TARGET_EXCEPT_UNWIND_INFO): Define.
4827 (i386_except_unwind_info): New function.
4828
4829 2012-07-18 Maciej W. Rozycki <macro@codesourcery.com>
4830 Chao-ying Fu <fu@mips.com>
4831
4832 * config/mips/mips.opt (mmcu): New option.
4833 * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Define
4834 _mips_mcu when TARGET_MCU.
4835 (ASM_SPEC): Pass mcu options to the assembler.
4836 * doc/invoke.texi (MIPS Options): Document -mmcu and -mno-mcu.
4837
4838 2012-07-18 Ralf Corsépius <ralf.corsepius@rtems.org>
4839
4840 * config.gcc (v850-*-rtems*): New target.
4841 * config/v850/rtems.h: New.
4842 * config/v850/t-rtems: New.
4843
4844 2012-07-18 Bill Schmidt <wschmidt@linux.ibm.com>
4845
4846 * doc/invoke.texi: Add -fhoist-adjacent-loads and -ftree-slsr to list
4847 of flags controlling optimization; add -ftree-slsr to list of flags
4848 enabled by default at -O; add -fhoist-adjacent-loads to list of flags
4849 enabled by default at -O2; add -fvect-cost-model to list of flags
4850 enabled by default at -O3; document -fhoist-adjacent-loads and
4851 -ftree-slsr.
4852 * opts.c (default_option): Make -ftree-slsr default at -O1 and above.
4853 * gimple-ssa-strength-reduction.c (gate_strength_reduction): Use
4854 flag_tree_slsr.
4855 * common.opt: Add -ftree-slsr with flag_tree_slsr.
4856
4857 2012-07-18 Jie Zhang <jzhang918@gmail.com>
4858 Julian Brown <julian@codesourcery.com>
4859
4860 * config/arm/arm.c (arm_rtx_costs_1): Adjust cost for CONST_VECTOR.
4861 (arm_size_rtx_costs): Likewise.
4862 (neon_valid_immediate): Add a case for double 0.0.
4863
4864 2012-07-18 Andrew Stubbs <ams@codesourcery.com>
4865 Mark Shinwell <shinwell@codesourcery.com>
4866 Julian Brown <julian@codesourcery.com>
4867
4868 * config/arm/vfp.md (*arm_movsi_vfp, *thumb2_movsi_vfp)
4869 (*movdi_vfp_cortexa8, *movsf_vfp, *thumb2_movsf_vfp)
4870 (*movdf_vfp, *thumb2_movdf_vfp, *movsfcc_vfp)
4871 (*thumb2_movsfcc_vfp, *movdfcc_vfp, *thumb2_movdfcc_vfp): Add
4872 neon_type.
4873 * config/arm/arm.md (neon_type): Update comment.
4874
4875 2012-07-18 Richard Guenther <rguenther@suse.de>
4876
4877 PR tree-optimization/53970
4878 * tree.h (contains_packed_reference): Remove.
4879 * expr.c (contains_packed_reference): Likewise.
4880 * tree-vect-data-refs.c (not_size_aligned): New function.
4881 (vector_alignment_reachable_p): Use it.
4882 (vect_supportable_dr_alignment): Likewise.
4883
4884 2012-07-18 Richard Guenther <rguenther@suse.de>
4885
4886 * tree.h (get_object_or_type_alignment): Remove.
4887 * builtins.c (get_object_alignment_2): New function copied from
4888 get_object_alignment_1. Take extra argument to indicate whether
4889 we take the address of EXP. Rework to use type alignment information
4890 if not, and return whether the result is an approximation or not.
4891 (get_object_alignment_1): Wrap around get_object_alignment_2.
4892 (get_pointer_alignment_1): Call get_object_alignment_2 indicating
4893 we take the address.
4894 (get_object_or_type_alignment): Remove.
4895 * expr.c (expand_assignment): Call get_object_alignment.
4896 (expand_expr_real_1): Likewise.
4897
4898 2012-07-18 Nick Clifton <nickc@redhat.com>
4899
4900 * doc/invoke.texi (ARM Options): Document -munaligned-access.
4901
4902 2012-07-18 Oleg Endo <olegendo@gcc.gnu.org>
4903
4904 * config/sh/sh.md (mulsidi3, umulsidi3): Remove constraints in
4905 expander. Use arith_reg_dest predicate.
4906 (rotldi3, rotrdi3): Remove constraints in expander.
4907 (adddi3_compact, subdi3_compact, mulsidi3_compact, umulsidi3_compact,
4908 ashlsi3_n, *ashlhi3_n, ashrsi2_16, ashrsi2_31, lshrsi3_n): Convert to
4909 insn_and_split.
4910
4911 2012-07-18 Oleg Endo <olegendo@gcc.gnu.org>
4912
4913 PR target/33135
4914 * config/sh/sh.opt (mieee): Use Var instead of Mask. Correct
4915 description.
4916 * config/sh/sh.c (sh_option_override): Do not change
4917 flag_finite_math_only. Set TARGET_IEEE to complement of
4918 flag_finite_math_only.
4919 * doc/invoke.texi (SH options): Add mno-ieee. Correct description
4920 of mieee and mno-ieee behavior.
4921
4922 2012-07-18 Steven Bosscher <steven@gcc.gnu.org>
4923
4924 * graphite-poly.c (print_pbb_body): Fixup dump_bb call.
4925
4926 2012-07-18 Steven Bosscher <steven@gcc.gnu.org>
4927
4928 * dumpfile.h (TDF_COMMENT): New define.
4929 * basic-block.h (EDGE_FALLTHRU, EDGE_ABNORMAL, EDGE_ABNORMAL_CALL,
4930 EDGE_EH, EDGE_FAKE, EDGE_DFS_BACK, EDGE_CAN_FALLTHRU,
4931 EDGE_IRREDUCIBLE_LOOP, EDGE_SIBCALL, EDGE_LOOP_EXIT, EDGE_TRUE_VALUE,
4932 EDGE_FALSE_VALUE, EDGE_EXECUTABLE, EDGE_CROSSING, EDGE_PRESERVE):
4933 Move to new file cfg-flags.h.
4934 (enum cfg_edge_flags): New enum, using cfg-flags.h.
4935 (EDGE_ALL_FLAGS): Compute value automatically.
4936 (BB_NEW, BB_REACHABLE, BB_IRREDUCIBLE_LOOP, BB_SUPERBLOCK,
4937 BB_DISABLE_SCHEDULE, BB_HOT_PARTITION, BB_COLD_PARTITION,
4938 BB_DUPLICATED, BB_NON_LOCAL_GOTO_TARGET, BB_RTL,
4939 BB_FORWARDER_BLOCK, BB_NONTHREADABLE_BLOCK, BB_MODIFIED, BB_VISITED,
4940 BB_IN_TRANSACTION): Move to new file cfg-flags.h.
4941 (enum bb_flags): Rename to cfg_bb_flags. Use cfg-flags.h.
4942 (BB_ALL_FLAGS): New, compute value automatically.
4943 (dump_bb_info): Update prototype.
4944 (dump_edge_info): Update prototype.
4945 * cfg-flags.h: New file.
4946 * cfg.c (dump_edge_info): Take flags argument. Be verbose only if
4947 TDF_DETAILS and not TDF_SLIM. Include cfg-flags.h for bitnames.
4948 Check that the edge flags are within the range of EDGE_ALL_FLAGS.
4949 (debug_bb): Update dump_bb call.
4950 (dump_cfg_bb_info): Remove.
4951 (dump_bb_info): New function. Use cfg-flags.h for bitnames.
4952 Adjust verbosity using TDF_* flags. Check that the basic block flags
4953 are within the range of BB_ALL_FLAGS.
4954 (brief_dump_cfg): Use dump_bb_info instead of dump_cfg_bb_info.
4955 * cfghooks.h (struct cfghooks): Update dump_bb hook, take a FILE
4956 first for consistency with other dump functions.
4957 (dump_bb): Update prototype accordingly.
4958 * cfghooks.c: Include dumpfile.h.
4959 (verify_flow_info): Update dump_edge_info calls.
4960 (dump_bb): Take a flags argument and pass it around.
4961 Use dump_bb_info to dump common information about a basic block.
4962 (dump_flow_info): Moved here from cfgrtl.c. Make IL agnostic.
4963 (debug_flow_info): Moved here from cfgrtl.c.
4964 * profile.c (is_edge_inconsistent): Update dump_bb calls.
4965 * loop-invariant.c (find_defs): Update print_rtl_with_bb call.
4966 * rtl.h (debug_bb_n_slim, debug_bb_slim, print_rtl_slim,
4967 print_rtl_slim_with_bb): Remove prototypes.
4968 (dump_insn_slim): Adjust prototype to take a const_rtx.
4969 (print_rtl_with_bb): Adjust prototype.
4970 * sched-rgn.c (debug_region): Use dump_bb instead of debug_bb_n_slim.
4971 * sched-vis.c (dump_insn_slim): Take a const_rtx.
4972 (debug_insn_slim): Prototype here near DEBUG_FUNCTION marker.
4973 (print_rtl_slim_with_bb): Remove.
4974 (print_rtl_slim): Rename to debug_rtl_slim. Print only insn info,
4975 not basic block info (print_rtl_with_bb with TDF_SLIM should be used
4976 for that. Prototype here near DEBUG_FUNCTION marker.
4977 (debug_bb_slim): Prototype here near DEBUG_FUNCTION marker.
4978 Use dump_bb.
4979 (debug_bb_n_slim): Prototype here near DEBUG_FUNCTION marker.
4980 * tree-cfg.c (gimple_can_merge_blocks_p): Use EDGE_COMPLEX.
4981 (remove_bb): Update dump_bb call.
4982 (gimple_debug_bb): Use dump_bb.
4983 (dump_function_to_file): Update gimple_dump_bb call.
4984 (print_loops_bb): Likewise.
4985 * tree-flow.h (gimple_dump_bb): Update prototype.
4986 * gimple-pretty-print.c (dump_bb_header): Rename to
4987 dump_gimple_bb_header. Write to a stream instead of a pretty
4988 printer. Use dump_bb_info to dump basic block info.
4989 (dump_bb_end): Rename to dump_gimple_bb_footer. Write to a
4990 stream instead of a pretty printer. Use dump_bb_info.
4991 (gimple_dump_bb_buff): Do not call dump_bb_header and dump_bb_end.
4992 (gimple_dump_bb): Do it here with dump_gimple_bb_header and
4993 dump_gimple_bb_footer.
4994 * cfgrtl.c (rtl_dump_bb): Update prototype. Only dump DF if the
4995 dump flags have TDF_DETAILS. Use dump_insn_slim if TDF_SLIM.
4996 (print_rtl_with_bb): Take a flags argument and pass it around.
4997 Use dump_insn_slim if TDF_SLIM.
4998 (dump_bb_info): Removed and re-incarnated in cfg.c.
4999 (dump_flow_info): Moved to cfghooks.c.
5000 (debug_flow_info): Moved to cfghooks.c.
5001 * passes.c (execute_function_dump): Unconditionally use
5002 print_rtl_with_bb for RTL dumps, now that it understands TDF_SLIM.
5003 * final.c (dump_basic_block_info): Update dump_edge_info calls.
5004 * tree-vrp.c (dump_asserts_for): Likewise.
5005 * ifcvt.c (if_convert): Unconditionally use print_rtl_with_bb.
5006 * tree-if-conv.c (if_convertible_bb_p): Don't look at
5007 EDGE_ABNORMAL_CALL, it has no meaning in the GIMPLE world.
5008 * trans-mem.c (make_tm_edge): Don't set EDGE_ABNORMAL_CALL,
5009 for the same reason.
5010 * config/rl78/rl78.c (rl78_reorg): Update print_rtl_with_bb calls.
5011
5012 2012-07-17 Richard Guenther <rguenther@suse.de>
5013
5014 * tree-vect-data-refs.c (vect_get_new_vect_var): Add referenced
5015 vars here, use create_tmp_reg where appropriate.
5016 (vect_create_addr_base_for_vector_ref): Do not add referenced
5017 vars here, use create_tmp_reg where appropriate.
5018 (vect_create_data_ref_ptr): Likewise.
5019 (vect_create_destination_var): Likewise.
5020 (vect_permute_store_chain): Likewise.
5021 (vect_permute_load_chain): Likewise.
5022 * tree-vect-loop-manip.c (vect_create_cond_for_align_checks):
5023 Likewise.
5024 * tree-vect-loop.c (get_initial_def_for_induction): Likewise.
5025 * tree-vect-patterns.c (vect_recog_temp_ssa_var): Likewise.
5026 (vect_handle_widen_op_by_const): Likewise.
5027 * tree-vect-stmts.c (vect_init_vector): Likewise.
5028 (vectorizable_load): Likewise.
5029
5030 2012-07-17 Tom de Vries <tom@codesourcery.com>
5031
5032 * hwint.c: Fix loop range.
5033
5034 2012-07-17 Tom de Vries <tom@codesourcery.com>
5035
5036 * double-int.h (double_int_popcount): New inline function.
5037 * hwint.c (popcount_hwi): New function.
5038 * hwint.h (popcount_hwi): Declare function. New inline function.
5039
5040 2012-07-17 Richard Henderson <rth@redhat.com>
5041
5042 * tree-vect-stmts.c (supportable_widening_operation): Remove decl
5043 parameters.
5044 (vectorizable_conversion): Update supportable_widening_operation call.
5045 * tree-vect-patterns.c (vect_recog_widen_mult_pattern): Likewise.
5046 (vect_recog_widen_shift_pattern): Likewise.
5047 * tree-vectorizer.h: Update decl.
5048
5049 2012-07-17 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
5050 Ulrich Weigand <ulrich.weigand@linaro.org>
5051
5052 * common/config/arm/arm-common.c (arm_option_optimization_table):
5053 Enable -fsched-pressure by default while optimizing.
5054 * config/arm/arm.c (arm_option_override): Use the alternate scheduler
5055 pressure algorithm by default.
5056
5057 2012-07-16 Oleg Endo <olegendo@gcc.gnu.org>
5058
5059 * config/sh/sh.h (CONST_OK_FOR_I06): Delete.
5060 (CONST_OK_FOR_I10): Move macro to ...
5061 * config/sh/sh.c: ... here.
5062 (sh_legitimate_index_p): Use satisfies_constraint_I06 instead of
5063 CONST_OK_FOR_I06.
5064
5065 2012-07-16 Oleg Endo <olegendo@gcc.gnu.org>
5066
5067 * config/sh/sh.md: Delete mov related define_peephole patterns.
5068
5069 2012-07-16 Jonathan Wakely <jwakely.gcc@gmail.com>
5070
5071 PR c++/53919
5072 * doc/install.texi (Installing GCC): Refer to instructions for
5073 released versions. Fix hyphenation.
5074
5075 2012-07-16 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
5076
5077 * config/spu/spu.c (targetm): Move to bottom of file.
5078 (spu_attribute_table): Likewise.
5079 (spu_option_override, spu_init_builtins, spu_builtin_decl,
5080 spu_scalar_mode_supported_p, spu_vector_mode_supported_p,
5081 spu_legitimate_address_p, spu_addr_space_legitimate_address_p,
5082 adjust_operand, get_pic_reg, need_to_save_reg, frame_emit_store,
5083 frame_emit_load, frame_emit_add_imm, emit_nop_for_insn,
5084 insn_clobbers_hbr, spu_emit_branch_hint, spu_emit_vector_compare,
5085 get_branch_target, spu_machine_dependent_reorg, spu_sched_issue_rate,
5086 spu_sched_variable_issue, spu_sched_adjust_cost, spu_sched_init_global,
5087 spu_sched_init, spu_sched_reorder, spu_handle_fndecl_attribute,
5088 spu_handle_vector_attribute, spu_pass_by_reference, spu_function_arg,
5089 spu_function_arg_advance, spu_build_builtin_va_list, spu_va_start,
5090 spu_gimplify_va_arg_expr, store_with_one_insn_p, reg_aligned_for_addr,
5091 spu_assemble_integer, spu_asm_globalize_label, spu_rtx_costs,
5092 spu_function_ok_for_sibcall, spu_init_libfuncs, spu_return_in_memory,
5093 spu_encode_section_info, spu_legitimize_address,
5094 spu_addr_space_legitimize_address, spu_builtin_mask_for_load,
5095 spu_builtin_vectorization_cost, spu_vector_alignment_reachable,
5096 spu_addr_space_pointer_mode, spu_addr_space_address_mode,
5097 spu_addr_space_subset_p, spu_addr_space_convert, spu_sms_res_mii,
5098 spu_section_type_flags, spu_select_section, spu_unique_section,
5099 spu_trampoline_init, spu_conditional_register_usage,
5100 spu_ref_may_alias_errno, spu_output_mi_thunk, spu_unwind_word_mode,
5101 spu_libgcc_cmp_return_mode, spu_libgcc_shift_count_mode,
5102 spu_setup_incoming_varargs): Remove prototypes.
5103 (spu_legitimize_address): Add "static" to definition.
5104
5105 2012-07-16 Jakub Jelinek <jakub@redhat.com>
5106
5107 * config/i386/rtmintrin.h (_xabort): Remove trailing semicolon.
5108
5109 2012-07-16 Ulrich Weigand <ulrich.weigand@linaro.org>
5110
5111 * tree-ssa-ccp.c (optimize_unreachable): Check gsi_end_p
5112 before calling gsi_stmt.
5113
5114 2012-07-16 Kirill Yukhin <kirill.yukhin@intel.com>
5115
5116 Revert
5117 2012-07-16 Sergey Melnikov <sergey.melnikov@intel.com>
5118
5119 * config/i386/i386.md (stack_protect_set): Disable the pattern
5120 for Android since Android libc (bionic) does not provide random
5121 value for stack protection guard at gs:0x14. Guard value
5122 will be provided from external symbol (default implementation).
5123 (stack_protect_set_<mode>): Likewise.
5124 (stack_protect_test): Likewise.
5125 (stack_protect_test_<mode>): Likewise.
5126
5127 2012-07-16 H.J. Lu <hongjiu.lu@intel.com>
5128
5129 PR middle-end/53959
5130 PR bootstrap/53963
5131 * gimple.c (gimple_types_compatible_p_1): Restore type attribute
5132 comparison.
5133
5134 2012-07-16 Bill Schmidt <wschmidt@linux.ibm.com>
5135
5136 * opts.c (default_option): Add -fvect-cost-model to default options
5137 at -O3 and above.
5138
5139 2012-07-16 Steven Bosscher <steven@gcc.gnu.org>
5140
5141 * graphite-clast-to-gimple.c, graphite-dependences.c,
5142 graphite-sese-to-poly.c: Include tree-pass.h instead of dumpfile.h
5143 for pass TODO flags.
5144 * Makefile.in: Fix dependencies.
5145
5146 2012-07-16 Steven Bosscher <steven@gcc.gnu.org>
5147
5148 * haifa-sched.c (init_before_recovery): Do not set EDGE_CAN_FALLTHRU.
5149 * cfgrtl.c (force_nonfallthru_and_redirect): Likewise.
5150
5151 * function.c (stack_protect_epilogue): Use expand_call to expand
5152 targetm.stack_protect_fail.
5153 * stmt.c (expand_expr_stmt): Remove now-unused function.
5154 * tree.h (expand_expr_stmt): Remove prototype.
5155 * doc/tm.texi.in (TARGET_STACK_PROTECT_FAIL): Document that this
5156 hook must return a CALL_EXPR.
5157 * doc/tm.texi: Regenerate.
5158
5159 * emit-rtl.c (emit_label_before): Do not allow the same label
5160 to be emitted twice.
5161 (emit_label_after): Likewise.
5162 (emit_label): Likewise.
5163
5164 * flags.h (TYPE_OVERFLOW_WRAPS, TYPE_OVERFLOW_UNDEFINED,
5165 TYPE_OVERFLOW_TRAPS, POINTER_TYPE_OVERFLOW_UNDEFINED): Move to tree.h.
5166 * tree.h (TYPE_OVERFLOW_WRAPS, TYPE_OVERFLOW_UNDEFINED,
5167 TYPE_OVERFLOW_TRAPS, POINTER_TYPE_OVERFLOW_UNDEFINED): New home.
5168
5169 2012-07-16 Steven Bosscher <steven@gcc.gnu.org>
5170
5171 * system.h (dump_file): Do not define.
5172 * tree-pass.h: Include dumpfile.h, which is a new file containing...
5173 (enum tree_dump_index, TDF_*, get_dump_file_name, dump_enabled_p,
5174 dump_initialized_p, dump_begin, dump_end, dump_node, dump_switch_p,
5175 dump_flag_name, dump_file, dump_flags, dump_file_name,
5176 get_dump_file_info, struct dump_file_info): all of this, moved to...
5177 * dumpfile.h: Here, new file.
5178 * tree-dump.h: Include dumpfile.h, but not tree-pass.h.
5179 (dump_stmt): Remove prototype for C++ specific function.
5180 (dump_enumerated_decls): Move prototype from here...
5181 * tree-flow.h (dump_enumerated_decls): ... to here.
5182 (get_ref_base_and_extent) Move prototype from here ...
5183 * tree.h (get_ref_base_and_extent) ... to here.
5184 * tree-ssa-live.c: Do not inclde tree-pretty-print.h, because
5185 gimple-pretty-print.h is enough. Do not include tree-dump.h,
5186 include timevar.h and dumpfile.h instead.
5187 (struct numbered_tree_d, compare_decls_by_uid,
5188 dump_enumerated_decls_push, dump_enumerated_decls): Move from here ...
5189 * tree-dfa.c:(struct numbered_tree_d, compare_decls_by_uid,
5190 dump_enumerated_decls_push, dump_enumerated_decls):... to here.
5191 Do not include timevar.h.
5192 * tree.c: Do not include timevar.h.
5193 * tree-cfg.c: Do not include langhooks.h, tree-pretty-print.h, and
5194 timevar.h.
5195 (dump_cfg_stats): Use current_function_name.
5196 (gimple_cfg2vcg): Likewise.
5197 (dump_function_to_file): Likewise.
5198 * df-scan.c: Do not include tree-pass.h and timevar.h.
5199 Include dumpfile.h.
5200 (df_entry_block_bitmap_verify, df_exit_block_bitmap_verify): Do not
5201 use print_current_pass.
5202 * df-problems.c: Include dumpfile.h.
5203 Always define REG_DEAD_DEBUGGING, avoid #ifdef code, because it
5204 leads to errors in the code not selected.
5205 (df_note_compute): Do not print_rtl_with_bb here. Fix compilation
5206 bug if REG_DEAD_DEBUGGING is not 0, get_insns is not available here.
5207 * lcm.c: Include dumpfile.h.
5208 Remove obsolete include of insn-attr.h.
5209 * dojump.c (do_compare_rtx_and_jump): Remove failure printing for
5210 missing probability notes.
5211 * stmt.c: Include dumpfile.h.
5212 (emit_case_decision_tree): Re-enable printing expand details only
5213 if TDF_DETAILS.
5214 * alias.c, auto-inc-dec.c, bb-reorder.c, caller-save.c, cfg.c,
5215 cfgcleanup.c, cfgexpand.c, cfgloop.c, cfgloopmanip.c, cgraph.c,
5216 cgraphclones.c, cgraphunit.c, combine.c, combine-stack-adj.c,
5217 coverage.c, cprop.c, cse.c, cselib.c, dbgcnt.c, dce.c, df-core.c,
5218 dse.c, dwarf2out.c, emit-rtl.c, except.c, expr.c, final.c,
5219 function.c, fwprop.c, gcse.c, gimple-fold.c,
5220 gimple-pretty-print.c, gimple-ssa-strength-reduction.c,
5221 gimplify.c, graphite-blocking.c, graphite-clast-to-gimple.c,
5222 graphite-dependences.c, graphite-interchange.c,
5223 graphite-optimize-isl.c, graphite-poly.c,
5224 graphite-sese-to-poly.c, haifa-sched.c, hw-doloop.c, ifcvt.c,
5225 ipa.c, ipa-cp.c, ipa-inline-analysis.c, ipa-inline.c,
5226 ipa-inline-transform.c, ipa-prop.c, ipa-pure-const.c,
5227 ipa-reference.c, ipa-split.c, ipa-utils.c, ira.c, ira-emit.c,
5228 jump.c, loop-doloop.c, loop-init.c, loop-invariant.c, loop-iv.c,
5229 loop-unroll.c, loop-unswitch.c, lower-subreg.c,
5230 lto-section-out.c, lto-streamer-in.c, matrix-reorg.c, mcf.c,
5231 mode-switching.c, modulo-sched.c, omega.c, omp-low.c, passes.c,
5232 plugin.c, postreload.c, postreload-gcse.c, predict.c, print-rtl.c,
5233 print-tree.c, profile.c, recog.c, ree.c, regcprop.c, reginfo.c,
5234 regmove.c, regrename.c, reg-stack.c, reload1.c, reorg.c,
5235 sched-rgn.c, sched-vis.c, sel-sched.c, sel-sched-ir.c,
5236 store-motion.c, tracer.c, trans-mem.c, tree-affine.c,
5237 tree-call-cdce.c, tree-cfgcleanup.c, tree-chrec.c,
5238 tree-data-ref.c, tree-diagnostic.c, tree-dump.c,
5239 tree-eh.c, tree-flow-inline.h, tree-if-conv.c, tree-into-ssa.c,
5240 tree-mudflap.c, tree-nrv.c, tree-object-size.c,
5241 tree-optimize.c, tree-outof-ssa.c, tree-predcom.c,
5242 tree-pretty-print.c, tree-profile.c, tree-scalar-evolution.c,
5243 tree-sra.c, tree-ssa-address.c, tree-ssa-alias.c, tree-ssa.c,
5244 tree-ssa-ccp.c, tree-ssa-coalesce.c, tree-ssa-copy.c,
5245 tree-ssa-copyrename.c,, tree-ssa-dce.c, tree-ssa-dom.c,
5246 tree-ssa-dse.c, tree-ssa-forwprop.c, tree-ssa-ifcombine.c,
5247 tree-ssa-loop.c, tree-ssa-loop-ch.c, tree-ssa-loop-im.c,
5248 tree-ssa-loop-ivcanon.c, tree-ssa-loop-ivopts.c,
5249 tree-ssa-loop-manip.c, tree-ssa-loop-niter.c,
5250 tree-ssa-loop-prefetch.c, tree-ssa-loop-unswitch.c,
5251 tree-ssa-math-opts.c, tree-ssa-operands.c, tree-ssa-phiopt.c,
5252 tree-ssa-phiprop.c, tree-ssa-pre.c, tree-ssa-propagate.c,
5253 tree-ssa-reassoc.c, tree-ssa-sccvn.c, tree-ssa-sink.c,
5254 tree-ssa-structalias.c, tree-ssa-tail-merge.c, tree-ssa-ter.c,
5255 tree-ssa-threadedge.c, tree-ssa-threadupdate.c,
5256 tree-ssa-uncprop.c, tree-ssa-uninit.c,
5257 tree-switch-conversion.c, tree-tailcall.c,
5258 tree-vect-data-refs.c, tree-vect-loop.c,
5259 tree-vect-loop-manip.c, tree-vectorizer.c,
5260 tree-vect-patterns.c, tree-vect-slp.c, tree-vect-stmts.c,
5261 tree-vrp.c, value-prof.c, var-tracking.c, web.c: Include tree-pass.h
5262 only if needed. If tree-pass.h is included, do not include timevar.h
5263 and dumpfile.h. If tree-pass.h is not included but dump_file, or
5264 dump_flags, or the TDF_* flags are used, include dumpfile.h.
5265 If gimple-pretty-print.h is included, don't include
5266 tree-pretty-print.h. Remove assorted unnecessary includes.
5267
5268 * config/mn10300/mn10300.c, config/c6x/c6x.c, config/ia64/ia64.c,
5269 config/arm/arm.c, config/bfin/bfin.c, config/frv/frv.c,
5270 config/spu/spu.c, config/mep/mep.c, config/i386/i386.c:
5271 Include dumpfile.h.
5272 * config/rl78/rl78.c: Include dumpfile.h instead of tree-pass.h.
5273 * arm/t-arm, avr/t-avr, i386/t-i386, ia64/t-ia64, mep/t-mep,
5274 spu/t-spu-elf: Fix dependencies.
5275
5276 2012-07-16 Dehao Chen <dehao@google.com>
5277
5278 Revert
5279 2012-07-10 Dehao Chen <dehao@google.com>
5280
5281 * tree.h (phi_arg_d): New field.
5282 * tree-flow-inline.h (gimple_phi_arg_block): New function.
5283 (gimple_phi_arg_block_from_edge): New function.
5284 (gimple_phi_arg_set_block): New function.
5285 (gimple_phi_arg_has_block): New function.
5286 (redirect_edge_var_map_block): New function.
5287 * tree-flow.h (_edge_var_map): New field.
5288 * tree-ssa-live.c (remove_unused_locals): Mark phi_arg's block as used.
5289 * tree-eh.c (cleanup_empty_eh_merge_phis): Add block debug info for
5290 redirect_edge_var_map_add.
5291 * tree-outof-ssa.c (_elim_graph): New field.
5292 (insert_partition_copy_on_edge): New parameter.
5293 (insert_value_copy_on_edge): New parameter.
5294 (insert_rtx_to_part_on_edge): New parameter.
5295 (insert_part_to_rtx_on_edge): New parameter.
5296 (elim_graph_add_edge): New parameter.
5297 (elim_graph_remove_succ_edge): New parameter.
5298 (FOR_EACH_ELIM_GRAPH_SUCC): New parameter.
5299 (FOR_EACH_ELIM_GRAPH_PRED): New parameter.
5300 (new_elim_graph): Add block debug info.
5301 (clear_elim_graph): Likewise.
5302 (delete_elim_graph): Likewise.
5303 (elim_graph_add_node): Likewise.
5304 (elim_graph_add_edge): Likewise.
5305 (elim_graph_remove_succ_edge): Likewise.
5306 (eliminate_build): Likewise.
5307 (elim_forward): Likewise.
5308 (elim_unvisited_predecessor): Likewise.
5309 (elim_backward): Likewise.
5310 (elim_create): Likewise.
5311 (eliminate_phi): Likewise.
5312 (insert_backedge_copies): Likewise.
5313 * tree-into-ssa.c (insert_phi_nodes_for): Add block debug info for
5314 add_phi_arg.
5315 (rewrite_add_phi_arguments): Likewise.
5316 * tree-ssa-loop-im.c (execute_sm_if_changed): Likewise.
5317 * tree-ssa-tail-merge.c (replace_block_by): Likewise.
5318 * tree-ssa-threadupdate.c (copy_phi_args): Likewise.
5319 * tree-loop-distribution.c (update_phis_for_loop_copy): Likewise.
5320 * tree-ssa-loop-manip.c (create_iv): Likewise.
5321 (add_exit_phis_edge): Likewise.
5322 (split_loop_exit_edge): Likewise.
5323 (copy_phi_node_args): Likewise.
5324 (tree_transform_and_unroll_loop): Likewise.
5325 * value-prof.c (gimple_ic): Likewise.
5326 (gimple_stringop_fixed_value): Likewise.
5327 * tree-tailcall.c (add_successor_phi_arg): Likewise.
5328 (eliminate_tail_call): Likewise.
5329 (create_tailcall_accumulator): Likewise.
5330 (tree_optimize_tail_calls_1): Likewise.
5331 * tree-phinodes.c (add_phi_arg): Likewise.
5332 (make_phi_node): Likewise.
5333 (resize_phi_node): Likewise.
5334 (remove_phi_arg_num): Likewise.
5335 * omp-low.c (expand_parallel_call): Likewise.
5336 (expand_omp_for_static_chunk): Likewise.
5337 * tree-vect-loop-manip.c (slpeel_update_phis_for_duplicate_loop):
5338 Likewise.
5339 (slpeel_update_phi_nodes_for_guard1): Likewise.
5340 (slpeel_update_phi_nodes_for_guard2): Likewise.
5341 (slpeel_tree_duplicate_loop_to_edge_cfg): Likewise.
5342 (set_prologue_iterations): Likewise.
5343 (slpeel_tree_peel_loop_to_edge): Likewise.
5344 (vect_loop_versioning): Likewise.
5345 * tree-parloops.c (create_phi_for_local_result): Likewise.
5346 (transform_to_exit_first_loop): Likewise.
5347 (create_parallel_loop): Likewise.
5348 * ipa-split.c (split_function): Likewise.
5349 * tree-vect-loop.c (get_initial_def_for_induction): Likewise.
5350 (vect_create_epilog_for_reduction): Likewise.
5351 * tree-vect-data-refs.c (vect_setup_realignment): Likewise.
5352 * graphite-scop-detection.c (canonicalize_loop_closed_ssa): Likewise.
5353 * tree-ssa-phiopt.c (cond_store_replacement): Likewise.
5354 (cond_if_else_store_replacement_1): Likewise.
5355 * tree-cfgcleanup.c (remove_forwarder_block): Likewise.
5356 (remove_forwarder_block_with_phi): Likewise.
5357 * tree-ssa-pre.c (insert_into_preds_of_block): Likewise.
5358 * tree-predcom.c (initialize_root_vars): Likewise.
5359 (initialize_root_vars_lm): Likewise.
5360 * sese.c (sese_add_exit_phis_edge): Likewise.
5361 * tree-ssa-dce.c (forward_edge_to_pdom): Likewise.
5362 * tree-ssa.c (flush_pending_stmts): Likewise.
5363 (redirect_edge_var_map_add): Likewise.
5364 (ssa_redirect_edge): Likewise.
5365 * gimple-streamer-in.c (input_phi): Likewise.
5366 * tree-vect-stmts.c (vectorizable_load): Likewise.
5367 * tree-inline.c (copy_phis_for_bb): Likewise.
5368 * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
5369 * tree-switch-conversion.c (fix_phi_nodes): Likewise.
5370 * tree-cfg.c (reinstall_phi_args): Likewise.
5371 (gimple_make_forwarder_block): Likewise.
5372 (add_phi_args_after_copy_edge): Likewise.
5373 (gimple_duplicate_sese_tail): Likewise.
5374
5375 2012-07-16 Sergey Melnikov <sergey.melnikov@intel.com>
5376
5377 * config/i386/i386.md (stack_protect_set): Disable the pattern
5378 for Android since Android libc (bionic) does not provide random
5379 value for stack protection guard at gs:0x14. Guard value
5380 will be provided from external symbol (default implementation).
5381 (stack_protect_set_<mode>): Likewise.
5382 (stack_protect_test): Likewise.
5383 (stack_protect_test_<mode>): Likewise.
5384
5385 2012-07-16 Hans-Peter Nilsson <hp@axis.com>
5386
5387 * config/cris/cris-protos.h (cris_legitimate_address_p): Declare.
5388 * config/cris/cris.h (CONSTANT_ADDRESS_P): Define in terms of
5389 CONSTANT_P and cris_legitimate_address_p.
5390 * config/cris/cris.c (cris_legitimate_address_p): Make non-static.
5391 (cris_preferred_reload_class): Don't return GENERAL_REGS as
5392 preferred to MOF_SRP_REGS.
5393
5394 * config/cris/cris.c (cris_init_libfuncs): Handle initialization
5395 of library functions for basic atomic compare-and-swap.
5396 * config/cris/cris.h (TARGET_ATOMICS_MAY_CALL_LIBFUNCS): New macro.
5397 * config/cris/cris.opt (munaligned-atomic-may-use-library): New option.
5398 * config/cris/sync.md ("atomic_fetch_<atomic_op_name><mode>")
5399 ("cris_atomic_fetch_<atomic_op_name><mode>_1")
5400 ("atomic_compare_and_swap<mode>")
5401 ("cris_atomic_compare_and_swap<mode>_1"): Make conditional on
5402 TARGET_ATOMICS_MAY_CALL_LIBFUNCS for sizes larger than byte.
5403 * config/cris/cris.c (cris_print_operand) <case 'P', 'q'>: New cases.
5404 * config/cris/sync.md (atomic_op_op_cnstr): New code_attr.
5405 (atomic_op_op_pred): Ditto.
5406 (atomic_op_mnem_pre_op2): Renamed from atomic_op_mnem_pre; to
5407 reflect the change to include %2 in expansion. All callers changed.
5408 (qm3): New mode_attr.
5409 ("atomic_fetch_<atomic_op_name><mode>"): Use <atomic_op_op_pred>
5410 as predicate for operand 2.
5411 ("cris_atomic_fetch_<atomic_op_name><mode>_1"): Update FIXME. Use
5412 "<atomic_op_op_pred>" "<atomic_op_op_cnstr>" for predicate and
5413 constraint for operand 2.
5414 ("atomic_compare_and_swap<mode>"): Add FIXME. Change predicate to
5415 nonmemory_operand for operand 3.
5416 ("cris_atomic_compare_and_swap<mode>_1"): Change operand 3 to
5417 exclude memory. Improve emitted sync code for v10 and v32. Use
5418 <qm3> instead of <m> for size designator for cmp.
5419 ("atomic_compare_and_swap<mode>"): Change predicate to
5420 nonmemory_operand for operand 3. Add FIXME.
5421 ("cris_atomic_compare_and_swap<mode>_1"): Change predicates and
5422 constraints for operand 3 to exclude memory.
5423 ("atomic_fetch_<atomic_op_name><mode>")
5424 ("atomic_compare_and_swap<mode>"): Gate expand_mem_thread_fence
5425 calls on result of call to need_atomic_barrier_p.
5426
5427 2012-07-15 Richard Sandiford <rdsandiford@googlemail.com>
5428
5429 * config/mips/mips.md (move_type): Replace mfhilo and mthilo
5430 with mflo and mtlo.
5431 (type): Split mfhilo into mfhi and mflo. Split mthilo into mthi
5432 and mtlo. Adjust move_type->type mapping.
5433 (may_clobber_hilo): Split mthilo into mthi and mtlo.
5434 (*movdi_32bit, *movdi_32bit_mips16, *movdi_64bit, *movdi_64bit_mips16)
5435 (*mov<mode>_internal, *mov<mode>_mips16, *movhi_internal)
5436 (*movhi_mips16, *movqi_internal, *movqi_mips16): Use mtlo and mflo
5437 instead of mthilo and mfhilo.
5438 (mfhi<GPR:mode>_<HILO:mode>): Use mfhi instead of mfhilo.
5439 (mthi<GPR:mode>_<HILO:mode>): Use mthi instead of mthilo.
5440 * config/mips/mips-dsp.md (mips_extr_w, mips_extr_r_w, mips_extr_rs_w)
5441 (mips_extr_s_h, mips_extp, mips_extpdp, mips_shilo, mips_mthlip):
5442 Use mflo instead of mfhilo.
5443 * config/mips/10000.md (r10k_arith): Split mthilo.
5444 (r10k_mfhi, r10k_mflo): Use mfhi and mflo directly.
5445 * config/mips/sb1.md (ir_sb1_mfhi, ir_sb1_mflo): Likewise.
5446 (ir_sb1_mthilo): Split mthilo into mthi and mtlo.
5447 * config/mips/20kc.md (r20kc_imthilo, r20kc_imfhilo): Split
5448 mthilo and mfhilo.
5449 * config/mips/24k.md (r24k_int_mfhilo, r24k_int_mthilo): Likewise.
5450 * config/mips/4130.md (vr4130_class, vr4130_mfhilo, vr4130_mthilo):
5451 Likewise.
5452 * config/mips/4k.md (r4k_int_mthilo, r4k_int_mfhilo): Likewise.
5453 * config/mips/5400.md (ir_vr54_hilo): Likewise.
5454 * config/mips/5500.md (ir_vr55_mthilo, ir_vr55_mfhilo): Likewise.
5455 * config/mips/5k.md (r5k_int_mthilo, r5k_int_mfhilo): Likewise.
5456 * config/mips/7000.md (rm7_mthilo, rm7_mfhilo): Likewise.
5457 * config/mips/74k.md (r74k_int_mfhilo, r74k_int_mthilo): Likewise.
5458 * config/mips/9000.md (rm9k_mfhilo, rm9k_mthilo): Likewise.
5459 * config/mips/generic.md (generic_hilo): Likewise.
5460 * config/mips/loongson2ef.md (ls2_alu): Likewise.
5461 * config/mips/loongson3a.md (ls3a_mfhilo): Likewise.
5462 * config/mips/octeon.md (octeon_imul_o1, octeon_imul_o2)
5463 (octeon_mfhilo_o1, octeon_mfhilo_o2): Likewise.
5464 * config/mips/sr71k.md (ir_sr70_hilo): Likewise.
5465 * config/mips/xlr.md (xlr_hilo): Likewise.
5466
5467 2012-07-14 Andrew Stubbs <ams@codesourcery.com>
5468 Sandra Loosemore <sandra@codesourcery.com>
5469
5470 * config/sh/sh.h (SH_ASM_SPEC): Add spaces between options.
5471
5472 2012-07-14 Uros Bizjak <ubizjak@gmail.com>
5473
5474 * config/i386/i386.c (ix86_set_reg_reg_cost): Enable TFmode/TCmode
5475 for TARGET_SSE.
5476
5477 2012-07-14 Steven Bosscher <steven@gcc.gnu.org>
5478
5479 * toplev.c (init_asm_output): Open asm_out_file in 'w' mode.
5480
5481 2012-07-13 Bill Schmidt <wschmidt@linux.ibm.com>
5482
5483 PR bootstrap/53955
5484 * config/spu/spu.c (spu_init_cost): Mark static.
5485 (spu_add_stmt_cost): Likewise.
5486 (spu_finish_cost): Likewise.
5487 (spu_destroy_cost_data): Likewise.
5488 * config/i386/i386.c (ix86_init_cost): Mark static.
5489 (ix86_add_stmt_cost): Likewise.
5490 (ix86_finish_cost): Likewise.
5491 (ix86_destroy_cost_data): Likewise.
5492 * config/rs6000/rs6000.c (rs6000_init_cost): Mark static.
5493 (rs6000_add_stmt_cost): Likewise.
5494 (rs6000_finish_cost): Likewise.
5495 (rs6000_destroy_cost_data): Likewise.
5496
5497 2012-07-13 Steven Bosscher <steven@gcc.gnu.org>
5498
5499 * ggc.h (ggc_internal_alloc_stat, ggc_alloc_typed_stat,
5500 ggc_internal_cleared_alloc_stat, ggc_cleared_alloc_htab_ignore_args,
5501 ggc_cleared_alloc_ptr_array_two_args, ggc_splay_alloc): Add
5502 ATTRIBUTE_MALLOC.
5503 * alloc-pool.h (pool_alloc): Likewise.
5504
5505 * final.c (final): Do not loop to find max_uid.
5506
5507 2012-07-13 Steven Bosscher <steven@gcc.gnu.org>
5508
5509 * emit-rtl.c (make_debug_insn_raw, make_jump_insn_raw): Make static.
5510 * rtl.h (make_debug_insn_raw, make_jump_insn_raw): Remove prototypes.
5511
5512 2012-07-13 Richard Guenther <rguenther@suse.de>
5513
5514 PR tree-optimization/53907
5515 * tree-ssa-forwprop.c (associate_pointerplus): New function.
5516 (ssa_forward_propagate_and_combine): Call it.
5517
5518 2012-07-13 Richard Guenther <rguenther@suse.de>
5519
5520 PR tree-optimization/53922
5521 * tree-vrp.c (value_inside_range): Change prototype to take
5522 min/max instead of value-range.
5523 (range_includes_zero_p): Likewise. Return the result from
5524 value_inside_range.
5525 (extract_range_from_binary_expr_1): Adjust to handle dont-know
5526 return value from range_includes_zero_p.
5527 (extract_range_from_unary_expr_1): Likewise.
5528 (compare_range_with_value): Likewise.
5529 (vrp_meet_1): Likewise.
5530
5531 2012-07-13 Bill Schmidt <wschmidt@linux.ibm.com>
5532
5533 * doc/tm.texi: Regenerate.
5534 * doc/tm.texi.in (TARGET_VECTORIZE_INIT_COST): New hook.
5535 (TARGET_VECTORIZE_ADD_STMT_COST): Likewise.
5536 (TARGET_VECTORIZE_FINISH_COST): Likewise.
5537 (TARGET_VECTORIZE_DESTROY_COST_DATA): Likewise.
5538 * targhooks.c (default_init_cost): New function.
5539 (default_add_stmt_cost): Likewise.
5540 (default_finish_cost): Likewise.
5541 (default_destroy_cost_data): Likewise.
5542 * targhooks.h (default_init_cost): New decl.
5543 (default_add_stmt_cost): Likewise.
5544 (default_finish_cost): Likewise.
5545 (default_destroy_cost_data): Likewise.
5546 * target.def (init_cost): New DEFHOOK.
5547 (add_stmt_cost): Likewise.
5548 (finish_cost): Likewise.
5549 (destroy_cost_data): Likewise.
5550 * target.h (struct _stmt_vec_info): New extern decl.
5551 (stmt_vectype): Likewise.
5552 (stmt_in_inner_loop_p): Likewise.
5553 * tree-vectorizer.h (stmt_info_for_cost): New struct/typedef.
5554 (stmt_vector_for_cost): New VEC/typedef.
5555 (add_stmt_info_to_vec): New function.
5556 (struct _slp_tree): Remove cost.inside_of_loop field.
5557 (struct _slp_instance): Remove cost.inside_of_loop field; add
5558 stmt_cost_vec field.
5559 (SLP_INSTANCE_INSIDE_OF_LOOP_COST): Remove macro.
5560 (SLP_INSTANCE_STMT_COST_VEC): New accessor macro.
5561 (SLP_TREE_INSIDE_OF_LOOP_COST): Remove macro.
5562 (struct _vect_peel_extended_info): Add stmt_cost_vec field.
5563 (struct _loop_vec_info): Add target_cost_data field.
5564 (LOOP_VINFO_TARGET_COST_DATA): New accessor macro.
5565 (struct _bb_vec_info): Add target_cost_data field.
5566 (BB_VINFO_TARGET_COST_DATA): New accessor macro.
5567 (struct _stmt_vec_info): Remove cost.inside_of_loop field.
5568 (STMT_VINFO_INSIDE_OF_LOOP_COST): Remove macro.
5569 (stmt_vinfo_set_inside_of_loop_cost): Remove function.
5570 (init_cost): New function.
5571 (add_stmt_cost): Likewise.
5572 (finish_cost): Likewise.
5573 (destroy_cost_data): Likewise.
5574 (vect_model_simple_cost): Change parameter list.
5575 (vect_model_store_cost): Likewise.
5576 (vect_model_load_cost): Likewise.
5577 (record_stmt_cost): New extern decl.
5578 (vect_get_load_cost): Change parameter list.
5579 (vect_get_store_cost): Likewise.
5580 * tree-vect-loop.c (new_loop_vec_info): Call init_cost.
5581 (destroy_loop_vec_info): Call destroy_cost_data.
5582 (vect_estimate_min_profitable_iters): Remove old calculation of
5583 inside costs; call finish_cost instead.
5584 (vect_model_reduction_cost): Call add_stmt_cost instead of old
5585 inside-costs calculation.
5586 (vect_model_induction_cost): Likewise.
5587 * tree-vect-data-refs.c (vect_get_data_access_cost): Change to
5588 return a stmt_vector_for_cost; modify calls to vect_get_load_cost
5589 and vect_get_store_cost to obtain the value to return.
5590 (vect_peeling_hash_get_lowest_cost): Obtain a stmt_cost_vec from
5591 vect_get_data_access_cost and store it in the minimum peeling
5592 structure.
5593 (vect_peeling_hash_choose_best_peeling): Change the parameter list
5594 to add a (stmt_vector_for_cost *) output parameter, and set its value.
5595 (vect_enhance_data_refs_alignment): Ignore the new return value from
5596 calls to vect_get_data_access_cost; obtain stmt_cost_vec from
5597 vect_peeling_hash_choose_best_peeling and pass its contents to the
5598 target cost model.
5599 * tree-vect-stmts.c (stmt_vectype): New function.
5600 (stmt_in_inner_loop_p): Likewise.
5601 (record_stmt_cost): Likewise.
5602 (vect_model_simple_cost): Add stmt_cost_vec parameter; call
5603 record_stmt_cost instead of old calculation; don't call
5604 stmt_vinfo_set_inside_of_loop_cost.
5605 (vect_model_promotion_demotion_cost): Call add_stmt_cost instead of
5606 old calculation; don't call stmt_vinfo_set_inside_of_loop_cost.
5607 (vect_model_store_cost): Add stmt_cost_vec parameter; call
5608 record_stmt_cost instead of old calculation; add stmt_cost_vec
5609 parameter to vect_get_store_cost call; don't call
5610 stmt_vinfo_set_inside_of_loop_cost.
5611 (vect_get_store_cost): Add stmt_cost_vec parameter; call
5612 record_stmt_cost instead of old calculation.
5613 (vect_model_load_cost): Add stmt_cost_vec parameter; call
5614 record_stmt_cost instead of old calculation; add stmt_cost_vec
5615 parameter to vect_get_load_cost call; don't call
5616 stmt_vinfo_set_inside_of_loop_cost.
5617 (vect_get_load_cost): Add stmt_cost_vec parameter; call
5618 record_stmt_cost instead of old calculation.
5619 (vectorizable_call): Add NULL parameter to vect_model_simple_cost call.
5620 (vectorizable_conversion): Likewise.
5621 (vectorizable_assignment): Likewise.
5622 (vectorizable_shift): Likewise.
5623 (vectorizable_operation): Likewise.
5624 (vectorizable_store): Add NULL parameter to vect_model_store_cost call.
5625 (vectorizable_load): Add NULL parameter to vect_model_load_cost call.
5626 (new_stmt_vec_info): Don't set STMT_VINFO_INSIDE_OF_LOOP_COST.
5627 * config/spu/spu.c (TARGET_VECTORIZE_INIT_COST): New macro def.
5628 (TARGET_VECTORIZE_ADD_STMT_COST): Likewise.
5629 (TARGET_VECTORIZE_FINISH_COST): Likewise.
5630 (TARGET_VECTORIZE_DESTROY_COST_DATA): Likewise.
5631 (spu_init_cost): New function.
5632 (spu_add_stmt_cost): Likewise.
5633 (spu_finish_cost): Likewise.
5634 (spu_destroy_cost_data): Likewise.
5635 * config/i386/i386.c (ix86_init_cost): New function.
5636 (ix86_add_stmt_cost): Likewise.
5637 (ix86_finish_cost): Likewise.
5638 (ix86_destroy_cost_data): Likewise.
5639 (TARGET_VECTORIZE_INIT_COST): New macro def.
5640 (TARGET_VECTORIZE_ADD_STMT_COST): Likewise.
5641 (TARGET_VECTORIZE_FINISH_COST): Likewise.
5642 (TARGET_VECTORIZE_DESTROY_COST_DATA): Likewise.
5643 * config/rs6000/rs6000.c (TARGET_VECTORIZE_INIT_COST): New macro def.
5644 (TARGET_VECTORIZE_ADD_STMT_COST): Likewise.
5645 (TARGET_VECTORIZE_FINISH_COST): Likewise.
5646 (TARGET_VECTORIZE_DESTROY_COST_DATA): Likewise.
5647 (rs6000_init_cost): New function.
5648 (rs6000_add_stmt_cost): Likewise.
5649 (rs6000_finish_cost): Likewise.
5650 (rs6000_destroy_cost_data): Likewise.
5651 * tree-vect-slp.c (vect_free_slp_instance): Free stmt_cost_vec.
5652 (vect_create_new_slp_node): Don't set SLP_TREE_INSIDE_OF_LOOP_COST.
5653 (vect_get_and_check_slp_defs): Add stmt_cost_vec parameter; add
5654 stmt_cost_vec parameter to vect_model_store_cost and
5655 vect_model_simple_cost calls.
5656 (vect_build_slp_tree): Remove inside_cost parameter; add stmt_cost_vec
5657 parameter; add stmt_cost_vec parameter to vect_get_and_check_slp_defs,
5658 vect_model_load_cost, and recursive vect_build_slp_tree calls; prevent
5659 calculating cost more than once for loads; remove inside_cost
5660 parameter from recursive vect_build_slp_tree calls; call
5661 record_stmt_cost instead of old calculation.
5662 (vect_analyze_slp_instance): Allocate stmt_cost_vec and save it with
5663 the instance; free it on premature exit; remove inside_cost parameter
5664 from vect_build_slp_tree call; add stmt_cost_vec parameter to
5665 vect_build_slp_tree call; don't set SLP_INSTANCE_INSIDE_OF_LOOP_COST.
5666 (new_bb_vec_info): Call init_cost.
5667 (destroy_bb_vec_info): Call destroy_cost_data.
5668 (vect_bb_vectorization_profitable_p): Call add_stmt_cost for each
5669 statement recorded with an SLP instance; call finish_cost instead of
5670 the old calculation.
5671 (vect_update_slp_costs_according_to_vf): Record statement costs from
5672 SLP instances, multiplying by the appropriate number of copies; don't
5673 update SLP_INSTANCE_INSIDE_OF_LOOP_COST.
5674
5675 2012-07-13 Richard Guenther <rguenther@suse.de>
5676
5677 PR middle-end/53937
5678 * builtins.c (get_pointer_alignment_1): Handle constant
5679 pointers.
5680
5681 2012-07-13 Richard Sandiford <rdsandiford@googlemail.com>
5682 Steven Bosscher <steven@gcc.gnu.org>
5683 Bernd Schmidt <bernds@codesourcery.com>
5684
5685 PR rtl-optimization/53908
5686 * df-problems.c (can_move_insns_across): When doing
5687 memory-reference book-keeping, handle call insns.
5688
5689 2012-07-13 Richard Guenther <rguenther@suse.de>
5690
5691 * gimple.c (gimple_types_compatible_p_1): Remove redundant
5692 type attribute comparisons.
5693 (gimple_canonical_types_compatible_p): Likewise.
5694
5695 2012-07-12 Hans-Peter Nilsson <hp@axis.com>
5696
5697 PR rtl-optimization/53176
5698 * rtlanal.c (rtx_cost): Adjust default cost for X with a
5699 UNITS_PER_WORD factor for all X according to the size of
5700 its mode, not just for SUBREGs with untieable modes.
5701 Handle SET. Use factor * factor for MULT, DIV, UDIV,
5702 MOD, UMOD.
5703
5704 2012-07-12 Uros Bizjak <ubizjak@gmail.com>
5705
5706 * config/i386/i386.md (QImode and HImode cmove splitters): Merge
5707 QImode and HImode splitters. Use ix86_comparison_operator.
5708 Explicitly match FLAGS_REG.
5709 (DFmode cmove splitter): Explicitly match FLAGS_REG.
5710
5711 2012-07-11 Steven Bosscher <steven@gcc.gnu.org>
5712
5713 * expr.h (can_move_by_pieces): Move prototype from here ...
5714 * tree.h (can_move_by_pieces): ... to here.
5715 * optabs.h (set_widening_optab_handler): Use XCNEW.
5716 * gimplify.c: Do not include expr.h.
5717
5718 * toplev.c: Do not include dwarf2out.h.
5719 * config/ia64/ia64.c: Likewise.
5720 * config/sparc/sparc.c: Likewise.
5721 * config/sparc/t-sparc (sparc.o): Fix dependencies.
5722
5723 * Makefile.in (toplev.o): Fix dependencies
5724 (c-family/c-gimplify.o): Likewise.
5725 (c-family/c-common.o): Likewise.
5726
5727 2012-07-11 Steven Bosscher <steven@gcc.gnu.org>
5728
5729 * basic-block.h (struct edge_def): Use basic_block instead of
5730 basic_block_def *.
5731 * cfgloop.h (struct loop_exit, struct loop): Likewise.
5732 * gengenrtl.c (type_from_format): Likewise. Also for 'tree'
5733 instead of union tree_node *.
5734 * rtl.h (union rtunion_def, emit_insn_before_noloc,
5735 emit_insn_after_noloc, add_insn_before, add_insn_after,
5736 debug_bb_slim): Likewise.
5737 * tree-inline.h (struct copy_body_data): Likewise.
5738 * sched-rgn.c (dump_region_dot): Likewise.
5739 * gimple.h (struct gimple_statement_base, gimple_set_bb,
5740 gsi_move_to_bb_end): Likewise.
5741 * sched-vis.c (debug_bb_slim): Likewise.
5742 (debug_bb_n_slim): Likewise.
5743 * config/mn10300/mn10300.c (mn10300_insert_setlb_lcc): Likewise.
5744 (mn10300_block_contains_call):
5745
5746 2012-07-11 Greta Yorsh <Greta.Yorsh@arm.com>
5747
5748 PR target/53859
5749 * config/arm/arm.c (arm_early_load_addr_dep): Handle new
5750 epilogue patterns.
5751
5752 2012-07-11 Jonathan Wakely <jwakely.gcc@gmail.com>
5753
5754 * doc/extend.texi (Namespace Association): Alter cautionary text.
5755
5756 2012-07-10 Oleg Endo <olegendo@gcc.gnu.org>
5757
5758 PR target/53911
5759 * config/sh/sh.md: Remove displacement addresssing related splits.
5760
5761 2012-07-10 Xinliang David Li <davidxl@google.com>
5762
5763 * doc/invoke.texi: New option documented.
5764 * flag-types.h: New enum type.
5765 * gimplify.c (gimplify_bind_expr): Control
5766 clobber generation with new option.
5767 (gimplify_target_expr): Ditto.
5768 * common.opt: New option.
5769
5770 2012-07-10 Julian Brown <julian@codesourcery.com>
5771
5772 * config/arm/arm.md (movsi): Don't split symbol refs here.
5773 (define_split): New.
5774
5775 2012-07-10 Andreas Schwab <schwab@linux-m68k.org>
5776
5777 PR bootstrap/53913
5778 * config/m68k/m68k.c (m68k_epilogue_uses): New.
5779 * config/m68k/m68k.h (EPILOGUE_USES): Use it.
5780 * config/m68k/m68k-protos.h (m68k_epilogue_uses): Add prototype.
5781
5782 2012-07-10 Richard Henderson <rth@redhat.com>
5783
5784 * target.def (builtin_mul_widen_even, builtin_mul_widen_odd): Remove.
5785 * system.h (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): Poison.
5786 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): Poison.
5787 * config/i386/i386.c (IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V4SI): Remove.
5788 (IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V8SI): Remove.
5789 (IX86_BUILTIN_VEC_WIDEN_UMUL_ODD_V4SI): Remove.
5790 (IX86_BUILTIN_VEC_WIDEN_UMUL_ODD_V8SI): Remove.
5791 (IX86_BUILTIN_VEC_WIDEN_SMUL_EVEN_V4SI): Remove.
5792 (IX86_BUILTIN_VEC_WIDEN_UMUL_EVEN_V4SI): Remove.
5793 (IX86_BUILTIN_VEC_WIDEN_UMUL_EVEN_V8SI): Remove.
5794 (bdesc_args): Remove entries to match.
5795 (ix86_builtin_mul_widen_even, ix86_builtin_mul_widen_odd): Remove.
5796 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): Remove.
5797 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): Remove.
5798 * config/rs6000/rs6000.c (rs6000_builtin_mul_widen_even): Remove.
5799 (rs6000_builtin_mul_widen_odd): Remove.
5800 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): Remove.
5801 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): Remove.
5802 * config/spu/spu.c (spu_builtin_mul_widen_even): Remove.
5803 (spu_builtin_mul_widen_odd): Remove.
5804 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): Remove.
5805 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): Remove.
5806 * doc/tm.texi.in: Don't document the removed hooks.
5807
5808 * tree-vect-stmts.c (supportable_widening_operation): Expand
5809 WIDEN_MULT_EXPR via VEC_WIDEN_MULT_EVEN/ODD_EXPR if possible.
5810
5811 * expmed.c (expmed_mult_highpart): Rename from expand_mult_highpart.
5812 (expmed_mult_highpart_optab): Rename from expand_mult_highpart_optab.
5813 * optabs.c (can_mult_highpart_p): New.
5814 (expand_mult_highpart): New.
5815 * expr.c (expand_expr_real_2) [MULT_HIGHPART_EXPR): Use it.
5816 * tree-vect-generic.c (expand_vector_operations_1): Don't expand
5817 by pieces if can_mult_highpart_p.
5818 (expand_vector_divmod): Use can_mult_highpart_p and always
5819 generate MULT_HIGHPART_EXPR.
5820 * tree-vect-patterns.c (vect_recog_divmod_pattern): Likewise.
5821 * tree-vect-stmts.c (vectorizable_operation): Likewise.
5822
5823 * config/spu/spu-builtins.md (spu_mpy): Move to spu.md.
5824 (spu_mpyu, spu_mpyhhu, spu_mpyhh): Likewise.
5825 * config/spu/spu.md (vec_widen_smult_odd_v8hi): Rename from spu_mpy.
5826 (vec_widen_umult_odd_v8hi): Rename from spu_mpyu.
5827 (vec_widen_smult_even_v8hi): Rename from spu_mpyhh.
5828 (vec_widen_umult_even_v8hi): Rename from spu_mpyhhu.
5829 * config/spu/spu-builtins.def: Update pattern names to match.
5830
5831 * config/rs6000/altivec.md (vec_widen_umult_even_v16qi): Rename
5832 from altivec_vmuleub.
5833 (vec_widen_smult_even_v16qi): Rename from altivec_vmulesb.
5834 (vec_widen_umult_even_v8hi): Rename from altivec_vmuleuh.
5835 (vec_widen_smult_even_v8hi): Rename from altivec_vmulesh.
5836 (vec_widen_umult_odd_v16qi): Rename from altivec_vmuloub.
5837 (vec_widen_smult_odd_v16qi): Rename from altivec_vmulosb.
5838 (vec_widen_umult_odd_v8hi): Rename from altivec_vmulouh.
5839 (vec_widen_smult_odd_v8hi): Rename from altivec_vmulosh.
5840 * config/rs6000/rs6000-builtin.def: Update pattern names to match.
5841
5842 * config/i386/sse.md (vec_widen_umult_even_v8si): Rename from
5843 avx2_umulv4siv4di3.
5844 (vec_widen_umult_even_v4si): Rename from sse2_umulv2siv2di3.
5845 (vec_widen_smult_even_v8si): Rename from avx2_mulv4siv4di3.
5846 (mulv4si3): Remove XOP test shadowed by SSE4 test.
5847 * config/i386/i386.c (bdesc_args): Update pattern names.
5848 (ix86_expand_sse2_mulvxdi3): Likewise.
5849 (ix86_expand_mul_widen_evenodd): Likewise. Remove XOP test
5850 shadowed by SSE4 test.
5851
5852 * tree.def (VEC_WIDEN_MULT_EVEN_EXPR, VEC_WIDEN_MULT_ODD_EXPR): New.
5853 * cfgexpand.c (expand_debug_expr): Handle them.
5854 * expr.c (expand_expr_real_2): Likewise.
5855 * fold-const.c (fold_binary_loc): Likewise.
5856 * gimple-pretty-print.c (dump_binary_rhs): Likewise.
5857 * optabs.c (optab_for_tree_code): Likewise.
5858 * tree-cfg.c (verify_gimple_assign_binary): Likewise.
5859 * tree-inline.c (estimate_operator_cost): Likewise.
5860 * tree-pretty-print.c (dump_generic_node): Likewise.
5861 * tree.c (commutative_tree_code): Likewise.
5862 * tree-vect-generic.c (expand_vector_operations_1): Likewise.
5863 Handle type change before looking up optab.
5864 * optabs.h (OTI_vec_widen_umult_even, OTI_vec_widen_umult_odd): New.
5865 (OTI_vec_widen_smult_even, OTI_vec_widen_smult_odd): New.
5866 (vec_widen_umult_even_optab, vec_widen_umult_odd_optab): New.
5867 (vec_widen_smult_even_optab, vec_widen_smult_odd_optab): New.
5868 * genopinit.c (optabs): Initialize them.
5869 * doc/md.texi: Document them.
5870
5871 2012-07-10 Dehao Chen <dehao@google.com>
5872
5873 * tree.h (phi_arg_d): New field.
5874 * tree-flow-inline.h (gimple_phi_arg_block): New function.
5875 (gimple_phi_arg_block_from_edge): New function.
5876 (gimple_phi_arg_set_block): New function.
5877 (gimple_phi_arg_has_block): New function.
5878 (redirect_edge_var_map_block): New function.
5879 * tree-flow.h (_edge_var_map): New field.
5880 * tree-ssa-live.c (remove_unused_locals): Mark phi_arg's block as used.
5881 * tree-eh.c (cleanup_empty_eh_merge_phis): Add block debug info for
5882 redirect_edge_var_map_add.
5883 * tree-outof-ssa.c (_elim_graph): New field.
5884 (insert_partition_copy_on_edge): New parameter.
5885 (insert_value_copy_on_edge): New parameter.
5886 (insert_rtx_to_part_on_edge): New parameter.
5887 (insert_part_to_rtx_on_edge): New parameter.
5888 (elim_graph_add_edge): New parameter.
5889 (elim_graph_remove_succ_edge): New parameter.
5890 (FOR_EACH_ELIM_GRAPH_SUCC): New parameter.
5891 (FOR_EACH_ELIM_GRAPH_PRED): New parameter.
5892 (new_elim_graph): Add block debug info.
5893 (clear_elim_graph): Likewise.
5894 (delete_elim_graph): Likewise.
5895 (elim_graph_add_node): Likewise.
5896 (elim_graph_add_edge): Likewise.
5897 (elim_graph_remove_succ_edge): Likewise.
5898 (eliminate_build): Likewise.
5899 (elim_forward): Likewise.
5900 (elim_unvisited_predecessor): Likewise.
5901 (elim_backward): Likewise.
5902 (elim_create): Likewise.
5903 (eliminate_phi): Likewise.
5904 (insert_backedge_copies): Likewise.
5905 * tree-into-ssa.c (insert_phi_nodes_for): Add block debug info for
5906 add_phi_arg.
5907 (rewrite_add_phi_arguments): Likewise.
5908 * tree-ssa-loop-im.c (execute_sm_if_changed): Likewise.
5909 * tree-ssa-tail-merge.c (replace_block_by): Likewise.
5910 * tree-ssa-threadupdate.c (copy_phi_args): Likewise.
5911 * tree-loop-distribution.c (update_phis_for_loop_copy): Likewise.
5912 * tree-ssa-loop-manip.c (create_iv): Likewise.
5913 (add_exit_phis_edge): Likewise.
5914 (split_loop_exit_edge): Likewise.
5915 (copy_phi_node_args): Likewise.
5916 (tree_transform_and_unroll_loop): Likewise.
5917 * value-prof.c (gimple_ic): Likewise.
5918 (gimple_stringop_fixed_value): Likewise.
5919 * tree-tailcall.c (add_successor_phi_arg): Likewise.
5920 (eliminate_tail_call): Likewise.
5921 (create_tailcall_accumulator): Likewise.
5922 (tree_optimize_tail_calls_1): Likewise.
5923 * tree-phinodes.c (add_phi_arg): Likewise.
5924 (make_phi_node): Likewise.
5925 (resize_phi_node): Likewise.
5926 (remove_phi_arg_num): Likewise.
5927 * omp-low.c (expand_parallel_call): Likewise.
5928 (expand_omp_for_static_chunk): Likewise.
5929 * tree-vect-loop-manip.c (slpeel_update_phis_for_duplicate_loop):
5930 Likewise.
5931 (slpeel_update_phi_nodes_for_guard1): Likewise.
5932 (slpeel_update_phi_nodes_for_guard2): Likewise.
5933 (slpeel_tree_duplicate_loop_to_edge_cfg): Likewise.
5934 (set_prologue_iterations): Likewise.
5935 (slpeel_tree_peel_loop_to_edge): Likewise.
5936 (vect_loop_versioning): Likewise.
5937 * tree-parloops.c (create_phi_for_local_result): Likewise.
5938 (transform_to_exit_first_loop): Likewise.
5939 (create_parallel_loop): Likewise.
5940 * ipa-split.c (split_function): Likewise.
5941 * tree-vect-loop.c (get_initial_def_for_induction): Likewise.
5942 (vect_create_epilog_for_reduction): Likewise.
5943 * tree-vect-data-refs.c (vect_setup_realignment): Likewise.
5944 * graphite-scop-detection.c (canonicalize_loop_closed_ssa): Likewise.
5945 * tree-ssa-phiopt.c (cond_store_replacement): Likewise.
5946 (cond_if_else_store_replacement_1): Likewise.
5947 * tree-cfgcleanup.c (remove_forwarder_block): Likewise.
5948 (remove_forwarder_block_with_phi): Likewise.
5949 * tree-ssa-pre.c (insert_into_preds_of_block): Likewise.
5950 * tree-predcom.c (initialize_root_vars): Likewise.
5951 (initialize_root_vars_lm): Likewise.
5952 * sese.c (sese_add_exit_phis_edge): Likewise.
5953 * tree-ssa-dce.c (forward_edge_to_pdom): Likewise.
5954 * tree-ssa.c (flush_pending_stmts): Likewise.
5955 (redirect_edge_var_map_add): Likewise.
5956 (ssa_redirect_edge): Likewise.
5957 * gimple-streamer-in.c (input_phi): Likewise.
5958 * tree-vect-stmts.c (vectorizable_load): Likewise.
5959 * tree-inline.c (copy_phis_for_bb): Likewise.
5960 * tree-ssa-phiprop.c (phiprop_insert_phi): Likewise.
5961 * tree-switch-conversion.c (fix_phi_nodes): Likewise.
5962 * tree-cfg.c (reinstall_phi_args): Likewise.
5963 (gimple_make_forwarder_block): Likewise.
5964 (add_phi_args_after_copy_edge): Likewise.
5965 (gimple_duplicate_sese_tail): Likewise.
5966
5967 2012-07-09 Oleg Endo <olegendo@gcc.gnu.org>
5968
5969 PR target/53886
5970 * config/sh/sh.c (sequence_insn_p): New function.
5971 (find_barrier, sh_insn_length_adjustment): Use it.
5972
5973 2012-07-09 Iain Sandoe <iain@codesourcery.com>
5974
5975 PR target/53283
5976 * config/i386/i386.c (ix86_fold_builtin): Call SUBTARGET_FOLD_BUILTIN
5977 if defined.
5978 * config/darwin.h: Rename TARGET_FOLD_BUILTIN to
5979 SUBTARGET_FOLD_BUILTIN.
5980 * config/rs6000/darwin.h: Map TARGET_FOLD_BUILTIN onto
5981 SUBTARGET_FOLD_BUILTIN.
5982
5983 2012-07-09 Iain Sandoe <iain@codesourcery.com>
5984
5985 * config/darwin.h (SUBTARGET_C_COMMON_OVERRIDE_OPTIONS): Move NeXT
5986 runtime exceptions model setting from here ...
5987 * config/darwin.c (darwin_override_options): ... to here.
5988
5989 2012-07-09 Steven Bosscher <steven@gcc.gnu.org>
5990
5991 PR tree-optimization/53887
5992 * tree-cfg.c (group_case_labels_stmt): Make non-static.
5993 * tree-flow.h (group_case_labels_stmt): Add prototype.
5994 * tree-switch-conversion.c (process_switch): Use group_case_labels_stmt
5995 to pre-process every switch.
5996
5997 2012-07-09 Jason Merrill <jason@redhat.com>
5998
5999 PR c++/53882
6000 * tree.c (type_contains_placeholder_1): Handle NULLPTR_TYPE.
6001 (type_hash_eq): Likewise.
6002
6003 2012-07-09 Tom de Vries <tom@codesourcery.com>
6004 Richard Guenther <rguenther@suse.de>
6005
6006 * tree-ssa-ccp.c (optimize_unreachable): New function.
6007 (execute_fold_all_builtins): Use optimize_unreachable to optimize
6008 BUILT_IN_UNREACHABLE. Don't optimize after BUILT_IN_UNREACHABLE.
6009
6010 2012-07-09 Richard Guenther <rguenther@suse.de>
6011
6012 PR bootstrap/53898
6013 * graphite-optimize-isl.c: Make sure CU is not empty.
6014
6015 2012-07-09 Steven Bosscher <steven@gcc.gnu.org>
6016
6017 * gensupport.c (init_rtx_reader_args_cb): Start counting code
6018 generating patterns from 1 to free up 0 for CODE_FOR_nothing.
6019 * gencodes.c (main): Give CODE_FOR_nothing the value 0. Add
6020 the LAST_INSN_CODE marker at the end.
6021 * genoutput.c (nothing): New static struct data.
6022 (idata): Initialize to &nothing.
6023 (idata_end): Initialize to &nothing.next.
6024 (init_insn_for_nothing): New function to create dummy 'nothing' insn.
6025 (main): Use it.
6026 * genpeep.c (insn_code_number): Remove global variable.
6027 (gen_peephole): Take it as an argument instead.
6028 (main): Take insn_code_number from read_md_rtx.
6029 * optabs.h: Revert r161809:
6030 (optab_handlers): Change type of insn_code back to insn_code.
6031 (optab_handler, widening_optab_handler, set_optab_handler,
6032 set_widening_optab_handler, convert_optab_handler,
6033 set_convert_optab_handler, direct_optab_handler,
6034 set_direct_optab_handler): Remove int casts.
6035 Revert to treating the insn_code field as "insn_code".
6036
6037 2012-07-08 Oleg Endo <olegendo@gcc.gnu.org>
6038
6039 * config/sh/sh.md (*return_i): Move trap_exit attribute check to ...
6040 * config/sh/sh.c (sh_cfun_trap_exit_p): ... this new function.
6041 * config/sh/sh-protos.h: Declare it.
6042
6043 2012-07-08 Steven Bosscher <steven@gcc.gnu.org>
6044
6045 * mcf.c: Do not include tm.h, tree.h, and langhooks.h.
6046 (dump_fixup_graph): Use current_function_name.
6047 (adjust_cfg_counts): Likewise.
6048 * ira-conflicts.c: Do not include tree.h.
6049 (ira_build_conflicts): Use REG_USERVAR_P instead of DECL_ARTIFICIAL.
6050
6051 2012-07-08 Oleg Endo <olegendo@gcc.gnu.org>
6052
6053 PR target/51244
6054 * config/sh/sh.md (*branch_true_eq, *branch_false_ne, nott): New insns.
6055
6056 2012-07-08 Steven Bosscher <steven@gcc.gnu.org>
6057
6058 * basic-block.h: Re-group most prototypes per file.
6059 (struct edge_list): Remove num_blocks field.
6060 (dump_bb_info): Adjust prototypes.
6061 (dump_reg_info): Move prototype to regs.h.
6062 * function.h: Do not include tree.h.
6063 Include vec.h, vecir.h, input.h and machmode.h to compensate.
6064 (function_name): New prototype.
6065 * gimple.h: Include tree.h to compensate for basic-block.h change.
6066 * langhooks.h: Note that tree.h is only necessary for enum tree_code.
6067 * regs.h (dump_reg_info): Prototype here.
6068 * regset.h: Adjust file reference in comment.
6069 (debug_regset): Remove prototype.
6070 * rtl.h: Include flags.h for flag_var_tracking_assignments.
6071 (MAY_HAVE_DEBUG_INSNS): Define as flag_var_tracking_assignments
6072 instead of no-longer-available tree.h's MAY_HAVE_DEBUG_STMTS.
6073 (dump_reg_info, dump_flow_info): Remove prototypes.
6074 * bb-reorder.c (set_edge_can_fallthru_flag): Move from cfganal.c
6075 to here, the only user. Make static.
6076 (reorder_basic_blocks): Call dump_reg_info before dump_flow_info.
6077 * cfg.c: Do not include tm.h, tree.h, rtl.h, hard-reg-set.h, regs.h,
6078 flags.h, function.h, except.h, diagnostic-core.h, tm_p.h, timevar.h,
6079 tree-pass.h, cfgloop.h, and tree-flow.h.
6080 Include basic-block.h, the first header I'd expect to be included.
6081 (reg_obstack): Move to df-core.c.
6082 (free_edge): Remove bogus ATTRIBUTE_UNUSED.
6083 (remove_edge_raw): Do not call tree-ssa's redirect_edge_var_map_clear.
6084 (redirect_edge_succ_nodup): Move to cfghooks.c.
6085 (dump_regset, debug_regset): Move to df-core.c.
6086 (dump_bb_info): Move to cfgrtl.c.
6087 (dump_reg_info): Move to regstat.c.
6088 (dump_flow_info): Move to cfgrtl.c.
6089 (debug_flow_info): Likewise.
6090 (dump_edge_info): Do not look at cfun, a CFG without cfun is nonsense.
6091 * cfganal.c: Do not include tm.h, rtl.h, obstack.h, hard-reg-set.h,
6092 insn-config.h, recog.h, diagnostic-core.h, tm_p.h, and cfgloop.h.
6093 (flow_active_insn_p, forwarder_block_p, can_fallthru,
6094 could_fall_through): Move to cfgrtl.c.
6095 (set_edge_can_fallthru_flag): Moved to bb-reorder.c.
6096 (create_edge_list): Do not set edge_list's removed num_blocks.
6097 (print_edge_list): Look at n_basic_blocks instead of num_blocks.
6098 (flow_nodes_print): Remove.
6099 (flow_edge_list_print): Remove.
6100 (inverted_post_order_compute): Use FOR_ALL_BB.
6101 * cfgrtl.c (dump_flow_info): Moved from cfg.c.
6102 Do not call dump_reg_info.
6103 (debug_flow_info): Moved from cfg.c
6104 (dump_bb_info): Moved from cfg.c. Take 'verbose' argument
6105 to avoid looking at TDF_* flags from tree-pass.h.
6106 (flow_active_insn_p, forwarder_block_p, can_fallthru,
6107 could_fall_through): Moved from cfganal.c.
6108 (print_rtl_with_bb): Adjust dump_bb_info calls.
6109 * cfghooks.c (redirect_edge_succ_nodup): Moved from cfg.c.
6110 (remove_edge): Call redirect_edge_var_map_clear if IR_GIMPLE.
6111 (cfgcleanup.c): Look at MAY_HAVE_DEBUG_INSNS, not MAY_HAVE_DEBUG_STMTS.
6112 * cselib.c: Include tree.h with a FIXME.
6113 * df-core.c (reg_obstack): Moved from cfg.c.
6114 (dump_regset): Likewise.
6115 (debug_regset): Likewise. Make a DEBUG_FUNCTION.
6116 * final.c (compute_alignments): Call dump_reg_info before
6117 dump_flow_info.
6118 * function.c (function_name): New function.
6119 (current_function_name): Use it.
6120 * ifcvt.c (rest_of_handle_if_conversion): Call dump_reg_info before
6121 dump_flow_info.
6122 * ira-conflicts.c: Include tree.h with a note.
6123 * regstat.c (dump_reg_info): Moved here from cfg.c.
6124 * loop-init.c: Include regs.h instead of hard-reg-set.h.
6125 (rtl_loop_init): Call dump_reg_info before dump_flow_info.
6126 (rtl_loop_done): Likewise.
6127 * mcf.c: Include tree.h before langhooks.h.
6128 * predict.c (maybe_hot_count_p): Assert we have cfun.
6129 (probably_never_executed_bb_p): Likewise.
6130 * profile.c (compute_branch_probabilities): Use gimple_dump_cfg
6131 instead of dump_flow_info.
6132 * sched-deps.c: Include tree.h with a FIXME.
6133 (call_may_noreturn_p): Add FIXME note why this function has to
6134 look at function decls instead of function decl flags.
6135 * sched-vis.c: Include tree.h with a FIXME.
6136 (print_rtl_slim): Adjust dump_bb_info uses.
6137 * statistics.c (statistics_fini_pass_2): Use current_function_name
6138 to avoid including tree.h.
6139 (statistics_counter_event): Use function_name for the same reason.
6140 (statistics_histogram_event): Likewise.
6141 * tracer.c (tracer): Remove bogus gcc_assert. Use brief_dump_cfg
6142 instead of dump_flow_info.
6143 * var-tracking.c (variable_tracking_main_1): Call dump_reg_info
6144 before dump_flow_info.
6145 * doc/cfg.texi: Update CFG documentation.
6146 * Makefile.in (RTL_H): Depend on FLAGS_H.
6147 (GIMPLE_H): Depend on TREE_H.
6148 (FUNCTION_H): Depend on VEC_H, vecir.h, INPUT_H and MACHMODE_H,
6149 but no longer on TREE_H.
6150 (C_COMMON_H): Depend on TREE_H.
6151 (cselib.o, cse.o, cfganal.o, loop-init.o, ira-conflicts.o,
6152 sched-deps.o, sched-vis.o): Fixup dependencies.
6153
6154 2012-07-08 Steven Bosscher <steven@gcc.gnu.org>
6155
6156 * alias.h: Do not include coretypes.h in header files.
6157 * cppbuiltin.h: Likewise.
6158 * double-int.h: Likewise.
6159 * gimple-fold.h: Likewise.
6160 * flags.h: Likewise.
6161 * tree-ssa-alias.h: Likewise.
6162 * gengtype.h (obstack_chunk_alloc, obstack_chunk_free,
6163 OBSTACK_CHUNK_SIZE): Define here to avoid dependency on coretypes.h.
6164 * Makefile.in (RTL_BASE_H): Depend on coretypes.h.
6165 (TREE_H): Likewise.
6166 (ALIAS_H): Do not depend on coretypes.h.
6167 (FLAGS_H): Likewise.
6168 (realmpfr.o): Depend on coretypes.h.
6169
6170 2012-07-08 Steven Bosscher <steven@gcc.gnu.org>
6171
6172 * Makefile.in (gengtype-lex.o, gengtype-parse.o, gengtype-state.o,
6173 gengtype.o): Add -DGENERATOR_FILE manually for host gengtype objects.
6174
6175 2012-07-07 Richard Earnshaw <rearnsha@arm.com>
6176
6177 * arm.h (TARGET_CPU_CPP_BUILTINS): Remove Maverick support.
6178 (TARGET_FPA): Delete definition.
6179 (TARGET_MAVERICK): Likewise.
6180 (TARGET_FPA_EMU2): Likewise.
6181 (arm_fp_model): Remove FPA and Maverick models.
6182 (arm_arch_cirrus): Delete declaration.
6183 (FLOAT_WORDS_BIG_ENDIAN): Delete definition.
6184 (FIXED_REGISTERS): Remove FPA and Maverick support. Reorganize.
6185 (CALL_USED_REGISTERS): Likewise.
6186 (FIRST_FPA_REGNUM, LAST_FPA_REGNUM): Delete definition.
6187 (FIRST_VFP_REGNUM): Renumbered.
6188 (D7_VFP_REGNUM): Chain definition.
6189 (LAST_LO_VFP_REGNUM): Likewise.
6190 (FIRST_HI_VFP_REGNUM): Likewise.
6191 (LAST_HI_VFP_REGNUM): Likewise.
6192 (FIRST_IWMMXT_GR_REGNUM): Likewise.
6193 (LAST_IWMMXT_GR_REGNUM): Likewise.
6194 (FIRST_IWMMXT_REGNUM): Likewise.
6195 (LAST_IWMMXT_REGNUM): Likewise.
6196 (FRAME_POINTER_REGNUM): Renumbered.
6197 (ARG_POINTER_REGNUM): Renumbered.
6198 (FIRST_PSEUDO_REGISTER): Remove FPA and Maverick registers.
6199 (FIRST_CIRRUS_FP_REGNUM, LAST_CIRRUS_FP_REGNUM): Delete definitions.
6200 (HARD_REGNO_REGNUM): Remove FPA support.
6201 (REG_ALLOC_ORDER): Remove FPA and Maverick registers. Reorganize.
6202 (reg_class): Likewise.
6203 (REG_CLASS_NAMES): Likewise.
6204 (REG_CLASS_CONTENTS): Likewise.
6205 (CANNOT_CHANGE_MODE_CLASS): Never true. Update comment.
6206 (SECONDARY_INPUT_RELOAD_CLASS): Remove Maverick support.
6207 (CLASS_MAX_NREGS): Remove FPA and Maverick support.
6208 * aout.h (REGISTER_NAMES): Remove FPA and Maverick registers.
6209 Reorganize. Use AAPCS preferred names.
6210 (ADDITIONAL_REGISTER_NAMES): Remove aliases for Maverick. Update
6211 comments.
6212 (OVERLAPPING_REGISTER_NAMES): Update register numbering.
6213 * arm.c (FL_CIRRUS): Delete definition.
6214 (arm_arch_cirrus): Delete variable.
6215 (arm_float_words_big_endian): Delete function.
6216 (cirrus_memory_offset): Delete function.
6217 (output_mov_long_double_fpa_from_arm): Delete function.
6218 (output_mov_long_double_arm_from_fpa): Delete function.
6219 (output_mov_double_fpa_from_arm): Delete function.
6220 (output_mov_double_arm_from_fpa): Delete function.
6221 (emit_sfm): Delete function.
6222 (maybe_get_arm_condition_code): Update comment.
6223 (arm_file_start): Always use softvfp for softfloat systems.
6224 (thumb_core_reg_alloc_order): Adjust for updated register allocation.
6225 (arm_option_override): Remove FPA and Maverick support. Always
6226 default to vfp as the fallback FPU format.
6227 (use_return_insn): Remove FPA support.
6228 (arm_get_frame_offsets): Likewise.
6229 (arm_save_coproc_regs): Likewise.
6230 (arm_canonicalize_comparison): Remove Maverick support.
6231 (arm_select_cc_mode): Likewise.
6232 (arm_gen_compare_reg): Likewise.
6233 (arm_print_operand): Likewise.
6234 (arm_libcall_value_1): Remove FPA and Maverick support.
6235 (arm_function_value_regno_p): Likewise.
6236 (arm_apply_result_size): Likewise.
6237 (arm_legitimate_index_p): Likewise.
6238 (thumb2_legitimate_index_p): Likewise.
6239 (legitimize_reload_address): Likewise.
6240 (arm_register_move_cost): Likewise.
6241 (arm_hard_regno_mode_ok): Likewise.
6242 (arm_regno_class): Likewise.
6243 (arm_dbx_register_number): Likewise.
6244 (arm_emit_unwind_sequence): Likewise.
6245 (arm_conditional_register_usage): Likewise.
6246 * arm-protos.h (neg_const_double_rtx_ok_for_fpa): Remove declaration.
6247 (cirrus_memory_offset): Likewise.
6248 (output_move_long_double_fpa_from_arm): Likewise.
6249 (output_move_long_double_arm_from_fpa): Likewise.
6250 (output_move_double_fpa_from_arm): Likewise.
6251 (output_move_double_arm_from_fpa): Likewise.
6252 (arm_float_words_big_endian): Likewise.
6253 * arm.md (CC_REGNUM): Renumbered.
6254 (VFPCC_REGNUM): Moved here. Renumbered.
6255 (FPA_F0_REGNUM, FPA_F7_REGNUM): Delete.
6256 (attr fpu): Remove FPA and Maverick support.
6257 * vfp.md (VFPCC_REGNUM): Delete. Moved to arm.md.
6258 * arm-cores.def (ep9312): Remove Maverick support.
6259 * arm-arches.def (ep9312): Delete architecture.
6260 * arm-tables.opt: Regenerated.
6261
6262 * arm/linux-elf.h (FPUTYPE_DEFAULT): Set to vfp.
6263
6264 2012-07-07 Steven Bosscher <steven@gcc.gnu.org>
6265
6266 PR tree-optimization/53881
6267 * tree-switch-conversion.c (emit_case_bit_tests): Do not rely on
6268 comparing labels to establish uniqueness of a switch case target,
6269 use the CFG instead.
6270
6271 2012-07-07 Ulrich Weigand <ulrich.weigand@linaro.org>
6272
6273 * combine.c (force_to_mode) [LSHIFTRT]: Avoid undefined behaviour
6274 due to negative shift amount.
6275
6276 2012-07-07 Hans-Peter Nilsson <hp@axis.com>
6277
6278 Fix configure test for "stack protector support in target C library".
6279 * configure.ac (test_prefix, test_exec_prefix): Move setting from
6280 inside sysroot handling to before and outside it.
6281 * configure: Regenerate.
6282
6283 2012-07-06 Kai Tietz <ktietz@redhat.com>
6284
6285 PR bootstrap/52947
6286 * config/i386/mingw32.h (NATIVE_SYSTEM_HEADER_DIR): Define it always
6287 as "/mingw/include".
6288
6289 2012-07-06 Alexandre Oliva <aoliva@redhat.com>
6290
6291 PR debug/53820
6292 * var-tracking.c (vt_add_function_parameter): Convert
6293 internal_arg_pointer into arg_pointer-based address even
6294 without DRAP.
6295
6296 2012-07-06 Alexandre Oilva <aoliva@redhat.com>
6297
6298 PR rtl-optimization/53827
6299 PR debug/53671
6300 PR debug/49888
6301 * alias.c (memrefs_conflict_p): Adjust offset and size by the
6302 same amount for alignment ANDs.
6303
6304 2012-07-06 Tom de Vries <tom@codesourcery.com>
6305
6306 PR tree-optimization/51879
6307 * tree-ssa-sccvn.c (copy_reference_ops_from_call)
6308 (visit_reference_op_call): Handle case that lhs is not an SSA_NAME.
6309 (visit_use): Also call visit_reference_op_call for calls with a vdef.
6310
6311 2012-07-06 Tom de Vries <tom@codesourcery.com>
6312
6313 PR tree-optimization/52009
6314 * tree-ssa-tail-merge.c (gimple_equal_p): For GIMPLE_ASSIGN, compare
6315 value numbers of gimple_vdef.
6316 * tree-ssa-sccvn.h (vn_reference_insert): Add vdef parameter to
6317 prototype.
6318 * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Handle MODIFY_EXPR.
6319 (vn_reference_insert): Add and handle vdef parameter.
6320 (visit_reference_op_load): Add argument to vn_reference_insert call.
6321 (visit_reference_op_store): Find value number of vdef of store. Insert
6322 value number of vdef of store.
6323
6324 2012-07-06 Uros Bizjak <ubizjak@gmail.com>
6325
6326 * config/i386/i386.md (simple lea to add peephole): Also transform
6327 RTXes where second PLUS operand matches output.
6328
6329 2012-07-06 Uros Bizjak <ubizjak@gmail.com>
6330
6331 * config/i386/i386.c (construct_plt_address): Make static.
6332 * config/i386/i386-protos.h (construct_plt_address): Remove.
6333
6334 2012-07-06 Nick Clifton <nickc@redhat.com>
6335
6336 * config/mn10300/mn10300.c (mn10300_encode_section_info): Call
6337 default_encode_section_info.
6338
6339 2012-07-06 Uros Bizjak <ubizjak@gmail.com>
6340
6341 PR target/53853
6342 * config/i386/i386.c (x86_output_mi_thunk): For CM_LARGE_PIC model,
6343 emit PIC sequence for fnaddr symbol reference in advance.
6344
6345 2012-07-06 Eric Botcazou <ebotcazou@adacore.com>
6346
6347 Revert
6348 2012-06-14 Eric Botcazou <ebotcazou@adacore.com>
6349
6350 * dwarf2out.c (function_possibly_abstracted_p): New static function.
6351 (gen_subprogram_die): Use it function_possibly_abstracted_p in lieu of
6352 cgraph_function_possibly_inlined_p.
6353 (gen_inlined_subroutine_die): Return if the origin is to be ignored.
6354 (process_scope_var): Do not emit concrete instances of abstracted
6355 nested functions from here.
6356 (gen_decl_die): Emit the abstract instance if the function is possibly
6357 abstracted and not only possibly inlined.
6358 (dwarf2out_finish): Find the first non-abstract parent instance and
6359 attach concrete instances on the limbo list to it.
6360
6361 2012-07-05 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
6362 Julian Brown <julian@codesourcery.com>
6363
6364 PR target/48941
6365 PR target/51980
6366 * config/arm/neon-gen.ml (return_by_ptr): Delete.
6367 (print_function): Handle empty strings.
6368 (return): Delete use of return_by_ptr.
6369 (mask_shape_for_shuffle): New function.
6370 (mask_elems): Likewise.
6371 (shuffle_fn): Likewise.
6372 (params): Simplify and remove use of return_by_ptr.
6373 (get_shuffle): New function.
6374 (print_variant): Update.
6375 * config/arm/neon.ml (rev_elems): New function.
6376 (permute_range): Likewise.
6377 (zip_range): Likewise.
6378 (uzip_range): Likewise.
6379 (trn_range): Likewise.
6380 (zip_elems): Likewise.
6381 (uzip_elems): Likewise.
6382 (trn_elems): Likewise.
6383 (features): New enumeration Use_shuffle. Delete ReturnPtr.
6384 (pf_su_8_16): New.
6385 (suf_32): New.
6386 (ops): Update entries for Vrev64, Vrev32, Vrev16, Vtr, Vzip, Vuzp.
6387 * config/arm/arm_neon.h: Regenerate.
6388
6389 2012-07-05 Richard Guenther <rguenther@suse.de>
6390
6391 * tree-pretty-print.c (dump_generic_node): Properly test
6392 the result of exact_log2.
6393
6394 2012-07-05 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
6395
6396 * config/s390/s390-protos.h (s390_expand_movmem)
6397 (s390_expand_cmpmem): Add return value.
6398 * config/s390/s390.c (s390_expand_movmem, s390_expand_cmpmem):
6399 Return FALSE to use the library function in some cases.
6400 * config/s390/s390.md (movmem, cmpmem): Evaluate return value of C
6401 helper functions.
6402
6403 2012-07-05 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
6404
6405 * config.gcc: Enable ifunc attribute by default on s390 and s390x.
6406
6407 2012-07-05 Steven Bosscher <steven@gcc.gnu.org>
6408
6409 * expr.c (try_casesi): Remove bogus ATTRIBUTE_UNUSED markers.
6410 * stmt.c (dump_case_nodes): New.
6411 (expand_case): Split out code generation parts into new functions.
6412 (expand_switch_as_decision_tree_p): Split out from expand_case.
6413 (emit_case_decision_tree): Likewise.
6414 (emit_case_dispatch_table): Likewise.
6415
6416 2012-07-05 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
6417
6418 * config/arm/iterators.md (SDF): New mode iterator.
6419 (V_if_elem): Add support for SF and DF modes.
6420 (V_reg): Likewise.
6421 (F_constraint): New mode iterator attribute.
6422 (F_fma_type): Likewise.
6423 config/arm/vfp.md (fma<SDF:mode>4): New pattern.
6424 (*fmsub<SDF:mode>4): Likewise.
6425 (*fmnsub<SDF:mode>4): Likewise.
6426 (*fmnadd<SDF:mode>4): Likewise.
6427
6428 2012-07-04 Uros Bizjak <ubizjak@gmail.com>
6429
6430 * expmed.c (expand_mult): Initialize coeff and is_neg.
6431
6432 2012-07-04 Oleg Endo <olegendo@gcc.gnu.org>
6433
6434 * config/sh/predicates.md (zero_extend_operand): New predicate.
6435 * config/sh/sh.md (zero_extendhisi2): Simplify by using new
6436 zero_extend_operand predicate.
6437 (zero_extendqisi2): Likewise.
6438
6439 2012-07-04 Uros Bizjak <ubizjak@gmail.com>
6440
6441 PR middle-end/53321
6442 * ipa.c (symtab_remove_unreachable_nodes): Partially revert r187375
6443 to not call cgraph_propagate_frequency if something was changed.
6444
6445 2012-07-04 Richard Guenther <rguenther@suse.de>
6446
6447 PR middle-end/53433
6448 * gimple-fold.c (get_base_constructor): Do not return an
6449 error_mark_node DECL_INITIAL.
6450
6451 2012-07-04 Richard Guenther <rguenther@suse.de>
6452
6453 PR tree-optimization/53844
6454 * tree-ssa-dse.c (dse_possible_dead_store_p): Properly handle
6455 the loop virtual PHI.
6456
6457 2012-07-04 Richard Guenther <rguenther@suse.de>
6458
6459 PR tree-optimization/53849
6460 * tree-cfg.c (move_stmt_op): Only call add_referenced_var
6461 for duplicated locals. Use add_referenced_var_1 to avoid
6462 pushing/popping cfun.
6463
6464 2012-07-04 Kai Tietz <ktietz@redhat.com>
6465
6466 * config/i386/winnt.c (i386_pe_reloc_rw_mask): New function.
6467 * config/i386/i386-protos.h (i386_pe_reloc_rw_mask): Add
6468 prototype.
6469 * config/i386/cygming.h (TARGET_ASM_RELOC_RW_MASK): Define
6470 as i386_pe_reloc_rw_mask.
6471
6472 2012-07-04 Richard Guenther <rguenther@suse.de>
6473
6474 * tree.c (find_decls_types_r): Handle TYPE_CONTEXT the same
6475 as in free_lang_data_in_type.
6476
6477 2012-07-04 Tobias Grosser <tobias@grosser.es>
6478 Michael Matz <matz@suse.de>
6479
6480 * Makefile.in (OBJS): Add graphite-optimize-isl.o.
6481 (graphite-optimize-isl.o): Add dependencies.
6482 * common.opt (floop-nest-optimize): New flag.
6483 * doc/invoke.texi (floop-nest-optimize): Document.
6484 * graphite-dependences.c (compute_deps): Export.
6485 * graphite-poly.h (compute_deps): Declare.
6486 * graphite-optimize-isl.c: New file.
6487 * graphite-poly.c (apply_poly_transforms): Run the loop
6488 nest optimizer.
6489 * tree-ssa-loop.c (gate_graphite_transforms): Enable graphite
6490 if -floop-nest-optimize is enabled.
6491
6492 2012-07-03 Oleg Endo <olegendo@gcc.gnu.org>
6493
6494 * config/sh/predicates.md (logical_and_operand): New predicate.
6495 * config/sh/constraints.md (Jmb, Jmw): New constraints.
6496 * config/sh/sh.md (andsi3): Move expander above insns. Add handling
6497 of 0xFFFF constant. Use logical_and_operand predicate and
6498 satisfies_constraint_Jmb, satisfies_constraint_Jmw.
6499 (*andsi3_compact): Make it an insn_and_split. Use
6500 logical_and_operand predicate. Add Jmb,Jmw alternatives.
6501
6502 2012-07-03 Jason Merrill <jason@redhat.com>
6503
6504 PR c++/53826
6505 * tree.c (build_zero_cst): Handle NULLPTR_TYPE.
6506
6507 2012-07-03 Nick Clifton <nickc@redhat.com>
6508
6509 * config/mep/mep.c (mep_reorg_regmove): Use
6510 next_nonnote_non_debug_insn to advance to the next insn. Do not
6511 expect delete_insn to return an rtx.
6512
6513 2012-07-03 Richard Guenther <rguenther@suse.de>
6514
6515 * doc/install.texi (CLooG): Clarify how CLooG needs to be
6516 configured and that it needs to be built against ISL 0.10.
6517
6518 2012-07-03 Uros Bizjak <ubizjak@gmail.com>
6519
6520 * config/i386/i386.c (ix86_option_override_internal): Fix wrong
6521 code model string in the error message.
6522
6523 2012-07-03 Uros Bizjak <ubizjak@gmail.com>
6524
6525 PR target/53811
6526 * config/i386/i386.c (x86_output_mi_thunk): Check if fnaddr satisfies
6527 sibcall_insn_operand. Move it to a temporary register if not.
6528
6529 2012-07-03 Andreas Schwab <schwab@linux-m68k.org>
6530
6531 PR target/28896
6532 * config/m68k/m68k.c (m68k_option_override): Reset stack_limit_rtx
6533 if !TARGET_68020.
6534
6535 2012-07-03 Uros Bizjak <ubizjak@gmail.com>
6536
6537 * config/i386/xmmintrin.h (_mm_sfence): Use __builtin_ia32_pause.
6538
6539 2012-07-03 Roland McGrath <mcgrathr@google.com>
6540
6541 * configure.ac (HAVE_AS_IX86_REP_LOCK_PREFIX): Also require that the
6542 assembler accept 'rep bsf ...', 'rep bsr ...', 'rep ret' and 'rep nop'.
6543 * configure: Regenerated.
6544 * config/i386/i386.md (simple_return_internal_long): Use %;
6545 (ctz<mode>2): Likewise.
6546 (*pause): Likewise.
6547
6548 2012-07-02 Oleg Endo <olegendo@gcc.gnu.org>
6549
6550 PR target/51244
6551 * config/sh/predicates.md (t_reg_operand, negt_reg_operand): New
6552 predicates.
6553 * config/sh/sh-protos.h (get_t_reg_rtx): New prototype.
6554 * config/sh/sh.c (get_t_reg_rtx): New function. Use it when invoking
6555 gen_branch_true and gen_branch_false.
6556 * config/sh/sh.md: Use get_t_reg_rtx when invoking gen_branch_true and
6557 gen_branch_false.
6558 (branch_true, branch_false): Use t_reg_operand predicate.
6559 (*branch_true, *branch_false): Delete.
6560 (movt): Use t_reg_operand predicate.
6561 (*negnegt): Use negt_reg_operand predicate and fold little and big
6562 endian variants.
6563 (*movtt): Use t_reg_operand and fold little and big endian variants.
6564 (*movt_qi): Delete.
6565
6566 2012-07-02 Steven Bosscher <steven@gcc.gnu.org>
6567
6568 * stmt.c (emit_case_bit_tests): Remove.
6569 (expand_case): Remove expand_switch_using_bit_tests_p code.
6570 * tree-switch-conversion.c (hoist_edge_and_branch_if_true): New.
6571 (MAX_CASE_BIT_TESTS): Moved from stmt.c to here.
6572 (lshift_cheap_p): Likewise.
6573 (expand_switch_using_bit_tests_p): Likewise.
6574 (struct case_bit_test): Likewise.
6575 (case_bit_test_cmp): Likewise.
6576 (emit_case_bit_tests): New implementation for GIMPLE.
6577 (gen_inbound_check): Do not release post-dominator info here.
6578 (process_switch): Reorder code. Expand as bit tests if it
6579 looks like a win.
6580 (do_switchconv): Release post-dominator info here if something changed.
6581 (struct gimple_opt_pass): Verify more.
6582 * tree.h (expand_switch_using_bit_tests_p): Remove prototype.
6583
6584 2012-07-02 Martin Jambor <mjambor@suse.cz>
6585
6586 PR middle-end/38474
6587 * ipa-prop.c (compute_known_type_jump_func): Put BINFO check before a
6588 dynamic type change check.
6589
6590 2012-07-02 Richard Guenther <rguenther@suse.de>
6591 Michael Matz <matz@suse.de>
6592 Tobias Grosser <tobias@grosser.es>
6593 Sebastian Pop <sebpop@gmail.com>
6594
6595 * Makefile.in: Remove PPL flags in favor of ISL ones.
6596 (BACKENDLIBS): Remove PPL libs.
6597 (INCLUDES): Remove PPL includes in favor of ISL ones.
6598 (graphite-clast-to-gimple.o): Remove graphite-dependences.h and
6599 graphite-cloog-compat.h dependencies.
6600 (graphite-dependences.o): Likewise.
6601 (graphite-poly.o): Likewise.
6602 * configure.ac: Declare ISL vars instead of PPL ones.
6603 * configure: Regenerated.
6604 * doc/install.texi: Replace PPL requirement documentation with ISL one.
6605 * graphite-blocking.c: Remove PPL code, add ISL equivalent.
6606 * graphite-clast-to-gimple.c: Likewise.
6607 * graphite-dependences.c: Likewise.
6608 * graphite-interchange.c: Likewise.
6609 * graphite-poly.h: Likewise.
6610 * graphite-poly.c: Likewise.
6611 * graphite-sese-to-poly.c: Likewise.
6612 * graphite.c: Likewise.
6613 * graphite-scop-detection.c: Re-arrange includes.
6614 * graphite-cloog-util.c: Remove.
6615 * graphite-cloog-util.h: Likewise.
6616 * graphite-ppl.h: Likewise.
6617 * graphite-ppl.c: Likewise.
6618 * graphite-dependences.h: Likewise.
6619
6620 2012-07-02 Richard Guenther <rguenther@suse.de>
6621
6622 Merge from graphite branch
6623 2011-07-21 Tobias Grosser <tobias@grosser.es>
6624
6625 * Makefile.in (graphite-clast-to-gimple.o, graphite-cloog-util.o):
6626 Remove graphite-cloog-util.h.
6627 * graphite-clast-to-gimple.c (gcc_type_for_iv_of_clast_loop,
6628 build_iv_mapping, translate_clast_user, translate_clast,
6629 free_scattering, initialize_cloog_names, build_cloog_prog,
6630 create_params_index): Do not use old compatibility functions.
6631 (clast_name_to_index, set_cloog_options): Remove code for legacy cloog.
6632 * graphite-cloog-util.c (openscop_print_cloog_matrix): Do not use old
6633 compatibility functions.
6634 (new_Cloog_Scattering_from_ppl_Polyhedron): Remove code for legacy
6635 cloog.
6636 * graphite-cloog-util.h: Remove include of graphite-cloog-util.h.
6637 * graphite.c (graphite.c): Do not call outdated cloog_initialize() and
6638 cloog_finalize().
6639 * graphite-cloog-compat.h: Remove.
6640
6641 2011-08-09 Tobias Grosser <tobias@grosser.es>
6642
6643 * graphite-clast-to-gimple.c (new_clast_name_index): Store a copy
6644 of the string, no just a reference.
6645 (clast_name_index): Add a new field, that specifies if we need to free
6646 the name.
6647 (free_clast_name_index): If necessary, free the name string.
6648 (clast_name_index_elt_info): Calculate the hash based on the string
6649 content, not the memory location it is stored in.
6650 (clast_name_to_level): Specify that we do not need to free the name.
6651 (clast_name_to_index): Dito.
6652 (clast_name_to_lb_ub): Dito.
6653 (eq_clast_name_indexes): Compare the strings, not their base pointers.
6654 (free_scattering): Removed.
6655 (initialize_cloog_names): Renamed to add_names_to_union_domain().
6656 (add_names_to_union_domain): Changed to work on a union_domain,
6657 instead of a CloogNames structure.
6658 (build_cloog_prog): Removed.
6659 (build_cloog_union_domain): New.
6660 (generate_cloog_input): New.
6661 (scop_to_clast): Use CloogInput instead of CloogProgram.
6662 (print_generated_program): Adapt to new scop_to_clast() and do not
6663 print the CloogProgram any more.
6664 (create_params_index): Removed, functionality integrated in
6665 add_names_to_union_domain().
6666 (gloog): Adapt to new scop_to_clast().
6667 * graphite-clast-to-gimple.h (scop_to_clast): Remove.
6668
6669 2012-01-11 Tobias Grosser <tobias@grosser.es>
6670
6671 * graphite-clast-to-gimple.c (clast_name_to_index,
6672 clast_name_to_lb_ub, clast_name_to_gcc): Change types.
6673 (clast_to_gcc_expression): Add clast_expr_name as a new
6674 case. Do not assume a clast_expr_term points always to a
6675 clast_expr_name.
6676 (type_for_clast_term): Do not assume a clast_expr_term points always to
6677 a clast_expr_name.
6678 (type_for_clast_name): New.
6679 (type_for_clast_expr): Add clast_expr_name as a new case.
6680
6681 2011-08-03 Sebastian Pop <sebpop@gmail.com>
6682
6683 * graphite-cloog-util.c (new_Cloog_Domain_from_ppl_Polyhedron,
6684 new_Cloog_Scattering_from_ppl_Polyhedron,
6685 new_Cloog_Domain_from_ppl_Pointset_Powerset): Remove ATTRIBUTE_UNUSED.
6686
6687 2012-07-02 Jakub Jelinek <jakub@redhat.com>
6688
6689 PR tree-optimization/53645
6690 * tree-vect-generic.c (expand_vector_divmod): Use TYPE_MODE (type)
6691 instead of TYPE_MODE (wider_type) as can_vec_perm_p argument.
6692
6693 2012-07-01 Wei Guozhi <carrot@google.com>
6694
6695 PR target/53447
6696 * config/arm/arm-protos.h (const_ok_for_dimode_op): New prototype.
6697 * config/arm/arm.c (const_ok_for_dimode_op): New function.
6698 * config/arm/constraints.md (Dd): New constraint.
6699 * config/arm/predicates.md (arm_adddi_operand): New predicate.
6700 * config/arm/arm.md (adddi3): Extend it to handle constants.
6701 (arm_adddi3): Likewise.
6702 (addsi3_carryin_<optab>): Extend it to handle sbc case.
6703 (addsi3_carryin_alt2_<optab>): Likewise.
6704 * config/arm/neon.md (adddi3_neon): Extend it to handle constants.
6705
6706 2012-06-30 Nathan Sidwell <nathan@acm.org>
6707
6708 * coverage.c (bbg_file_stamp): New.
6709 (read_counts_file): Merge incoming stamp with bbg_file_stamp.
6710 (build_info): Write bbg_file_stamp.
6711 (coverage_init): Initialize bbg_file_stamp. Read counts file
6712 before writing graph header.
6713 (coverage_finish): Don't unlink the data file if we can generate a
6714 unique file stamp.
6715 * tree.h (crc32_unsigned): Declare.
6716 * tree.c (crc32_unsigned_bits): New, broken out of ...
6717 (crc32_byte): ... here. Use it.
6718 (crc32_unsigned): New.
6719
6720 2012-06-29 Cary Coutant <ccoutant@google.com>
6721
6722 * dwarf2out.c (add_pubname_string): Don't check for want_pubnames.
6723 (gen_subprogram_die): Don't add pubname if want_pubnames is false.
6724 (gen_variable_die): Likewise.
6725 (gen_namespace_die): Likewise.
6726
6727 2012-06-29 Eric Botcazou <ebotcazou@adacore.com>
6728
6729 * tree-eh.c (lower_try_finally_switch): Really put the location of the
6730 last statement of the finally block onto the switch.
6731
6732 2012-06-29 H.J. Lu <hongjiu.lu@intel.com>
6733
6734 PR target/53539
6735 * config/i386/gnu-user64.h (WCHAR_TYPE): Use "int" only for
6736 TARGET_LP64.
6737
6738 2012-06-29 Sterling Augustine <saugustine@google.com>
6739
6740 * dwarf2out.c (add_pubname): Add comment.
6741 (add_pubtype): Fix indentation.
6742 (gen_enumeration_type_die): Likewise.
6743
6744 2012-06-29 Jakub Jelinek <jakub@redhat.com>
6745
6746 * tree-vect-generic.c (expand_vector_divmod): For even/odd
6747 widening multiply, put even always as first argument to VEC_PERM_EXPR.
6748
6749 2012-06-29 Richard Henderson <rth@redhat.com>
6750
6751 * tree-vect-generic.c: Include target.h.
6752 (expand_vector_divmod): Use builtin_mul_widen_even/odd if supported.
6753 * Makefile.in (tree-vect-generic.o): Update.
6754
6755 2012-06-29 Steven Bosscher <steven@gcc.gnu.org>
6756
6757 * configure.ac: Remove special gtfiles case for C.
6758 * configure: Regenerate.
6759 * Makefile.in: Remove C front-end hooks and build hooks that
6760 will be picked up from c/Make-lang.in now.
6761 Add tree-mudflap to C_COMMON_OBJS.
6762 * gengtype.c (files_rules): Adjust gt-files for c/c-decl.c.
6763 * config/vms/vms.c: Look for c-tree.h in c/.
6764 * doc/gty.texi: Remove reference to c-config-lang.in.
6765 * doc/sourcebuild.texi: Document the c/ subdirectory.
6766
6767 2012-06-29 Steven Bosscher <steven@gcc.gnu.org>
6768
6769 * system.h (CASE_USE_BIT_TESTS): Poison.
6770 * stmt.c (CASE_USE_BIT_TESTS): Fold away into its only user ...
6771 (expand_switch_using_bit_tests_p): ...here.
6772 * doc/tm.texi.in (CASE_USE_BIT_TESTS): Remove documentation.
6773 * doc/tm.texi (CASE_USE_BIT_TESTS): Regenerate.
6774
6775 2012-06-29 Steven Bosscher <steven@gcc.gnu.org>
6776
6777 * system.h (IFCVT_EXTRA_FIELDS): Poison.
6778 (IFCVT_INIT_EXTRA_FIELDS): Poison.
6779 * basic-block.h (struct ce_if_block): Remove IFCVT_EXTRA_FIELDS.
6780 * ifcvt.c (find_if_header): Use IFCVT_MACHDEP_INIT instead of
6781 IFCVT_INIT_EXTRA_FIELDS.
6782 * gengtype-parse.c (struct_field_seq): Remove obsolete comment.
6783 * config/frv/frv.h (IFCVT_INIT_EXTRA_FIELDS): Rename to
6784 IFCVT_MACHDEP_INIT.
6785 * config/frv/frv.c (frv_ifcvt_init_extra_fields): Rename to
6786 frv_ifcvt_machdep_init.
6787 * doc/tm.texi.in (IFCVT_INIT_EXTRA_FIELDS, IFCVT_EXTRA_FIELDS):
6788 Remove documentation.
6789 (IFCVT_MACHDEP_INIT): Document.
6790 * doc/tm.texi: Regenerate.
6791
6792 2012-06-29 Nick Clifton <nickc@redhat.com>
6793
6794 * config/lm32/lm32.c (lm32_compute_frame_size): Fix typo.
6795
6796 2012-06-29 Jakub Jelinek <jakub@redhat.com>
6797
6798 * tree-vect-stmts.c (vectorizable_operation): Check both
6799 VEC_WIDEN_MULT_LO_EXPR and VEC_WIDEN_MULT_HI_EXPR optabs.
6800 Verify that operand[0]'s mode is TYPE_MODE (wide_vectype).
6801
6802 2012-06-28 Richard Henderson <rth@redhat.com>
6803
6804 * doc/generic.texi (MULT_HIGHPART_EXPR): Document it.
6805
6806 2012-06-28 Jakub Jelinek <jakub@redhat.com>
6807
6808 PR tree-optimization/51581
6809 * tree-vect-stmts.c (permute_vec_elements): Add forward decl.
6810 (vectorizable_operation): Handle vectorization of MULT_HIGHPART_EXPR
6811 also using VEC_WIDEN_MULT_*_EXPR or builtin_mul_widen_* plus
6812 VEC_PERM_EXPR if vector MULT_HIGHPART_EXPR isn't supported.
6813 * tree-vect-patterns.c (vect_recog_divmod_pattern): Use
6814 MULT_HIGHPART_EXPR instead of VEC_WIDEN_MULT_*_EXPR and shifts.
6815
6816 PR tree-optimization/53645
6817 * tree-vect-generic.c (expand_vector_divmod): Use MULT_HIGHPART_EXPR
6818 instead of VEC_WIDEN_MULT_{HI,LO}_EXPR followed by VEC_PERM_EXPR
6819 if possible.
6820
6821 2012-06-28 Georg-Johann Lay <avr@gjlay.de>
6822
6823 PR 53595
6824 * config/avr/avr.c (avr_hard_regno_call_part_clobbered): New.
6825 * config/avr/avr-protos.h (avr_hard_regno_call_part_clobbered): New.
6826 * config/avr/avr.h (HARD_REGNO_CALL_PART_CLOBBERED): Forward to
6827 avr_hard_regno_call_part_clobbered.
6828
6829 2012-06-28 Richard Guenther <rguenther@suse.de>
6830
6831 PR middle-end/53790
6832 * expr.c (expand_expr_real_1): Verify if the type is complete
6833 before inspecting its size.
6834
6835 2012-06-28 Andreas Schwab <schwab@linux-m68k.org>
6836
6837 * doc/include/gpl.texi: Remove.
6838 * doc/sourcebuild.texi (Texinfo Manuals): Don't mention gpl.texi.
6839
6840 2012-06-28 Jakub Jelinek <jakub@redhat.com>
6841
6842 PR tree-optimization/53645
6843 * tree-vect-generic.c (add_rshift): New function.
6844 (expand_vector_divmod): New function.
6845 (expand_vector_operation): Use it for vector integer
6846 TRUNC_{DIV,MOD}_EXPR by VECTOR_CST.
6847 * tree-vect-patterns.c (vect_recog_divmod_pattern): Replace
6848 unused lguup variable with dummy_int.
6849
6850 2012-06-28 OLivier Hainque <hainque@adacore.com>
6851
6852 * expr.c (convert_move): Latch mem integer inputs into a
6853 register before expanding a multi-instructions sequence.
6854
6855 2012-06-28 Alexandre Oliva <aoliva@redhat.com>
6856 Uros Bizjak <ubizjak@gmail.com>
6857 Jakub Jelinek <jakub@redhat.com>
6858
6859 PR debug/53706
6860 PR debug/47624
6861 * var-tracking.c (vt_emit_notes): Release loc_exp_dep_pool...
6862 (vt_finalize): ... here instead, if needed.
6863
6864 2012-06-28 Alexandre Oliva <aoliva@redhat.com>
6865
6866 PR debug/53740
6867 PR debug/52983
6868 PR debug/48866
6869 * dce.c (word_dce_process_block): Check whether inserting debug
6870 temps are needed even for needed insns.
6871 (dce_process_block): Likewise.
6872 * df-problems.c (dead_debug_add): Add comment about multi-regs.
6873 (dead_debug_insert_temp): Likewise. Don't subreg when we're
6874 setting fewer regs than a multi-reg requires.
6875
6876 2012-06-27 Richard Henderson <rth@redhat.com>
6877
6878 * config/alpha/alpha.c (alpha_dimode_u): New.
6879 (alpha_init_builtins): Initialize it, and use it.
6880 (alpha_fold_builtin_cmpbge): Use alpha_dimode_u.
6881 (alpha_fold_builtin_zapnot, alpha_fold_builtin_insxx): Likewise.
6882 (alpha_fold_vector_minmax, alpha_fold_builtin_perr): Likewise.
6883 (alpha_fold_builtin_pklb, alpha_fold_builtin_pkwb): Likewise.
6884 (alpha_fold_builtin_unpkbl, alpha_fold_builtin_unpkbw): Likewise.
6885 (alpha_fold_builtin_cttz, alpha_fold_builtin_ctlz): Likewise.
6886 (alpha_fold_builtin_ctpop): Likewise.
6887 (alpha_fold_builtin_umulh): Remove.
6888 (alpha_fold_builtin): Use MULT_HIGHPART_EXPR for UMULH; fix
6889 typo in MAX_ARGS check.
6890
6891 2012-06-27 Richard Henderson <rth@redhat.com>
6892
6893 * tree.def (MULT_HIGHPART_EXPR): New.
6894 * cfgexpand.c (expand_debug_expr): Ignore it.
6895 * expr.c (expand_expr_real_2): Handle it.
6896 * fold-const.c (int_const_binop_1): Likewise.
6897 * optabs.c (optab_for_tree_code): Likewise.
6898 * tree-cfg.c (verify_gimple_assign_binary): Likewise.
6899 * tree-inline.c (estimate_operator_cost): Likewise.
6900 * tree-pretty-print.c (dump_generic_node): Likewise.
6901 (op_code_prio, op_symbol_code): Likewise.
6902 * tree.c (commutative_tree_code): Likewise. Also handle
6903 WIDEN_MULT_EXPR, VEC_WIDEN_MULT_HI_EXPR, VEC_WIDEN_MULT_LO_EXPR.
6904
6905 2012-06-27 Richard Henderson <rth@redhat.com>
6906
6907 PR target/53749
6908 * config/i386/i386.c (ix86_rtx_costs): Fix typo vs UNITS_PER_WORD
6909 in 2012-06-23 change. Adjust two other DImode tests as well.
6910
6911 2012-06-27 Nick Clifton <nickc@redhat.com>
6912
6913 * config/rx/rx.md (comparesi3_extend): Remove = modifier from
6914 input operand.
6915
6916 2012-06-27 Richard Guenther <rguenther@suse.de>
6917
6918 PR middle-end/53676
6919 * tree-chrec.c (chrec_convert_1): Represent truncation to
6920 a type with undefined overflow as truncation to an unsigned
6921 type converted to the type with undefined overflow.
6922 * tree-scalar-evolution.c (interpret_rhs_expr): For computing
6923 the scalar evolution of a truncated widened operation avoid
6924 looking at the non-existing evolution of the widened operation
6925 result.
6926
6927 2012-06-27 Richard Guenther <rguenther@suse.de>
6928
6929 PR tree-optimization/53774
6930 * tree-ssa-reassoc.c (get_rank): All default defs have
6931 precomputed rank.
6932 (init_reassoc): Precompute rank for all SSA default defs.
6933
6934 2012-06-27 Nick Clifton <nickc@redhat.com>
6935
6936 * config/rx/rx.md (simple_return): Use the simple_return rtx.
6937
6938 2012-06-26 Richard Henderson <rth@redhat.com>
6939
6940 * config/i386/i386.c (ix86_rtx_costs): Use standard_sse_constant_p
6941 and don't fall thru from standard_80387_constant_p to the memory
6942 fallback.
6943
6944 2012-06-26 Richard Henderson <rth@redhat.com>
6945
6946 * config/i386/i386.c (bdesc_args): Update. Change
6947 IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V4SI to OPTION_MASK_ISA_SSE2.
6948 (IX86_BUILTIN_VEC_WIDEN_SMUL_EVEN_V4SI): New.
6949 (ix86_builtin_mul_widen_even): Use it.
6950 (ix86_builtin_mul_widen_odd): Relax SMUL_ODD from sse4 to sse2.
6951 (ix86_expand_mul_widen_evenodd): Handle signed for sse2.
6952 * config/i386/sse.md (vec_widen_<s>mult_hi_<V124_AVX2>): Allow
6953 for all SSE2.
6954 (vec_widen_<s>mult_lo_<V124_AVX2>): Likewise.
6955 (vec_widen_<s>mult_odd_<VI4_AVX2>): Likewise. Relax from V124_AVX2.
6956 (vec_widen_smult_even_v4si): New.
6957
6958 2012-06-26 Richard Henderson <rth@redhat.com>
6959
6960 * config/i386/sse.md (mul<VI8_AVX2>3): Change from insn_and_split
6961 to expander; move guts to ...
6962 * config/i386/i386.c (ix86_expand_sse2_mulvxdi3): ... here. Add
6963 highparts before shifting up.
6964 * config/i386/i386-protos.h: Update.
6965
6966 2012-06-26 Steven Bosscher <steven@gcc.gnu.org>
6967
6968 * system.h (USE_COMMON_FOR_ONE_ONLY): Poison.
6969 * defaults.h (USE_COMMON_FOR_ONE_ONLY): Do not provide default.
6970 * config/darwin.h (USE_COMMON_FOR_ONE_ONLY): Do not define.
6971
6972 2012-06-26 Alexandre Oliva <aoliva@redhat.com>
6973
6974 * var-tracking.c (vt_add_function_parameter): Use a preserved
6975 VALUE for the MEM address of an incoming parameter.
6976
6977 2012-06-26 Sterling Augustine <saugustine@google.com>
6978
6979 * dwarf2out.c (output_pubnames): Add check for DW_TAG_enumerator.
6980 (prune_unused_types): Likewise.
6981
6982 2012-06-26 Steven Bosscher <steven@gcc.gnu.org>
6983
6984 * system.h (UNALIGNED_SHORT_ASM_OP, UNALIGNED_INT_ASM_OP,
6985 UNALIGNED_LONG_ASM_OP, UNALIGNED_DOUBLE_INT_ASM_OP): Poison.
6986 * vmsdbgout.c (UNALIGNED_SHORT_ASM_OP, UNALIGNED_INT_ASM_OP,
6987 UNALIGNED_LONG_ASM_OP, UNALIGNED_DOUBLE_INT_ASM_OP): Rename to
6988 VMS_UNALIGNED_SHORT_ASM_OP, VMS_UNALIGNED_INT_ASM_OP,
6989 VMS_UNALIGNED_LONG_ASM_OP, and VMS_UNALIGNED_DOUBLE_INT_ASM_OP.
6990 * config/microblaze/microblaze.h (UNALIGNED_SHORT_ASM_OP,
6991 UNALIGNED_INT_ASM_OP, UNALIGNED_DOUBLE_INT_ASM_OP): Do not define.
6992 * doc/tm.texi.in: Remove UNALIGNED_INT_ASM_OP reference from the
6993 documentation.
6994 * doc/tm.texi: Regenerate.
6995 * doc/cpp.texi: Make example for #error generic.
6996 * config/frv/frv.h: Fix example text to match tm.texi.
6997
6998 2012-06-26 Bill Schmidt <wschmidt@linux.ibm.com>
6999
7000 * tree-pass.h (pass_strength_reduction): New decl.
7001 * tree-ssa-loop-ivopts.c (initialize_costs): Make non-static.
7002 (finalize_costs): Likewise.
7003 * timevar.def (TV_TREE_SLSR): New timevar.
7004 * gimple-ssa-strength-reduction.c: New.
7005 * tree-flow.h (initialize_costs): New decl.
7006 (finalize_costs): Likewise.
7007 * Makefile.in (tree-ssa-strength-reduction.o): New dependencies.
7008 * passes.c (init_optimization_passes): Add pass_strength_reduction.
7009
7010 2012-06-26 Matt Turner <mattst88@gmail.com>
7011
7012 * doc/extend.texi (__builtin_arm_tinsrb): Add missing second parameter.
7013 (__builtin_arm_tinsrh): Likewise.
7014 (__builtin_arm_tinsrw): Likewise.
7015 (__builtin_arm_wsadb): Add missing v2si parameter.
7016 (__builtin_arm_wsadh): Likewise.
7017 (__builtin_arm_getwcx): Delete.
7018 (__builtin_arm_setwcx): Delete.
7019 (__builtin_arm_getwcgr0): Add.
7020 (__builtin_arm_getwcgr1): Add.
7021 (__builtin_arm_getwcgr2): Add.
7022 (__builtin_arm_getwcgr3): Add.
7023 (__builtin_arm_setwcgr0): Add.
7024 (__builtin_arm_setwcgr1): Add.
7025 (__builtin_arm_setwcgr2): Add.
7026 (__builtin_arm_setwcgr3): Add.
7027
7028 2012-06-26 Richard Guenther <rguenther@suse.de>
7029
7030 Revert
7031 2012-06-21 Richard Guenther <rguenther@suse.de>
7032
7033 * tree-inline.c (estimate_num_insns): Estimate call cost for
7034 tailcalls properly.
7035
7036 2012-06-26 Steven Bosscher <steven@gcc.gnu.org>
7037
7038 PR other/33190
7039 * doc/tm.texi.in: Document LOGICAL_OP_NON_SHORT_CIRCUIT.
7040 * doc/tm.texi: Regenerate.
7041
7042 2012-06-26 Steven Bosscher <steven@gcc.gnu.org>
7043
7044 PR other/33190
7045 * config/mips/mips.h: Do not define ALL_COP_ADDITIONAL_REGISTER_NAMES.
7046 * config/frv/frv.h: Do not define REVERSE_CONDEXEC_PREDICATES_P.
7047 * doc/tm.texi.in: Remove documentation for unused target macros
7048 ALL_COP_ADDITIONAL_REGISTER_NAMES, DBX_OUTPUT_LBRAC, DBX_OUTPUT_NFUN,
7049 DBX_OUTPUT_RBRAC, RANGE_TEST_NON_SHORT_CIRCUIT, REAL_VALUE_TRUNCATE,
7050 REVERSE_CONDEXEC_PREDICATES_P, TARGET_ALIGN_ANON_BITFIELDS, and
7051 TARGET_NARROW_VOLATILE_BITFIELDS.
7052 Document that MD_HANDLE_UNWABI is a macro in libgcc.
7053 * doc/tm.texi: Regenerate.
7054 * system.h: Poison target macros
7055 ALL_COP_ADDITIONAL_REGISTER_NAMES, DBX_OUTPUT_LBRAC, DBX_OUTPUT_NFUN,
7056 DBX_OUTPUT_RBRAC, RANGE_TEST_NON_SHORT_CIRCUIT, REAL_VALUE_TRUNCATE,
7057 REVERSE_CONDEXEC_PREDICATES_P, TARGET_ALIGN_ANON_BITFIELDS, and
7058 TARGET_NARROW_VOLATILE_BITFIELDS
7059
7060 2012-06-26 Jan Hubicka <jh@suse.cz>
7061
7062 PR lto/53572
7063 * cgraph.h (varpool_can_remove_if_no_refs): Fix handling of
7064 used symbols.
7065
7066 2012-06-26 Dehao Chen <dehao@google.com>
7067
7068 * tree-inline.c: (expand_call_inline): Ensure that lexical block's
7069 source location is consistant with the call stmt.
7070
7071 2012-06-26 Ulrich Weigand <ulrich.weigand@linaro.org>
7072
7073 PR tree-optimization/53729
7074 PR tree-optimization/53636
7075 * tree-vect-slp.c (vect_slp_analyze_bb_1): Delay call to
7076 vect_verify_datarefs_alignment until after statements have
7077 been marked as relevant/irrelevant.
7078 * tree-vect-data-refs.c (vect_verify_datarefs_alignment):
7079 Skip irrelevant statements.
7080 (vect_enhance_data_refs_alignment): Use STMT_VINFO_RELEVANT_P
7081 instead of STMT_VINFO_RELEVANT.
7082 (vect_get_data_access_cost): Do not check for supportable
7083 alignment before calling vect_get_load_cost/vect_get_store_cost.
7084 * tree-vect-stmts.c (vect_get_store_cost): Do not abort when
7085 handling unsupported alignment.
7086 (vect_get_load_cost): Likewise.
7087
7088 2012-06-25 Steven Bosscher <steven@gcc.gnu.org>
7089
7090 * config/rl78/rl78.h: Do not undefine DONT_USE_BUILTIN_SETJMP.
7091 Do not define JMP_BUF_SIZE.
7092
7093 2012-06-26 Jakub Jelinek <jakub@redhat.com>
7094
7095 PR tree-optimization/53748
7096 * tree-ssa-phiopt.c (conditional_replacement): Only optimize
7097 if arg0/arg1 have integral or pointer types.
7098
7099 2012-06-25 Richard Henderson <rth@redhat.com>
7100
7101 * config/i386/sse.md (sse2_sse4_1): Remove code attr.
7102 (<s>dot_prodv4si, <s>dot_prodv8si): Remove
7103 (sdot_prodv4si): New; handle only XOP.
7104
7105 2012-06-25 Richard Henderson <rth@redhat.com>
7106
7107 * config/i386/i386-builtin-types.def (V4UDI, V8USI): New.
7108 (V2UDI_FUNC_V4USI_V4USI): New.
7109 (V4UDI_FUNC_V8USI_V8USI): New.
7110 * config/i386/i386.c (ix86_expand_args_builtin): Handle them.
7111 (IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V4SI): New.
7112 (IX86_BUILTIN_VEC_WIDEN_SMUL_ODD_V8SI): New.
7113 (IX86_BUILTIN_VEC_WIDEN_UMUL_ODD_V4SI): New.
7114 (IX86_BUILTIN_VEC_WIDEN_UMUL_ODD_V8SI): New.
7115 (IX86_BUILTIN_VEC_WIDEN_UMUL_EVEN_V4SI): New.
7116 (IX86_BUILTIN_VEC_WIDEN_UMUL_EVEN_V8SI): New.
7117 (bdesc_args): Add them.
7118 (ix86_builtin_mul_widen_even, ix86_builtin_mul_widen_odd): New.
7119 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_EVEN): New.
7120 (TARGET_VECTORIZE_BUILTIN_MUL_WIDEN_ODD): New.
7121 (ix86_expand_mul_widen_evenodd): Use xop_pmacsdqh.
7122 * config/i386/sse.md (vec_widen_<s>mult_odd_<V124_AVX2>): New.
7123
7124 2012-06-25 Richard Henderson <rth@redhat.com>
7125
7126 * config/i386.sse.md (mul<VI4_AVX2>3): Use xop_pmacsdd.
7127
7128 2012-06-25 Richard Henderson <rth@redhat.com>
7129
7130 * config/i386/i386.c (ix86_rtx_costs) [MULT]: Only apply XOP cost
7131 to V16QImode.
7132 (ix86_expand_vec_interleave): New.
7133 (ix86_expand_mul_widen_evenodd): New.
7134 (ix86_expand_mul_widen_hilo): New.
7135 (ix86_expand_sse2_mulv4si3): Use ix86_expand_mul_widen_evenodd.
7136 * config/i386/i386.md (u_bool) New code attr.
7137 * config/i386/predicates.md
7138 (nonimmediate_or_const_vector_operand): Remove.
7139 * config/i386/sse.md (mul<VI4_AVX2>3): Don't use it; don't test
7140 both AVX and SSE4_1.
7141 (vec_widen<s>mult_hi_<VI2_AVX2>): Remove.
7142 (vec_widen<s>mult_lo_<VI2_AVX2>): Remove.
7143 (vec_widen<s>mult_hi_v8si): Remove.
7144 (vec_widen<s>mult_lo_v8si): Remove.
7145 (vec_widen_smult_hi_v4si): Remove.
7146 (vec_widen_smult_lo_v4si): Remove.
7147 (vec_widen_umult_hi_v4si): Remove.
7148 (vec_widen_umult_lo_v4si): Remove.
7149 (vec_widen_<s>mult_hi_<VI124_AVX2>): New.
7150 (vec_widen_<s>mult_lo_<VI124_AVX2>): New.
7151 * config/i386/i386-protos.h: Update.
7152
7153 2012-06-25 Christophe Lyon <christophe.lyon@st.com>
7154
7155 * config/arm/neon.md (UNSPEC_VLD1_DUP): Remove.
7156 (neon_vld1_dup): Restrict to VQ operands.
7157 (neon_vld1_dupv2di): New, fixes vld1q_dup_s64.
7158
7159 2012-06-25 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
7160 James Greenhalgh <james.greenhalgh@arm.com>
7161
7162 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Add new built-ins.
7163 (TARGET_FMA): New macro.
7164 (TARGET_ARM_QBIT, TARGET_ARM_SAT): Likewise.
7165 (TARGET_ARM_ARCH): Likewise.
7166 (TARGET_ARM_ARCH_ISA_THUMB): Likewise.
7167 (TARGET_V6M, TARGET_V7M): Likewise.
7168 (TARGET_ARM_ARCH_PROFILE): Likewise.
7169 (TARGET_ARM_FEATURE_LDREX): Likewise.
7170 (TARGET_ARM_FP, TARGET_NEON_FP): Likewise.
7171 (ARM_MIN_ENUM_SIZE): Likewise.
7172 * config/arm/arm.c (arm_file_start): Refactor appropriately.
7173 (base_architecture): New enumeration.
7174 (arm_base_arch): New global variable.
7175 (processors): Add field base_arch.
7176 (ARM_ARCH, ARM_CORE): Adjust accordingly.
7177 (arm_option_override): Add initialization of arm_base_arch.
7178 * doc/cpp.texi (system-specific predefined macros.): Change.
7179
7180 2012-06-25 Jakub Jelinek <jakub@redhat.com>
7181
7182 PR target/53759
7183 * config/i386/sse.md (sse_loadlps): Use x m x constraints instead
7184 of x x x in the vmovlps load alternative.
7185
7186 2012-06-25 Richard Sandiford <rdsandiford@googlemail.com>
7187
7188 PR debug/53740
7189 * df.h (dead_debug_add): Remove third argument.
7190 * df-problems.c (dead_debug_add): Likewise. Use the REGNO of the
7191 REG that we want to replace instead.
7192 (dead_debug_insert_temp): Use the REGNO of the reg that we want
7193 to replace instead of DF_REF_REGNO. Require there to always be
7194 at least one such use. Check for cases where the same location
7195 has more than df_ref associated with it.
7196 (df_note_bb_compute): Remove third dead_debug_add argument.
7197 * dce.c (word_dce_process_block): Likewise.
7198
7199 2012-06-25 Steven Bosscher <steven@gcc.gnu.org>
7200
7201 * config/v850/v850.c: Remove redundant extern declarations for
7202 last_assemble_variable_decl and size_directive_output.
7203
7204 * doc/tm.texi.in: Document JMP_BUF_SIZE.
7205 * doc/tm.texi: Regenerate.
7206 * config/sparc/sparc.h (JMP_BUF_SIZE): Do not define.
7207 * config/pa/pa.h (JMP_BUF_SIZE): Likewise.
7208 * config/stormy16/stormy16.h: Likewise.
7209
7210 * config/picochip/picochip.c: Do not define DONT_USE_BUILTIN_SETJMP.
7211
7212 * doc/sourcebuild.texi: Add missing subdirectories.
7213
7214 2012-06-25 Tristan Gingold <gingold@adacore.com>
7215
7216 * config/i386/i386.h: Fix typo.
7217
7218 2012-06-25 Tristan Gingold <gingold@adacore.com>
7219
7220 * config/i386/winnt.c (i386_pe_seh_end_prologue): Move code to ...
7221 (seh_cfa_adjust_cfa): ... that function.
7222 (seh_emit_stackalloc): Do not emit out of range values.
7223 * config/i386/i386.md: Delete unused UNSPEC_REG_SAVE,
7224 UNSPEC_DEF_CFA constants.
7225 * config/i386/i386.h (SEH_MAX_FRAME_SIZE): Define.
7226 * config/i386/i386.c (ix86_frame_pointer_required): Required
7227 for very large frames on SEH target.
7228 (ix86_compute_frame_layout): Save area is before frame pointer
7229 on SEH target. Handle very large frames.
7230 (ix86_expand_prologue): Likewise.
7231
7232 2012-06-24 Steven Bosscher <steven@gcc.gnu.org>
7233
7234 * output.h: (current_function_is_leaf,
7235 current_function_sp_is_unchanging,
7236 current_function_uses_only_leaf_regs): Remove.
7237 * function.c (current_function_is_leaf,
7238 current_function_sp_is_unchanging,
7239 current_function_uses_only_leaf_regs): Remove.
7240 (rest_of_handle_check_leaf_regs): Set crtl->uses_only_leaf_regs
7241 instead of current_function_uses_only_leaf_regs.
7242 * function.h (struct rtl_data): New fields sp_is_unchanging,
7243 is_leaf, uses_only_leaf_regs.
7244 * resource.c (init_resource_info): Replace current_function_is_leaf,
7245 current_function_sp_is_unchanging, and
7246 current_function_uses_only_leaf_regs with new crtl fields.
7247 * sdbout.c (sdbout_symbol): Likewise.
7248 * df-core.c (rest_of_handle_df_initialize): Likewise.
7249 * ira.c (ira): Likewise.
7250 * final.c (final_start_function): Likewise.
7251 * reorg.c (fill_simple_delay_slots): Likewise.
7252 * regrename.c (check_new_reg_p): Likewise.
7253 * stack-ptr-mod.c (notice_stack_pointer_modification_1): Likewise.
7254 (notice_stack_pointer_modification): Likewise.
7255 * dbxout.c (dbxout_symbol): Likewise.
7256 (dbxout_parms): Likewise.
7257 * sel-sched.c (init_regs_for_mode): Likewise.
7258 * dwarf2out.c (dbx_reg_number): Likewise.
7259 (multiple_reg_loc_descriptor): Likewise.
7260 * config/i386/i386.c (ix86_frame_pointer_required): Likewise.
7261 (gen_pop): Likewise.
7262 (ix86_select_alt_pic_regnum): Likewise.
7263 (ix86_compute_frame_layout): Likewise.
7264 (ix86_finalize_stack_realign_flags): Likewise.
7265 (ix86_expand_epilogue): Likewise.
7266 * config/rs6000/rs6000.c (rs6000_stack_info): Likewise.
7267 * config/h8300/h8300.c (byte_reg): Likewise.
7268 * config/c6x/c6x.c (must_reload_pic_reg_p): Likewise.
7269 (c6x_save_reg): Likewise.
7270 (c6x_compute_frame_layout): Likewise.
7271 * config/pa/pa.c (pa_compute_frame_size): Likewise.
7272 (pa_output_function_prologue): Likewise.
7273 * config/stormy16/stormy16.c (struct xstormy16_stack_layout): Likewise.
7274 * config/sparc/sparc.md (attr "leaf_function"): Likewise.
7275 * config/sparc/sparc.c (sparc_initial_elimination_offset): Likewise.
7276 (sparc_expand_prologue): Likewise.
7277 (sparc_flat_expand_prologue): Likewise.
7278 (sparc_asm_function_prologue): Likewise.
7279 (sparc_output_mi_thunk): Likewise.
7280 (sparc_frame_pointer_required): Likewise.
7281 * config/epiphany/epiphany.c (epiphany_compute_function_type):
7282 Likewise.
7283 (epiphany_compute_frame_size): Likewise.
7284 * config/lm32/lm32.c (lm32_compute_frame_size): Likewise.
7285 * config/cris/cris.c (cris_md_asm_clobbers): Likewise.
7286 (cris_frame_pointer_required): Likewise.
7287 * config/tilepro/tilepro.c (emit_sp_adjust): Likewise.
7288 (tilepro_current_function_is_leaf): Likewise.
7289 * config/arm/arm.c (arm_compute_save_reg0_reg12_mask): Likewise.
7290 * config/pdp11/pdp11.c (pdp11_expand_epilogue): Likewise.
7291 * config/ia64/ia64.c (find_gr_spill): Likewise.
7292 (ia64_compute_frame_size): Likewise.
7293 (ia64_can_eliminate): Likewise.
7294 (ia64_initial_elimination_offset): Likewise.
7295 * config/m68k/m68k.c (m68k_save_reg): Likewise.
7296 (m68k_expand_epilogue): Likewise.
7297 * config/rx/rx.c (rx_get_stack_layout): Likewise.
7298 * config/tilegx/tilegx.c (tilegx_current_function_is_leaf): Likewise.
7299 * config/picochip/picochip.c (picochip_can_eliminate_link_sp_save):
7300 Likewise.
7301 (picochip_output_frame_debug): Likewise.
7302 * config/sh/sh.c (sh_media_register_for_return): Likewise.
7303 (sh_allocate_initial_value): Likewise.
7304 (sh_output_mi_thunk): Likewise.
7305 * config/microblaze/microblaze.c (microblaze_must_save_register):
7306 Likewise.
7307 (compute_frame_size): Likewise.
7308 (microblaze_initial_elimination_offset): Likewise.
7309 (microblaze_expand_prologue): Likewise.
7310 (microblaze_expand_epilogue): Likewise.
7311 * config/frv/frv.c (frv_expand_epilogue): Likewise.
7312 (frv_frame_pointer_required): Likewise.
7313 * config/spu/spu.c (get_pic_reg): Likewise.
7314 (direct_return): Likewise.
7315 (spu_expand_prologue): Likewise.
7316 (spu_expand_epilogue): Likewise.
7317 (spu_initial_elimination_offset): Likewise.
7318 * config/mips/mips.c (mips_global_pointer): Likewise.
7319 (mips_cfun_might_clobber_call_saved_reg_p): Likewise.
7320 (mips_compute_frame_info): Likewise.
7321 * config/mep/mep.c (mep_interrupt_saved_reg): Likewise.
7322 (mep_reload_pointer): Likewise.
7323 * config/rl78/rl78.c (need_to_save): Likewise.
7324 * config/cr16/cr16.c (cr16_compute_save_regs): Likewise.
7325 * config/score/score.c (score_compute_frame_size): Likewise.
7326 (score_function_prologue): Likewise.
7327 * config/bfin/bfin.c (must_save_p): Likewise.
7328 (expand_prologue_reg_save): Likewise.
7329 (expand_epilogue_reg_restore): Likewise.
7330 (bfin_frame_pointer_required): Likewise.
7331 (n_regs_saved_by_prologue): Likewise.
7332 (add_to_reg): Likewise.
7333 (expand_interrupt_handler_prologue): Likewise.
7334 (expand_interrupt_handler_epilogue): Likewise.
7335 (bfin_expand_prologue): Likewise.
7336 * config/avr/avr.c (avr_regs_to_save): Likewise.
7337 (avr_prologue_setup_frame): Likewise.
7338 (expand_epilogue): Likewise.
7339 * config/s390/s390.c (s390_regs_ever_clobbered): Likewise.
7340 (s390_register_info): Likewise.
7341 (s390_frame_info): Likewise.
7342 (s390_init_frame_layout): Likewise.
7343 (s390_emit_prologue): Likewise.
7344
7345
7346 2012-06-24 Steven Bosscher <steven@gcc.gnu.org>
7347
7348 * system.h: Poison ASM_BYTE_OP and ASM_OUTPUT_BYTE.
7349 * vmsdbgout: Do not undefine it if defined.
7350 Rename local ASM_BYTE_OP definition to VMS_ASM_BYTE_OP.
7351 * config/microblaze/microblaze/h: Do no define ASM_BYTE_OP.
7352 * config/mep/mep.h: Do not define ASM_OUTPUT_BYTE.
7353
7354 2012-06-24 Richard Sandiford <rdsandiford@googlemail.com>
7355
7356 * config/mips/mips.c (mips_process_sync_loop): Add missing enum cast.
7357
7358 2012-06-23 Richard Henderson <rth@redhat.com>
7359
7360 PR target/53749
7361 * config/i386/i386.c (ix86_rtx_costs): Add reasonable costs for
7362 V*QImode shifts and multiply.
7363 (ix86_expand_vecop_qihi): Support shifts.
7364 * config/i386/i386.md (any_shift): New code iterator.
7365 * config/i386/sse.md (ashlv16qi3): Merge ...
7366 (<any_shiftrt>v16qi3): ... into ...
7367 (<any_shift><VI1_AVX2>3): ... here. Use ix86_expand_vecop_qihi
7368 to support SSE and AVX.
7369
7370 * config/i386/i386.c (ix86_expand_sse_unpack): Split operands[]
7371 parameter into src and dest.
7372 * config/i386/sse.md (vec_unpacku_hi_<V124_AVX2>): Update call.
7373 (vec_unpacks_hi_<V124_AVX2>): Likewise.
7374 (vec_unpacku_lo_<V124_AVX2>): Likewise.
7375 (vec_unpacks_lo_<V124_AVX2>): Likewise.
7376 * config/i386/i386-protos.h: Update.
7377
7378 * config/i386/sse.md (mul<VI1_AVX2>3): Change from insn_and_split to
7379 pure expander; move expansion code ...
7380 * config/i386/i386.c (ix86_expand_vecop_qihi): ... here. New function.
7381 * config/i386/i386-protos.h: Update.
7382
7383 2012-06-22 Edmar Wienskoski <edmar@freescale.com>
7384
7385 * config/rs6000/rs6000.md (define_attr "type"): New type popcnt.
7386 (popcntb<mode>2): Add attribute type popcnt.
7387 (popcntd<mode>2): Ditto.
7388 * config/rs6000/power4.md (define_insn_reservation): Add type popcnt.
7389 * config/rs6000/power5.md (define_insn_reservation): Ditto.
7390 * config/rs6000/power7.md (define_insn_reservation): Ditto.
7391 * config/rs6000/476.md (define_insn_reservation): Ditto.
7392 * config/rs6000/power6.md (define_insn_reservation): New
7393 reservation for popcnt instructions.
7394
7395 2012-06-22 H.J. Lu <hongjiu.lu@intel.com>
7396
7397 * doc/invoke.texi: Update -mpreferred-stack-boundary=3 warning.
7398
7399 2012-06-22 H.J. Lu <hongjiu.lu@intel.com>
7400
7401 PR target/53383
7402 * doc/invoke.texi: Add a warning for -mpreferred-stack-boundary=3.
7403
7404 * config/i386/i386.c (ix86_option_override_internal): Allow
7405 -mpreferred-stack-boundary=3 for 64-bit if SSE is disabled.
7406
7407 * config/i386/i386.h (MIN_STACK_BOUNDARY): Set to 64 for 64-bit
7408 if SSE is disabled.
7409
7410 2012-06-22 Bill Schmidt <wschmidt@linux.ibm.com>
7411
7412 * double-int.c (double_int_multiple_of): New function.
7413 * double-int.h (double_int_multiple_of): New decl.
7414 * tree-ssa-loop-ivopts.c (add_cost, zero_cost): Remove undefs.
7415 (mbc_entry_hash): New forward decl.
7416 (mbc_entry_eq): Likewise.
7417 (zero_cost): Change to no_cost.
7418 (mult_costs): New static var.
7419 (cost_tables_exist): Likewise.
7420 (initialize_costs): New function.
7421 (finalize_costs): Likewise.
7422 (tree_ssa_iv_optimize_init): Call initialize_costs.
7423 (add_cost): Change to add_regs_cost; distinguish costs by speed.
7424 (multiply_regs_cost): New function.
7425 (add_const_cost): Likewise.
7426 (extend_or_trunc_reg_cost): Likewise.
7427 (negate_reg_cost): Likewise.
7428 (multiply_by_cost): Change to multiply_by_const_cost; distinguish
7429 costs by speed.
7430 (get_address_cost): Change add_cost to add_regs_cost; change
7431 multiply_by_cost to multiply_by_const_cost.
7432 (force_expr_to_var_cost): Change zero_cost to no_cost; change
7433 add_cost to add_regs_cost; change multiply_by_cost to
7434 multiply_by_const_cost.
7435 (split_cost): Change zero_cost to no_cost.
7436 (ptr_difference_cost): Likewise.
7437 (difference_cost): Change zero_cost to no_cost; change multiply_by_cost
7438 to multiply_by_const_cost.
7439 (get_computation_cost_at): Change add_cost to add_regs_cost; change
7440 multiply_by_cost to multiply_by_const_cost.
7441 (determine_use_iv_cost_generic): Change zero_cost to no_cost.
7442 (determine_iv_cost): Change add_cost to add_regs_cost.
7443 (iv_ca_new): Change zero_cost to no_cost.
7444 (tree_ssa_iv_optimize_finalize): Call finalize_costs.
7445 * tree-ssa-address.c (most_expensive_mult_to_index): Change
7446 multiply_by_cost to multiply_by_const_cost.
7447 * tree-flow.h (multiply_by_cost): Change to multiply_by_const_cost.
7448 (add_regs_cost): New decl.
7449 (multiply_regs_cost): Likewise.
7450 (add_const_cost): Likewise.
7451 (extend_or_trunc_reg_cost): Likewise.
7452 (negate_reg_cost): Likewise.
7453
7454 2012-06-22 Richard Guenther <rguenther@suse.de>
7455
7456 Merge from graphite branch
7457 2011-08-10 Sebastian Pop <sebpop@gmail.com>
7458
7459 * graphite-sese-to-poly.c (build_scop_drs): Fix memory leak.
7460
7461 2012-01-13 Tobias Grosser <tobias@grosser.es>
7462
7463 * tree-flow.h (parallelized_function_p): Declare.
7464 * tree-parloops.c (parallelized_function_p): Export.
7465 * graphite.c (graphite_transform_loops): Do not run graphite on
7466 already parallel functions.
7467
7468 2012-06-22 Alan Modra <amodra@gmail.com>
7469
7470 * config/rs6000/rs6000.c (rs6000_pre_atomic_barrier): Pass in and
7471 return mem. Convert to indirect addressing if not indirect or
7472 indexed. Adjust all callers.
7473
7474 2012-06-22 Richard Guenther <rguenther@suse.de>
7475
7476 * gcov-iov.c: Include bconfig.h and system.h.
7477
7478 2012-06-22 Andreas Schwab <schwab@linux-m68k.org>
7479
7480 * doc/include/texinfo.tex: Update to version 2012-06-05.14.
7481
7482 2012-06-22 Richard Guenther <rguenther@suse.de>
7483
7484 PR gcov-profile/53744
7485 * gcov-iov.c (main): Treat "" and "prerelease" the same.
7486
7487 2012-06-22 Eric Botcazou <ebotcazou@adacore.com>
7488
7489 PR debug/53704
7490 * dwarf2out.c (gen_compile_unit_die): Use DW_LANG_Fortran90 as language
7491 for GNU Fortran if in strict DWARF2 mode.
7492
7493 2012-06-22 Eric Botcazou <ebotcazou@adacore.com>
7494
7495 * tree-ssa-live.c (remove_unused_scope_block_p): Remove again
7496 DECL_IGNORED_P non-reg vars even if they are used.
7497
7498 2012-06-21 Alexandre Oliva <aoliva@redhat.com>
7499
7500 PR debug/53671
7501 PR debug/49888
7502 * var-tracking.c (vt_get_canonicalize_base): New.
7503 (vt_canonicalize_addr, vt_stack_offset_p): New.
7504 (vt_canon_true_dep): New.
7505 (drop_overlapping_mem_locs): Use vt_canon_true_dep.
7506 (clobber_overlaping_mems): Use vt_canonicalize_addr.
7507
7508 2012-06-21 Alexandre Oliva <aoliva@redhat.com>
7509
7510 PR debug/53671
7511 PR debug/49888
7512 * var-tracking.c (vt_initialize): Record initial offset between
7513 arg pointer and stack pointer.
7514
7515 2012-06-21 Alexandre Oliva <aoliva@redhat.com>
7516
7517 PR debug/53671
7518 PR debug/49888
7519 * var-tracking.c (vt_init_cfa_base): Drop redundant recording of
7520 CFA base.
7521
7522 2012-06-21 Alexandre Oliva <aoliva@redhat.com>
7523
7524 PR debug/53671
7525 PR debug/49888
7526 * alias.c (memrefs_conflict_p): Improve handling of AND for alignment.
7527
7528 2012-06-21 Alexandre Oliva <aoliva@redhat.com>
7529
7530 * ddg.c (build_intra_loop_deps): Discard deps of nondebug on debug.
7531
7532 2012-06-21 Alexandre Oliva <aoliva@redhat.com>
7533
7534 PR debug/53682
7535 * cselib.c (promote_debug_loc): Don't crash on NULL argument.
7536
7537 2012-06-21 Meador Inge <meadori@codesourcery.com>
7538
7539 PR c/53702
7540 * c-decl.c (c_push_function_context): Restore the behavior to reuse
7541 the language function allocated for -Wunused-local-typedefs.
7542 (c_pop_function_context): If necessary, clear the language function
7543 created in c_push_function_context. Always clear out the
7544 x_cur_stmt_list field of the restored language function.
7545
7546 2012-06-21 Sterling Augustine <saugustine@google.com>
7547 Cary Coutant <ccoutant@google.com>
7548
7549 * dwarf2out.c (is_cu_die, is_namespace_die, is_class_die,
7550 add_AT_pubnames, add_enumerator_pubname, want_pubnames): New functions.
7551 (comdat_type_struct): New field 'skeleton_die'.
7552 (breakout_comdat_types): Update it.
7553 (add_pubname): Rework logic. Call is_class_die, is_cu_die and
7554 is_namespace_die. Fix minor style violation. Call want_pubnames.
7555 (add_pubname_string): Call want_pubnames.
7556 (add_pubtype): Rework logic for calculating type name. Call
7557 is_namespace_die. Call want_pubnames.
7558 (output_pubnames): Move conditional logic deciding when to produce the
7559 section from dwarf2out_finish. Use new skeleton_die field.
7560 (base_type_die): Call add_pubtype.
7561 (gen_enumeration_type_die): Unconditionally call add_pubtype.
7562 (gen_subprogram_die): Adjust calls to add_pubname.
7563 (gen_namespace_die): Call add_pubname_string.
7564 (dwarf2out_finish): Call add_AT_pubnames; Move logic on when to
7565 produce pubnames and pubtypes sections to output_pubnames.
7566 * common.opt (-gpubnames): New option.
7567 * doc/invoke.texi: Document it.
7568
7569 2012-06-21 Steven Bosscher <steven@gcc.gnu.org>
7570
7571 * config/m32c/m32c-pragma.c: Remove unnecessary includes.
7572
7573 2012-06-21 Michael Matz <matz@suse.de>
7574
7575 PR middle-end/53688
7576 * builtins.c (get_memory_rtx): Always build an all-aliasing MEM_REF
7577 with correct size.
7578
7579 2012-06-21 Richard Guenther <rguenther@suse.de>
7580
7581 * tree-inline.c (estimate_num_insns): Estimate call cost for
7582 tailcalls properly.
7583
7584 2012-06-20 Rüdiger Sonderfeld <ruediger@c-plusplus.de>
7585
7586 * tree.h (DECL_SOURCE_COLUMN): New accessor.
7587
7588 2012-06-20 Uros Bizjak <ubizjak@gmail.com>
7589
7590 * config/i386/i386.md (SINCOS): New int iterator.
7591 (sincos): New int attribute.
7592 (*<sincos>xf2_i387): Macroize insn from *{sin,cos}xf2_i387 using
7593 SINCOS int iterator.
7594 (*<sincos>_extend<mode>xf2_i387): Macroize insn from
7595 *{sin,cos}_extend<mode>xf2_i387 using SINCOS int iterator.
7596
7597 2012-06-20 Uros Bizjak <ubizjak@gmail.com>
7598
7599 * config/i386/i386.md (RDFSGSBASE): New int iterator.
7600 (WRFSGSBASE): Ditto.
7601 (fsgs): New int attribute.
7602 (rd<fsgs>base<mode>): Macroize insn from rd<fsgs>base<mode> using
7603 RDFSGSBASE int iterator.
7604 (wr<fsgs>base<mode>): Macroize insn from wr<fsgs>base<mode> using
7605 WRFSGSBASE int iterator.
7606
7607 2012-06-20 Uros Bizjak <ubizjak@gmail.com>
7608
7609 * config/i386/i386.md (<rounding_insn><mode>2): Macroize expander
7610 from {floor,ceil,btrunc}<mode>2 using FIST_ROUNDING int iterator.
7611 (l<rounding_insn><MODEF:mode><SWI48:mode>2): Macroize expander
7612 from l{floor,ceil}<MODEF:mode><SWI48:mode>2 using FIST_ROUNDING
7613 int iterator.
7614
7615 2012-06-20 Steven Bosscher <steven@gcc.gnu.org>
7616
7617 * system.h: Poison ASM_OUTPUT_IDENT and IDENT_ASM_OP.
7618
7619 2012-06-20 Richard Guenther <rguenther@suse.de>
7620
7621 PR tree-optimization/30318
7622 * tree-vrp.c (range_int_cst_p): Do not reject overflowed
7623 constants here.
7624 (range_int_cst_singleton_p): But explicitely here.
7625 (zero_nonzero_bits_from_vr): And here.
7626 (extract_range_from_binary_expr_1): Re-implement PLUS_EXPR
7627 to cover all cases we can perform arbitrary precision
7628 arithmetic with double-ints.
7629 (intersect_ranges): Handle adjacent anti-ranges.
7630
7631 2012-06-20 Uros Bizjak <ubizjak@gmail.com>
7632
7633 * config/i386/i386.md (rounding_insn): New int attribute.
7634 (<rounding_insn>xf2): Macroize insn from
7635 {floor,ceil,btrunc}xf2 using FRNDINT_ROUNDING int iterator.
7636 (l<rounding_insn>xf<mode>2): Rename from l<rounding>xf<mode>2.
7637
7638 2012-06-20 Uros Bizjak <ubizjak@gmail.com>
7639
7640 * config/i386/i386.md (IEEE_MAXMIN): New int iterator.
7641 (ieee_maxmin): New int attribute.
7642 (*ieee_s<ieee_maxmin><mode>3): Macroize insn from
7643 *ieee_s{max,min}<mode>3 using IEEE_MAXMIN int iterator.
7644
7645 2012-06-20 Steven Bosscher <steven@gcc.gnu.org>
7646
7647 * config/arm/arm.h (EMIT_EABI_ATTRIBUTE): Remove.
7648 * config/arm/arm.c: Do not include c-pragma.h.
7649 (arm_emit_eabi_attribute): New function based on EMIT_EABI_ATTRIBUTE.
7650 (arm_file_start): Replace uses of EMIT_EABI_ATTRIBUTE with calls
7651 to arm_emit_eabi_attribute.
7652 * arm-c.c: Do not include output.h.
7653 (arm_output_c_attributes): Replace use of EMIT_EABI_ATTRIBUTE with a
7654 call to arm_emit_eabi_attribute.
7655 * config/arm/arm-protos.h (arm_emit_eabi_attribute): Prototype it.
7656
7657 2012-06-20 Richard Guenther <rguenther@suse.de>
7658
7659 * tree-vect-data-refs.c (vect_can_force_dr_alignment_p):
7660 Allow adjusting alignment of user-aligned decls again.
7661
7662 2012-06-20 Steven Bosscher <steven@gcc.gnu.org>
7663
7664 * config/rl78/rl78-c.c: Remove unnecessary includes.
7665
7666 2012-06-20 Steven Bosscher <steven@gcc.gnu.org>
7667
7668 * config/cris/cris.c: Include cgraph.h.
7669 (cris_option_override): Do not set non-existing flag_no_gcc_ident.
7670
7671 2012-06-19 Maxim Kuvyrkov <maxim@codesourcery.com>
7672
7673 * emit-rtl.c (need_atomic_barrier_p): New function.
7674 * emit-rtl.h (need_atomic_barrier_p): Declare it.
7675 * config/alpha/alpha.c (alpha_{pre,post}_atomic_barrier): Use it.
7676 * config/arm/arm.c (arm_{pre,post}_atomic_barrier): Use it.
7677 * config/tilegx/tilegx.c (tile_{pre,post}_atomic_barrier): Use it.
7678 * config/mips/mips.c (mips_{pre,post}_atomic_barrier_p): Remove.
7679 (mips_process_sync_loop): Use generic version instead.
7680
7681 2012-06-19 Maxim Kuvyrkov <maxim@codesourcery.com>
7682
7683 * config/mips/mips.c (mips_process_sync_loop): Emit cmp result only if
7684 it is used.
7685
7686 2012-06-19 Tom de Vries <vries@codesourcery.com>
7687 Maxim Kuvyrkov <maxim@codesourcery.com>
7688
7689 * config/mips/constraints.md (ZR): New constraint.
7690 * config/mips/predicates.md (mem_noofs_operand): New predicate.
7691 * config/mips/mips.c (mips_print_operand): Handle new print modifier.
7692 * config/mips/mips.h (TARGET_XLP): Define.
7693 (TARGET_SYNC_AFTER_SC): Update.
7694 (ISA_HAS_SWAP, ISA_HAS_LDADD): Define.
7695 * config/mips/sync.md (atomic_exchange, atomic_fetch_add): Use
7696 XLP-specific swap and ldadd patterns.
7697 (atomic_exchange_swap, atomic_fetch_add_ldadd): New patterns.
7698
7699 2012-06-19 Tom de Vries <vries@codesourcery.com>
7700 Maxim Kuvyrkov <maxim@codesourcery.com>
7701
7702 * config/mips/mips.c (mips_emit_pre_atomic_barrier_p,)
7703 (mips_emit_post_atomic_barrier_p): New static functions.
7704 (mips_process_sync_loop): Use them. Emit sync memory barriers in
7705 accordance with memory model semantics. Add return of CMP result for
7706 compare_and_swap.
7707 * config/mips/mips.md: Update comment.
7708 (sync_cmp): New attribute.
7709 (sync_memmodel): New attribute replacing sync_release_barrier.
7710 * config/mips/sync.md (UNSPEC_ATOMIC_COMPARE_AND_SWAP,)
7711 (UNSPEC_ATOMIC_EXCHANGE, UNSPEC_ATOMIC_FETCH_OP): New constants.
7712 (sync_lock_test_and_set, test_and_set_12): Update.
7713 (atomic_compare_and_swap, atomic_exchange, atomic_exchange_llsc,)
7714 (atomic_fetch_add, atomic_fetch_add_llsc): New patterns.
7715
7716 2012-06-19 Joseph Myers <joseph@codesourcery.com>
7717
7718 * config/rs6000/spe.md (*mov_si<mode>_e500_subreg0): Rename to
7719 mov_si<mode>_e500_subreg0.
7720 (*mov_si<mode>_e500_subreg0_elf_low)
7721 (*mov_si<mode>_e500_subreg4_elf_low): New patterns.
7722
7723 2012-06-19 Richard Henderson <rth@redhat.com>
7724
7725 * config/alpha/alpha.c: Include params.h.
7726 (alpha_option_override): Initialize PARAM_L1_CACHE_LINE_SIZE,
7727 PARAM_L1_CACHE_SIZE, PARAM_L2_CACHE_SIZE for the cpu tuning.
7728
7729 2012-06-19 Steven Bosscher <steven@gcc.gnu.org>
7730
7731 * doc/tm.texi.in (TARGET_OBJC_DECLARE_UNRESOLVED_CLASS_REFERENCE,
7732 TARGET_OBJC_DECLARE_CLASS_DEFINITION): Add @hooks.
7733 (ASM_DECLARE_CLASS_REFERENCE, ASM_DECLARE_UNRESOLVED_REFERENCE):
7734 Remove.
7735 * doc/tm.texi: Regenerate.
7736 * config/darwin.h (ASM_OUTPUT_LABELREF): Remove special case for
7737 .objc_class_name_*.
7738 * config/darwin-c.c: Include target.h.
7739 (darwin_objc_declare_unresolved_class_reference): New function.
7740 (darwin_objc_declare_class_definition): New function.
7741 (TARGET_OBJC_DECLARE_UNRESOLVED_CLASS_REFERENCE): Define.
7742 (TARGET_OBJC_DECLARE_CLASS_DEFINITION): Define.
7743
7744 2012-06-19 Steven Bosscher <steven@gcc.gnu.org>
7745
7746 * target.def (output_ident): New hook.
7747 * targhooks.h (default_asm_output_ident_directive): Add prototype.
7748 * varasm.c (assemble_asm): Only prefix a tab if the string does not
7749 already start with one.
7750 (default_asm_output_ident_directive): New function to emit
7751 .ident as a top-level asm node while parsing, or directly to
7752 asm_out_file after parsing.
7753 * toplev.c (compile_file): Print a GCC .ident with
7754 targetm.asm_out.output_ident.
7755 * doc/tm.texi.in (ASM_OUTPUT_IDENT): Remove documentation for macro.
7756 (TARGET_ASM_OUTPUT_IDENT): Add @hook for this.
7757 * doc/tm.texi: Update.
7758
7759 * config/elfos.h (ASM_OUTPUT_IDENT, IDENT_ASM_OP): Remove.
7760 (TARGET_ASM_OUTPUT_IDENT): Define.
7761 * config/i386/djgpp.h (IDENT_ASM_OP): Remove.
7762 * config/i386/gas.h (ASM_OUTPUT_IDENT): Remove.
7763 * config/arm/aout.h (ASM_OUTPUT_IDENT): Remove.
7764 * config/sparc/sparc.h (IDENT_ASM_OP): Remove.
7765 (TARGET_ASM_OUTPUT_IDENT): Define.
7766 * config/picochip/picochip.h (IDENT_ASM_OP): Remove.
7767 (TARGET_ASM_OUTPUT_IDENT): Define.
7768
7769 * config/cris/cris-protos.h (cris_asm_output_ident): Add prototype.
7770 * config/cris/cris.c (cris_asm_output_ident): New function.
7771 * config/cris/cris.h (ASM_OUTPUT_IDENT, IDENT_ASM_OP): Remove.
7772
7773 * config/microblaze/microblaze-protos.h (microblaze_asm_output_ident):
7774 Add prototype.
7775 * config/microblaze/microblaze.c: Include cgraph.h for add_asm_node.
7776 (microblaze_asm_output_ident): Rewrite to work similar to
7777 default_asm_output_ident_directive for front-end .idents.
7778 * config/microblaze/microblaze.h (ASM_OUTPUT_IDENT): Remove.
7779 (TARGET_ASM_OUTPUT_IDENT): Define.
7780
7781 * config/mips/mips.h (ASM_OUTPUT_IDENT): Remove.
7782 * config/mips/sde.h (IDENT_ASM_OP, ASM_OUTPUT_IDENT): Remove.
7783
7784 * config/rx/rx.c: Include cgraph.h for add_asm_node.
7785 (rx_asm_output_ident): New function, similar to
7786 default_asm_output_ident_directive, but handle AS100 syntax also, so
7787 that #ident also works for rx in AS100 syntax.
7788 (TARGET_ASM_OUTPUT_IDENT): Define.
7789 * config/rx/rx.h (IDENT_ASM_OP): Remove.
7790
7791 * Makefile.in: Fix dependencies for c-family/c-lex.o.
7792
7793 2012-06-19 Uros Bizjak <ubizjak@gmail.com>
7794
7795 * config/i386/i386.md (FIST_ROUNDING): New int iterator.
7796 (rounding): Handle UNSPEC_FIST_{FLOOR,CEIL}.
7797 (ROUNDING): Ditto.
7798 (*fist<mode>2_<rounding>_1): Macroize insn from
7799 *fist<mode>2_{floor,ceil}_1 using FIST_ROUNDING int iterator.
7800 (fistdi2_<rounding>): Macroize insn from
7801 fistdi2_{floor,ceil} using FIST_ROUNDING int iterator.
7802 (fistdi2_<rounding>_with_temp and splitters): Macroize insn and
7803 corresponding splitters from fistdi2_{floor,ceil} and corresponding
7804 splitters using FIST_ROUNDING int iterator.
7805 (fist<mode>2_<rounding>): Macroize insn from
7806 fist<mode>2_{floor,ceil} using FIST_ROUNDING int iterator.
7807 (fist<mode>2_<rounding>_with_temp and splitters): Macroize insn and
7808 corresponding splitters from fist<mode>2_{floor,ceil} and corresponding
7809 splitters using FIST_ROUNDING int iterator.
7810 (l<rounding>xf<mode>2): Macroize expander from l{floor,ceil}xf<mode>2
7811 using FIST_ROUNDING int iterator.
7812
7813 2012-06-19 Richard Henderson <rth@redhat.com>
7814
7815 * config/i386/i386-protos.h (ix86_expand_sse2_mulv4si3): Declare.
7816 * config/i386/i386.c (ix86_expand_sse2_mulv4si3): New.
7817 * config/i386/predicates.md (nonimmediate_or_const_vector_operand): New.
7818 * config/i386/sse.md (sse2_mulv4si3): Delete.
7819 (mul<VI4_AVX2>3): Use ix86_expand_sse2_mulv4si3 and
7820 nonimmediate_or_const_vector_operand.
7821
7822 2012-06-19 Richard Henderson <rth@redhat.com>
7823
7824 * expmed.c (struct init_expmed_rtl): Split ...
7825 (init_expmed_one_mode): ... out of ...
7826 (init_expmed): ... here. Initialize integer vector modes also.
7827 (synth_mult): Handle integer vector modes.
7828 (choose_mult_variant): Likewise.
7829 (expand_mult_const): Likewise.
7830 (expand_mult): Likewise.
7831 * machmode.h (GET_MODE_UNIT_BITSIZE): New.
7832
7833 2012-06-19 Richard Henderson <rth@redhat.com>
7834
7835 * config/i386/i386.c (ix86_rtx_costs): Handle CONST_VECTOR, and
7836 integral vector modes.
7837
7838 2012-06-19 Uros Bizjak <ubizjak@gmail.com>
7839
7840 * config/i386/i386.md (FRNDINT_ROUNDING): New int iterator.
7841 (rounding): New int attribute.
7842 (ROUNDING): Ditto.
7843 (frndintxf2_<rounding>): Macroize insn from
7844 frndintxf2_{floor,ceil,trunc} using FRNDINT_ROUNDING int iterator.
7845 (frndintxf2_<rounding>_i387): Macroize insn from
7846 frndintxf2_{floor,ceil,trunc}_i387 using FRNDINT_ROUNDING int iterator.
7847
7848 2012-06-19 Richard Guenther <rguenther@suse.de>
7849
7850 * tree-vrp.c (union_ranges): New function.
7851 (vrp_meet_1): Use union_ranges.
7852 (vrp_meet): Dump what we union and call vrp_meet_1.
7853
7854 2012-06-19 Richard Earnshaw <rearnsha@arm.com>
7855
7856 * arm.md (enum unspec): Delete UNSPEC_SIN and UNSPEC_COS.
7857 (attr type): Remove fmul, ffmul, farith, ffarith, float_em
7858 f_fpa_load, f_fpa_store, f_mem_r, r_mem_f.
7859 (attr write_conflict, attr core_cycles): Update.
7860 * arm-generic.md (r_mem_f_wbuf): Delete reservation.
7861
7862 2012-06-19 Richard Guenther <rguenther@suse.de>
7863
7864 * tree-vrp.c (intersect_ranges): Handle more cases.
7865 (vrp_intersect_ranges): Dump what we intersect and call ...
7866 (vrp_intersect_ranges_1): ... this.
7867
7868 2012-06-19 Richard Guenther <rguenther@suse.de>
7869
7870 PR tree-optimization/53708
7871 * tree-vect-data-refs.c (vect_can_force_dr_alignment_p): Preserve
7872 user-supplied alignment and alignment of decls with the used
7873 attribute.
7874
7875 2012-06-18 Lawrence Crowl <crowl@google.com>
7876
7877 * timevar.def (TV_PHASE_GENERATE): Rename to TV_PHASE_LATE_ASM.
7878 (TV_PHASE_CGRAPH): Rename to TV_PHASE_OPT_GEN.
7879 (TV_PHASE_STREAM_IN): New.
7880 (TV_PHASE_STREAM_OUT): New.
7881 * timevar.c (validate_phases): New.
7882 (timevar_print): Call validate_phases.
7883 * c-decl.c (c_write_global_declarations): Rename use of TV_PHASE_CGRAPH
7884 to TV_PHASE_OPT_GEN.
7885 * langhooks.c (write_global_declarations): Rename use of
7886 TV_PHASE_CGRAPH to TV_PHASE_OPT_GEN. Use TV_PHASE_DBGINFO instead of
7887 TV_PHASE_CHECK_DBGINFO.
7888 * toplev.c (compile_file): Rename use of TV_PHASE_GENERATE to
7889 TV_PHASE_LATE_ASM. Move start of TV_PHASE_LATE_ASM to after call to
7890 lang_hooks.decls.final_write_globals.
7891
7892 2012-06-18 David Edelshn <dje.gcc@gmail.com>
7893
7894 * config/rs6000/aix52.h (TARGET_EXTRA_BUILTINS): Define as 0.
7895
7896 2012-06-18 Uros Bizjak <ubizjak@gmail.com>
7897
7898 PR target/53712
7899 * config/i386/sse.md (*sse4_2_pcmpestr_unaligned): New.
7900 (*sse4_2_pcmpistr_unaligned): New.
7901
7902 2012-06-18 Ian Bolton <ian.bolton@arm.com>
7903 Sameera Deshpande <sameera.deshpande@arm.com>
7904 Greta Yorsh <greta.yorsh@arm.com>
7905
7906 * config/arm/arm-protos.h (arm_output_epilogue): Remove.
7907 * config/arm/arm.c (print_multi_reg): Remove.
7908 (vfp_output_fldmd): Likewise.
7909 (arm_output_epilogue): Likewise.
7910 * config/arm/arm.md (epilogue_insns): Update condition and code.
7911
7912 2012-06-18 Ian Bolton <ian.bolton@arm.com>
7913 Sameera Deshpande <sameera.deshpande@arm.com>
7914 Greta Yorsh <greta.yorsh@arm.com>
7915
7916 * config/arm/arm-protos.h (thumb2_expand_return): New declaration.
7917 * config/arm/arm.c (thumb2_expand_return): New function.
7918 * config/arm/arm.md (return): Update condition and code.
7919
7920 2012-06-18 Ian Bolton <ian.bolton@arm.com>
7921 Sameera Deshpande <sameera.deshpande@arm.com>
7922 Greta Yorsh <greta.yorsh@arm.com>
7923
7924 * config/arm/arm-protos.h (output_return_instruction): New parameter
7925 and int to bool change of parameter types.
7926 * config/arm/arm.c (output_return_instruction): Likewise.
7927 * config/arm/arm.md (arm_simple_return): New pattern.
7928 (arm_return, cond_return, cond_return_inverted): Add new arguments.
7929 * config/arm/thumb2.md (thumb2_return): Update condition and code.
7930
7931 2012-06-18 Ian Bolton <ian.bolton@arm.com>
7932 Sameera Deshpande <sameera.deshpande@arm.com>
7933 Greta Yorsh <greta.yorsh@arm.com>
7934
7935 * config/arm/arm-protos.h (arm_expand_epilogue): New declaration.
7936 * config/arm/arm.c (arm_expand_epilogue): New function.
7937 * config/arm/arm.md (epilogue): Update condition and code.
7938 (sibcall_epilogue): Likewise.
7939
7940 2012-06-18 Ian Bolton <ian.bolton@arm.com>
7941 Sameera Deshpande <sameera.deshpande@arm.com>
7942 Greta Yorsh <greta.yorsh@arm.com>
7943
7944 * config/arm/arm.c (arm_expand_epilogue_apcs_frame): New function.
7945 * config/arm/arm.md (arm_addsi3) Add an alternative.
7946
7947 2012-06-18 Ian Bolton <ian.bolton@arm.com>
7948 Sameera Deshpande <sameera.deshpande@arm.com>
7949 Greta Yorsh <greta.yorsh@arm.com>
7950
7951 * config/arm/arm.md (vfp_pop_multiple_with_writeback) New define_insn.
7952 * config/arm/predicates.md (pop_multiple_fp) New special predicate.
7953 * config/arm/arm.c (arm_emit_vfp_multi_reg_pop): New function.
7954
7955 2012-06-18 Ian Bolton <ian.bolton@arm.com>
7956 Sameera Deshpande <sameera.deshpande@arm.com>
7957 Greta Yorsh <greta.yorsh@arm.com>
7958
7959 * config/arm/arm.md (load_multiple_with_writeback) New define_insn.
7960 (load_multiple, pop_multiple_with_writeback_and_return) Likewise.
7961 (pop_multiple_with_return, ldr_with_return) Likewise.
7962 * config/arm/predicates.md (pop_multiple_return) New special predicate.
7963 * config/arm/arm-protos.h (arm_output_multireg_pop) New declaration.
7964 * config/arm/arm.c (arm_output_multireg_pop) New function.
7965 (arm_emit_multi_reg_pop): New function.
7966
7967 2012-06-18 Greta Yorsh <Greta.Yorsh@arm.com>
7968
7969 * config/arm/arm.c (ldm_stm_operation_p): Require SP
7970 as base register for loads if SP is in the register list.
7971
7972 2012-06-18 Richard Guenther <rguenther@suse.de>
7973
7974 PR tree-optimization/53693
7975 * tree-vect-patterns.c (vect_operation_fits_smaller_type):
7976 Reject operands with more than one use.
7977
7978 2012-06-18 Bill Schmidt <wschmidt@linux.ibm.com>
7979
7980 PR tree-optimization/53703
7981 * tree-ssa-phiopt.c (hoist_adjacent_loads): Skip virtual phis;
7982 correctly set bb_for_def[12].
7983
7984 2012-06-18 Steven Bosscher <steven@gcc.gnu.org>
7985
7986 * config/vax/vax.h (VMS_TARGET): Remove.
7987
7988 2012-06-18 Richard Guenther <rguenther@suse.de>
7989
7990 * tree-vrp.c (extract_range_from_assert): Split out range
7991 intersecting code.
7992 (intersect_ranges): New function.
7993 (vrp_intersect_ranges): Likewise.
7994
7995 2012-06-18 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
7996
7997 * config/s390/s390.c (s390_gimplify_va_arg): Revert change from
7998 r187965.
7999
8000 2012-06-18 Tejas Belagod <tejas.belagod@arm.com>
8001
8002 * doc/md.texi: Document int iterators.
8003 * read-rtl.c (ints): New iterator group.
8004 (find_int): Int iterator group callback.
8005 (apply_int_iterator): Likewise.
8006 (apply_iterators): Traverse int iterator table and add all the used
8007 iterators to list.
8008 (initialize_iterators): Initialize data structures and callbacks for
8009 int iterators.
8010 (read_rtx): Parse and read mappings for int iterators.
8011 (read_rtx_code): Record int iterator usage.
8012
8013 2012-06-18 Richard Sandiford <rdsandiford@googlemail.com>
8014
8015 PR middle-end/53698
8016 * expr.c (expand_expr_addr_expr_1): Convert to tmode before
8017 performing an addition.
8018
8019 2012-06-17 Steven Bosscher <steven@gcc.gnu.org>
8020
8021 * output.h (split_double): Move prototype to rtl.h.
8022 (constructor_static_from_elts_p): Move prototype to tree.c.
8023 * rtl.h (split_double): Moved here from output.h.
8024 * tree.h (constructor_static_from_elts_p): Moved here from output.h.
8025 * final.c (split_double): Move from here ...
8026 * rtlanal.c (split_double): ... to here.
8027 * expr.c: Do not include output.h.
8028
8029 2012-06-17 Steven Bosscher <steven@gcc.gnu.org>
8030
8031 * cfglayout.h: Remove.
8032 * cfglayout.c: Remove.
8033 * function.h (struct function): Remove x_last_location field.
8034 * function.c: Do not include cfglayout.h.
8035 (expand_function_start): Do not call no-op force_next_line_note.
8036 (expand_function_end): Likewise.
8037 * cfgrtl.c: Do not include cfglayout.h. Include gt-cfgrtl.h.
8038 (unlink_insn_chain): Moved here from cfglayout.c.
8039 (skip_insns_after_block, label_for_bb, record_effective_endpoints,
8040 into_cfg_layout_mode, outof_cfg_layout_mode,
8041 pass_into_cfg_layout_mode, pass_outof_cfg_layout_mode,
8042 relink_block_chain, fixup_reorder_chain, verify_insn_chain,
8043 fixup_fallthru_exit_predecessor, force_one_exit_fallthru,
8044 cfg_layout_can_duplicate_bb_p, duplicate_insn_chain,
8045 cfg_layout_duplicate_bb, cfg_layout_initialize, break_superblocks,
8046 cfg_layout_finalize): Likewise.
8047 (rtl_can_remove_branch_p): Likewise.
8048 * rtl.h (insn_scope): Move prototype from cfglayout.h here.
8049 (duplicate_insn_chain): Likewise.
8050 (force_next_line_note): Remove prototype.
8051 * emit-rtl.c: Do not include tree-flow.h, egad. Include vecprim.h.
8052 (last_location): Remove #define to emit.x_last_location.
8053 (force_next_line_note): Remove no-op function.
8054 (init_emit): Don't set x_last_location.
8055 (block_locators_locs, block_locators_blocks, locations_locators_locs,
8056 locations_locators_vals, prologue_locator, epilogue_locator,
8057 curr_location, last_location, curr_block, last_block, curr_rtl_loc):
8058 Move POD to here from cfglayout.c.
8059 (insn_locators_alloc, insn_locators_finalize, insn_locators_free,
8060 set_curr_insn_source_location, get_curr_insn_source_location,
8061 set_curr_insn_block, get_curr_insn_block, curr_insn_locator,
8062 locator_scope, insn_scope, locator_location, locator_line, insn_line,
8063 locator_file, insn_file, locator_eq): Move to here from cfglayout.c.
8064 * cfghooks.h: Remove double-include protection.
8065 (can_copy_bbs_p, copy_bbs): Move prototypes from cfglayout.h to here.
8066 * cfghooks.c (can_copy_bbs_p, copy_bbs): Move to here from cfglayout.c.
8067 * final.c: Do not include cfglayout.h.
8068 (choose_inner_scope, change_scope): Move to here from cfglayout.c.
8069 (reemit_insn_block_notes): Likewise. Make static.
8070 * tree-flow.h (tree_could_trap_p, operation_could_trap_helper_p,
8071 operation_could_trap_p, tree_could_throw_p): Move from here...
8072 * tree.h: ... to here.
8073 * gengtype.c (open_base_files): Remove cfglayout.h from the list.
8074 * profile.c: Do not include cfghooks.h.
8075 * cfgloopmanip.c: Do not include cfglayout.h and cfghooks.h.
8076 * modulo-sched.c: Likewise.
8077 * loop-unswitch.c: Do not include cfglayout.h.
8078 * sched-ebb.c: Likewise.
8079 * tracer.c: Likewise.
8080 * ddg.c: Likewise.
8081 * tree-vect-loop-manip.c: Likewise.
8082 * loop-init.c: Likewise.
8083 * dwarf2out.c: Likewise.
8084 * hw-doloop.c: Likewise.
8085 * loop-unroll.c: Likewise.
8086 * cfgcleanup.c: Likewise.
8087 * bb-reorder.c: Likewise.
8088 * sched-rgn.c: Likewise.
8089 * tree-cfg.c: Likewise.
8090 * config/alpha/alpha.c: Likewise.
8091 * config/spu/spu.c: Likewise.
8092 * config/sparc/sparc.c: Likewise.
8093 * config/sh/sh.c: Likewise.
8094 * config/c6x/c6x.c: Likewise.
8095 * config/ia64/ia64.c: Likewise.
8096 * config/rs6000/rs6000.c: Likewise.
8097 * config/score/score.c: Likewise.
8098 * config/mips/mips.c: Likewise.
8099 * config/bfin/bfin.c: Likewise.
8100 * Makefile.in (CFGAYOUT_H): Remove, and fixup users.
8101 * config/rs6000/t-rs6000 (rs6000.o): Do not depend on cfglayout.h.
8102 * config/spu/t-spu-elf (spu.o: $): Likewise.
8103 * config/sparc/t-sparc (sparc.o): Do not depend on CFGLAYOUT_H.
8104
8105 2012-06-17 Steven Bosscher <steven@gcc.gnu.org>
8106
8107 * cfgloop.h: Do not include rtl.h.
8108 (enum iv_extend_code): New.
8109 (struct rtx_iv): Use iv_extend_code instead of rtx_code.
8110 * Makefile.in (CFGLOOP_H): Do not depend on RTL_H.
8111 * loop-iv.c (iv_extend_to_rtx_code): New function to translate
8112 an IV_EXTEND_CODE to an RTX_CODE.
8113 (dump_iv_info): Update for rtx_iv field type change.
8114 (iv_constant): Likewise.
8115 (iv_subreg): Likewise.
8116 (iv_extend): Likewise.
8117 (iv_neg): Likewise.
8118 (iv_add): Likewise.
8119 (iv_mult): Likewise.
8120 (iv_shift): Likewise.
8121 (get_biv_step_1): Likewise.
8122 (get_biv_step): Likewise.
8123 (iv_analyze_biv): Likewise.
8124 (get_iv_value): Likewise.
8125 (shorten_into_mode): Likewise.
8126 (canonicalize_iv_subregs): Likewise.
8127 * sese.c (sese_build_liveouts): Use MAY_HAVE_DEBUG_STMTS instead
8128 of MAY_HAVE_DEBUG_INSNS.
8129 * tree-ssa-loop-ivopts.c: Include recog.h after expr.h.
8130 * tree-ssa-loop-prefetch.c: Likewise.
8131
8132 2012-06-17 Steven Bosscher <steven@gcc.gnu.org>
8133
8134 * expmed.c (ceil_log2): Move from here...
8135 * hwint.c: ... to here for older GCCs...
8136 * hwint.h: ... and here for newer GCCs.
8137 * rtl.h (ceil_log2): Remove prototype.
8138
8139 * tree-phinodes.c: Do not include rtl.h.
8140 * Makefile.in (tree-phinodes.o): Do not depend on RTL_H.
8141
8142 2012-06-17 Steven Bosscher <steven@gcc.gnu.org>
8143
8144 * config/cris/cris.h (TARGET_ELF): Remove.
8145 (FORCE_EH_FRAME_INFO_IN_DATA_SECTION): Remove.
8146 (CRIS_ASM_OUTPUT_ALIGNED_DECL_COMMON): Simpify using TARGET_ELF==1.
8147 (LOCAL_LABEL_PREFIX): Likewise.
8148 * config/cris/cris.c (cris_target_asm_named_section): Remove.
8149 (cris_option_override): Simpify using TARGET_ELF==1.
8150 (cris_file_start): Likewise.
8151 * config/cris/cris-protos.h (cris_target_asm_named_section): Remove.
8152
8153 2012-06-17 Uros Bizjak <ubizjak@gmail.com>
8154
8155 * config/i386/sse.md (vcvtph2ps): Fix vec_select selector.
8156
8157 2012-06-16 Eric Botcazou <ebotcazou@adacore.com>
8158
8159 PR middle-end/53590
8160 * tree-inline.c (initialize_cfun): Copy can_delete_dead_exceptions.
8161
8162 2012-06-15 Easwaran Raman <eraman@google.com>
8163
8164 * passes.c (init_optimization_passes): Remove pass_call_cdce
8165 from its current position and insert after pass_dce.
8166
8167 2012-06-15 Walter Lee <walt@tilera.com>
8168
8169 * config/tilegx/sync.md (atomic_fetch_<fetchop_name><mode>): Fix typo.
8170
8171 2012-06-15 Richard Earnshaw <rearnsha@arm.com>
8172
8173 * arm.c (note_invalid_constants): Don't return a result.
8174 (arm_memory_load_p): Delete function.
8175 (arm_const_double_rtx): Delete iterator variable i;
8176 (fp_immediate_constant): Likewise.
8177 (fp_const_from_val): Likewise.
8178
8179 * arm.c (arm_init_iwmmxt_builtins): Delete void_ftype_void.
8180
8181 2012-06-15 Marc Glisse <marc.glisse@inria.fr>
8182
8183 PR c++/51033
8184 * c-typeck.c (c_build_vec_perm_expr): Move to c-family/c-common.c.
8185 * c-tree.h (c_build_vec_perm_expr): Move to c-family/c-common.h.
8186
8187 2012-06-15 Georg-Johann Lay <avr@gjlay.de>
8188
8189 * config/avr/avr.c (avr_default_expand_builtin): New function.
8190 (avr_expand_builtin): Use it.
8191 (avr_expand_unop_builtin): Remove.
8192 (avr_expand_binop_builtin): Remove.
8193 (avr_expand_triop_builtin): Remove.
8194
8195 2012-06-15 Michael Matz <matz@suse.de>
8196
8197 PR middle-end/38474
8198 * cfgexpand.c (add_alias_set_conflicts): Remove.
8199 (expand_used_vars): Don't call it.
8200 (aggregate_contains_union_type): Remove.
8201 * function.c (n_temp_slots_in_use): New static data.
8202 (make_slot_available, assign_stack_temp_for_type): Update it.
8203 (init_temp_slots): Zero it.
8204 (remove_unused_temp_slot_addresses): Use it for quicker removal.
8205 (remove_unused_temp_slot_addresses_1): Use htab_clear_slot.
8206
8207 2012-06-15 Michael Matz <matz@suse.de>
8208
8209 * gimplify.c (gimplify_compound_literal_expr): Take gimple_test_f
8210 argument, don't emit assign statement if value is directly usable.
8211 (gimplify_expr): Adjust.
8212
8213 2012-06-15 Michael Matz <matz@suse.de>
8214
8215 * gimplify.c (gimplify_modify_expr): Fold generated statements.
8216 * gimple-fold.c (can_refer_decl_in_current_unit_p): Check flag_ltrans.
8217
8218 2012-06-15 Richard Guenther <rguenther@suse.de>
8219
8220 * tree-vrp.c (set_and_canonicalize_value_range): Use canonical
8221 predicates to set VR_UNDEFINED and VR_VARYING. Drop a case
8222 we assert for in set_value_range to VR_VARYING.
8223
8224 2012-06-15 Richard Earnshaw <rearnsha@arm.com>
8225
8226 * arm.md (addsf3, adddf3): Use s_register_operand.
8227 (subsf3, subdf3): Likewise.
8228 (mulsf3, muldf3): Likewise.
8229 (difsf3, divdf3): Likewise.
8230 (movsfcc, movdfcc): Likewise.
8231 * predicates.md (f_register_operand): Delete.
8232 (arm_float_rhs_operand): Delete.
8233 (arm_float_add_operand): Delete.
8234 (arm_float_compare_operand): Use s_register_operand when
8235 there's no VFP.
8236 (cirrus_register_operand): Delete.
8237 (cirrus_fp_register): Delete.
8238 (cirrus_shift_const): Delete.
8239 (cmpdi_operand): Remove Maverick support.
8240 * constraints.md (f, v, H): Delete constraints.
8241 (G): Update documentation.
8242 * arm.c (fp_consts_inited): Convert to bool.
8243 (strings_fp): Delete.
8244 (values_fp): Delete.
8245 (value_fp0): New variable.
8246 (init_fp_table): Simplify logic.
8247 (arm_const_double_rtx): Likewise.
8248 (fp_immediate_constant): Likewise.
8249 (fp_const_from_val): Likewise.
8250 (neg_const_double_rtx_ok_for_fpa): Delete.
8251 * doc/md.texi (ARM constraints): Update documentation.
8252
8253 2012-06-15 Ulrich Weigand <ulrich.weigand@linaro.org>
8254
8255 PR tree-optimization/53636
8256 * tree-vect-data-refs.c (vect_compute_data_ref_alignment): Verify
8257 stride when doing basic-block vectorization.
8258
8259 2012-06-15 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
8260
8261 * tree-vect-generic.c (lower_vec_perm): Propagate vector constants
8262 into VEC_PERM_EXPR.
8263
8264 2012-06-15 Jakub Jelinek <jakub@redhat.com>
8265
8266 * tree-vect-patterns.c (vect_pattern_recog): Don't unnecessarily
8267 allocate and free bbs array for the SLP case.
8268
8269 PR tree-optimization/51581
8270 * expr.h (choose_multiplier): New prototype.
8271 * expmed.c (choose_multiplier): No longer static.
8272 Change multiplier_ptr from rtx * to UHWI *.
8273 (expand_divmod): Adjust callers.
8274 * tree-vect-patterns.c (vect_recog_sdivmod_pow2_pattern): Renamed to...
8275 (vect_recog_divmod_pattern): ... this. Pass bb_vinfo as last
8276 argument to new_stmt_vec_info. Attempt to optimize also divisions
8277 by non-pow2 constants if integer vector division isn't supported.
8278 * tree-vect-stmts.c (vect_analyze_stmt): If node != NULL,
8279 don't look at pattern stmts and sequences.
8280
8281 2012-06-15 Eric Botcazou <ebotcazou@adacore.com>
8282
8283 PR middle-end/53590
8284 * common.opt (-fdelete-dead-exceptions): New switch.
8285 * doc/invoke.texi (Code Gen Options): Document it.
8286 * cse.c (count_reg_usage) <CALL_INSN>: Use !insn_nothrow_p in lieu of
8287 insn_could_throw_p predicate. Do not skip an insn that could throw
8288 if dead exceptions can be deleted.
8289 (insn_live_p): Likewise, do not return true in that case.
8290 * dce.c (can_alter_cfg): New flag.
8291 (deletable_insn_p): Do not return false for an insn that can throw if
8292 the CFG can be altered and dead exceptions can be deleted.
8293 (init_dce): Set can_alter_cfg to false for fast DCE, true otherwise.
8294 * dse.c (scan_insn): Use !insn_nothrow_p in lieu of insn_could_throw_
8295 predicate. Do not preserve an insn that could throw if dead exceptions
8296 can be deleted.
8297 * function.h (struct function): Add can_delete_dead_exceptions flag.
8298 * function.c (allocate_struct_function): Set it.
8299 * lto-streamer-in.c (input_struct_function_base): Stream it.
8300 * lto-streamer-out.c (input_struct_function_base): Likewise.
8301 * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Do not mark a
8302 statement that could throw as necessary if dead exceptions can be
8303 deleted.
8304
8305 2012-06-14 Maxim Kuvyrkov <maxim@codesourcery.com>
8306
8307 * config/tilegx/sync.md (atomic_fetch_sub<mode>): Fix typo.
8308
8309 2012-06-14 Oleg Endo <olegendo@gcc.gnu.org>
8310
8311 PR target/53568
8312 * config/sh/sh.md: Add peephole for swapbsi2.
8313 (*swapbisi2_and_shl8, *swapbhisi2): New insns and splits.
8314
8315 2012-06-14 Uros Bizjak <ubizjak@gmail.com>
8316
8317 * config/i386/i386.md (*zero_extendsidi2): Remove x,x alternative.
8318 (*zero_extendsidi2_rex64): Ditto. Remove isa attribute.
8319
8320 2012-06-14 Jakub Jelinek <jakub@redhat.com>
8321
8322 PR target/53639
8323 * config/i386/i386.md (*anddi_1 into *andsi_1_zext splitter): New.
8324
8325 2012-06-14 Richard Earnshaw <rearnsha@arm.com>
8326
8327 * arm.c (arm_cirrus_insn_p): Delete.
8328 (cirrus_reorg): Delete.
8329 (arm_reorg): Don't call cirrus_reorg.
8330 (arm_final_prescan_insn_p): Don't check for cirrus insns.
8331 * arm.md (define_attr "type"): Remove mav_farith and mav_dmult.
8332 (adddi3, subdi3): Remove Maverick support.
8333 (arm_adddi3): Likewise.
8334 (adddi_sesidi_di, adddi_zesidi_di): Likewise.
8335 (addsf3, adddf3): Likewise.
8336 (subsf3, subdf3): Likewise.
8337 (mulsf3, muldf3): Likewise.
8338 (ashldi3, ashrdi3, lshrdi3): Likewise.
8339 (floatsisf2, floatsidf2): Likewise.
8340 (fix_truncsfsi2, fix_truncdfsi2): Likewise.
8341 (arm_movdi, thumb1_movdi_insn): Likewise.
8342 (arm_cmpdi_insn): Likewise.
8343 (cirrus_cmpsf, cirrus_cmpdf, cirrus_cmpdi): Likewise.
8344 (cirrus.md): Don't include.
8345 * cirrus.md: Delete file.
8346 * t-arm (MD_INCLUDES): Remove cirrus.md.
8347
8348 2012-06-14 Eric Botcazou <ebotcazou@adacore.com>
8349
8350 * dwarf2out.c (function_possibly_abstracted_p): New static function.
8351 (gen_subprogram_die): Use it function_possibly_abstracted_p in lieu of
8352 cgraph_function_possibly_inlined_p.
8353 (gen_inlined_subroutine_die): Return if the origin is to be ignored.
8354 (process_scope_var): Do not emit concrete instances of abstracted
8355 nested functions from here.
8356 (gen_decl_die): Emit the abstract instance if the function is possibly
8357 abstracted and not only possibly inlined.
8358 (dwarf2out_finish): Find the first non-abstract parent instance and
8359 attach concrete instances on the limbo list to it.
8360
8361 2012-06-14 Richard Earnshaw <rearnsha@arm.com>
8362
8363 * arm.md (divsf3, divdf3): Remove FPA support.
8364 (negsf2, negdf2): Likewise.
8365 (sqrtsf2, sqrtdf2): Likewise.
8366 (movdfcc): Likewise.
8367 (modsf3, moddf3, movxf): Delete.
8368 (push_fp_multi): Delete.
8369 (fpa.md): Don't include it.
8370 * fpa.md: Delete file.
8371 * t-arm (MD_INCLUDES): Remove fpa.md.
8372
8373 2012-06-14 Bill Schmidt <wschmidt@linux.ibm.com>
8374
8375 * tree-vectorizer.h (vect_get_stmt_cost): Move from tree-vect-stmts.c.
8376 (cost_for_stmt): Remove decl.
8377 (vect_get_single_scalar_iteration_cost): Correct typo in name.
8378 * tree-vect-loop.c (vect_get_cost): Remove.
8379 (vect_get_single_scalar_iteration_cost): Correct typo in name; use
8380 vect_get_stmt_cost rather than vect_get_cost.
8381 (vect_get_known_peeling_cost): Use vect_get_stmt_cost rather than
8382 vect_get_cost.
8383 (vect_estimate_min_profitable_iters): Correct typo in call to
8384 vect_get_single_scalar_iteration_cost; use vect_get_stmt_cost rather
8385 than vect_get_cost.
8386 (vect_model_reduction_cost): Use vect_get_stmt_cost rather than
8387 vect_get_cost.
8388 (vect_model_induction_cost): Likewise.
8389 * tree-vect-data-refs.c (vect_peeling_hash_get_lowest_cost): Correct
8390 typo in call to vect_get_single_scalar_iteration_cost.
8391 * tree-vect-stmts.c (vect_get_stmt_cost): Move to tree-vectorizer.h.
8392 (cost_for_stmt): Remove unnecessary function.
8393 * Makefile.in (TREE_VECTORIZER_H): Update dependencies.
8394
8395 2012-06-14 Richard Earnshaw <rearnsha@arm.com>
8396
8397 * arm.opt (mfp=2, mfp=3, mfpe, mfpe=2, mfpe=3): Delete options.
8398 * arm-fpus.def (fpa, fpe2, fpe3, maverick): Delete FPU types.
8399 * arm-tables.opt: Regenerated.
8400 * doc/invoke.texi: Remove references to deleted options.
8401
8402 2012-06-14 Sandeep Kumar Singh <Sandeep.Singh2@kpitcummins.com>
8403
8404 * config/h8300/genmova.sh: Modified to add offset bits of
8405 mova/Sz assembly instruction for memory access.
8406 * config/h8300/h8300.c: Likewise.
8407 * config/h8300/mova.md: Likewise.
8408
8409 2012-06-12 Christian Bruel <christian.bruel@st.com>
8410
8411 PR target/53621
8412 * config/sh/sh.c (sh_option_override): Don't force
8413 flag_omit_frame_pointer and maccumulate_outgoing_args.
8414 * config/sh/sh.opt (maccumulate-outgoing-args): Init as Var.
8415
8416 2012-06-14 Richard Guenther <rguenther@suse.de>
8417
8418 * tree-vrp.c (VR_INITIALIZER): New define.
8419 (ranges_from_anti_range): New function.
8420 (extract_range_from_binary_expr_1): Decompose operations on
8421 VR_ANTI_RANGEs to operations on VR_RANGE.
8422 (extract_range_from_unary_expr_1): Likewise.
8423 (extract_range_from_binary_expr_1, extract_range_from_binary_expr,
8424 extract_range_from_unary_expr_1, extract_range_from_unary_expr,
8425 extract_range_from_cond_expr, adjust_range_with_scev,
8426 vrp_visit_assignment_or_call, vrp_visit_phi_node,
8427 simplify_bit_ops_using_ranges): Use VR_INITIALIZER.
8428
8429 2012-06-13 Richard Henderson <rth@redhat.com>
8430
8431 * hwint.h (HOST_WIDEST_INT_C): New.
8432 (HOST_WIDE_INT_C): New.
8433 (HOST_WIDE_INT_1): Use it.
8434 * config/alpha/alpha.c (alpha_trampoline_init): Use it.
8435
8436 2012-06-13 Alexandre Oliva <aoliva@redhat.com>
8437
8438 PR debug/49888
8439 * var-tracking.c: Include alias.h.
8440 (overlapping_mems): New struct.
8441 (drop_overlapping_mem_locs): New.
8442 (clobber_overlapping_mems): New.
8443 (var_mem_delete_and_set, var_mem_delete): Call it.
8444 (val_bind): Likewise, but only if modified.
8445 (compute_bb_dataflow, emit_notes_in_bb): Call it on MEMs.
8446 * Makefile.in (var-tracking.o): Depend in $(ALIAS_H).
8447
8448 2012-06-13 Alexandre Oliva <aoliva@redhat.com>
8449
8450 PR debug/47624
8451 * var-tracking.c (loc_exp_dep_pool): New.
8452 (vt_emit_notes): Create and release the pool.
8453 (compute_bb_dataflow): Use value-based locations in MO_VAL_SET.
8454 (emit_notes_in_bb): Likewise.
8455 (loc_exp_dep_insert): Deal with NOT_ONEPART vars.
8456 (notify_dependents_of_changed_value): Likewise.
8457 (notify_dependents_of_resolved_value): Check that NOT_ONEPART
8458 variables don't have a VAR_LOC_DEP_LST.
8459 (emit_note_insn_var_location): Expand NOT_ONEPART locs that are
8460 VALUEs or MEMs of VALUEs.
8461
8462 2012-06-13 Alexandre Oliva <aoliva@redhat.com>
8463
8464 PR debug/52983
8465 PR debug/48866
8466 * dce.c (word_dce_process_block): Insert debug temps only if the
8467 insn is not marked.
8468 (dce_process_block): Likewise, and if debug.used is not empty,
8469 and only after iterating over all DEFs that might mark the insn.
8470
8471 2012-06-13 Alexandre Oliva <aoliva@redhat.com>
8472
8473 * common.opt (ftree-coalesce-inlined-vars): New.
8474 (ftree-coalesce-vars): New.
8475 * doc/invoke.texi: Document them.
8476 * tree-ssa-copyrename.c (copy_rename_partition_coalesce):
8477 Implement them.
8478
8479 2012-06-13 Richard Sandiford <rdsandiford@googlemail.com>
8480
8481 * read-rtl.c (mapping): Remove index field. Add current_value field.
8482 Define heap vectors.
8483 (iterator_group): Fix long line. Remove num_builtins field and
8484 uses_iterator fields. Make apply_iterator take a void * parameter.
8485 (iterator_use, atttribute_use): New structures.
8486 (iterator_traverse_data, BELLWETHER_CODE, bellwether_codes): Delete.
8487 (current_iterators, iterator_uses, attribute_uses): New variables.
8488 (uses_mode_iterator_p, uses_code_iterator_p): Delete.
8489 (apply_mode_iterator, apply_code_iterator): Take a void * parameter.
8490 (map_attr_string, apply_iterator_to_string): Remove iterator
8491 and value parameters. Look through all current iterator values
8492 for a matching attribute.
8493 (mode_attr_index, apply_mode_maps): Delete.
8494 (apply_iterator_to_rtx): Replace with...
8495 (copy_rtx_for_iterators): ...this new function.
8496 (uses_iterator_p, apply_iterator_traverse): Delete.
8497 (apply_attribute_uses, add_current_iterators, apply_iterators): New
8498 functions.
8499 (add_mapping): Remove index field. Set current_value field.
8500 (initialize_iterators): Don't set num_builtins and uses_iterator_p
8501 fields.
8502 (find_iterator): Delete.
8503 (record_iterator_use, record_attribute_use): New functions.
8504 (record_potential_iterator_use): New function.
8505 (check_code_iterator): Remove handling of bellwether codes.
8506 (read_rtx): Remove mode maps. Truncate iterator and attribute uses.
8507 (read_rtx_code, read_nested_rtx, read_rtx_variadic): Remove mode_maps
8508 parameter. Use the first code iterator value instead of the
8509 bellwether_codes array. Use record_potential_iterator_use for modes.
8510
8511 2012-06-13 Oleg Endo <olegendo@gcc.gnu.org>
8512
8513 PR target/53568
8514 * config/sh/sh.md (bswapsi2): New expander.
8515 (swapbsi2): New insn.
8516
8517 2012-06-13 H.J. Lu <hongjiu.lu@intel.com>
8518
8519 PR target/53647
8520 * config/i386/i386.c (ix86_tune_cost): New variable.
8521 (ix86_option_override_internal): Set ix86_tune_cost. Use
8522 ix86_tune_cost for simultaneous_prefetches, prefetch_block,
8523 l1_cache_size and l2_cache_size.
8524
8525 2012-06-13 Richard Guenther <rguenther@suse.de>
8526
8527 * tree-vrp.c (vrp_meet): Properly meet equivalent ranges.
8528 Handle meeting two VR_RANGE to an VR_ANTI_RANGE. Implement
8529 all possible meetings of VR_RANGE with VR_ANTI_RANGE and
8530 VR_ANTI_RANGE with VR_ANTI_RANGE.
8531
8532 2012-06-13 Richard Earnshaw <rearnsha@arm.com>
8533
8534 * config.gcc (unsupported): Move obsoleted FPA-based configurations
8535 here from ...
8536 (obsolete): ... here.
8537 (arm*-*-freebsd*): Remove.
8538 (arm*-*-linux*): Only accept EABI variants. Simplify logic.
8539 (arm*-*-uclinux*): Likewise.
8540 (arm*-*-ecos-elf): Remove.
8541 (arm*-*-rtems*): Remove.
8542 (arm*-*-elf): Remove.
8543 (arm*-wince-pe*): Remove.
8544 (arm, --with-fpu): Remove support for fpa and Maverick variants.
8545 * arm/ecos-elf.h: Delete.
8546 * arm/t-strongarm-elf: Delete.
8547 * arm/rtems-elf.h: Delete.
8548 * arm/wince-pe.h: Delete.
8549 * arm/pe.c: Delete.
8550 * arm/pe.h: Delete.
8551 * arm/t-wince-pe: Delete.
8552
8553 2012-06-13 Bill Schmidt <wschmidt@linux.ibm.com>
8554
8555 PR tree-optimization/53647
8556 * tree-ssa-phiopt.c (gate_hoist_loads): Skip transformation for
8557 targets with no defined cache line size.
8558
8559 2012-06-13 Bill Schmidt <wschmidt@linux.ibm.com>
8560
8561 * targhooks.c (default_builtin_vectorized_conversion): Handle
8562 vec_construct, using vectype to base cost on subparts.
8563 * target.h (enum vect_cost_for_stmt): Add vec_construct.
8564 * tree-vect-stmts.c (vect_model_load_cost): Use vec_construct
8565 instead of scalar_to-vec.
8566 * config/spu/spu.c (spu_builtin_vectorization_cost): Handle
8567 vec_construct in same way as default for now.
8568 * config/i386/i386.c (ix86_builtin_vectorization_cost): Likewise.
8569 * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost):
8570 Handle vec_construct, including special case for 32-bit loads.
8571
8572 2012-06-13 Xinyu Qi <xyqi@marvell.com>
8573
8574 * config/arm/arm.c (FL_IWMMXT2): New define.
8575 (arm_arch_iwmmxt2): New variable.
8576 (arm_option_override): Enable use of iWMMXt with VFP.
8577 Disable use of iWMMXt with NEON. Disable use of iWMMXt under
8578 Thumb mode. Set arm_arch_iwmmxt2.
8579 (arm_expand_binop_builtin): Accept VOIDmode op.
8580 (enum arm_builtins): Revise built-in fcode.
8581 (IWMMXT2_BUILTIN): New define.
8582 (IWMMXT2_BUILTIN2): Likewise.
8583 (iwmmx2_mbuiltin): Likewise.
8584 (builtin_description bdesc_2arg): Revise built in declaration.
8585 (builtin_description bdesc_1arg): Likewise.
8586 (arm_init_iwmmxt_builtins): Revise built in initialization.
8587 (arm_expand_builtin): Revise built in expansion.
8588 (arm_output_iwmmxt_shift_immediate): New function.
8589 (arm_output_iwmmxt_tinsr): Likewise.
8590 * config/arm/arm-protos.h (arm_output_iwmmxt_shift_immediate): Declare.
8591 (arm_output_iwmmxt_tinsr): Likewise.
8592 * config/arm/iwmmxt.md (WCGR0, WCGR1, WCGR2, WCGR3): New constant.
8593 (iwmmxt_psadbw, iwmmxt_walign, iwmmxt_tmrc, iwmmxt_tmcr): Delete.
8594 (rorv4hi3, rorv2si3, rordi3): Likewise.
8595 (rorv4hi3_di, rorv2si3_di, rordi3_di): Likewise.
8596 (ashrv4hi3_di, ashrv2si3_di, ashrdi3_di): Likewise.
8597 (lshrv4hi3_di, lshrv2si3_di, lshrdi3_di): Likewise.
8598 (ashlv4hi3_di, ashlv2si3_di, ashldi3_di): Likewise.
8599 (iwmmxt_tbcstqi, iwmmxt_tbcsthi, iwmmxt_tbcstsi): Likewise
8600 (*iwmmxt_clrv8qi, *iwmmxt_clrv4hi, *iwmmxt_clrv2si): Likewise.
8601 (tbcstv8qi, tbcstv4hi, tbsctv2si): New pattern.
8602 (iwmmxt_clrv8qi, iwmmxt_clrv4hi, iwmmxt_clrv2si): Likewise.
8603 (*and<mode>3_iwmmxt, *ior<mode>3_iwmmxt, *xor<mode>3_iwmmxt): Likewise.
8604 (ror<mode>3, ror<mode>3_di): Likewise.
8605 (ashr<mode>3_di, lshr<mode>3_di, ashl<mode>3_di): Likewise.
8606 (ashli<mode>3_iwmmxt, iwmmxt_waligni, iwmmxt_walignr): Likewise.
8607 (iwmmxt_walignr0, iwmmxt_walignr1): Likewise.
8608 (iwmmxt_walignr2, iwmmxt_walignr3): Likewise.
8609 (iwmmxt_setwcgr0, iwmmxt_setwcgr1): Likewise.
8610 (iwmmxt_setwcgr2, iwmmxt_setwcgr3): Likewise.
8611 (iwmmxt_getwcgr0, iwmmxt_getwcgr1): Likewise.
8612 (iwmmxt_getwcgr2, iwmmxt_getwcgr3): Likewise.
8613 (All instruction patterns): Add wtype attribute.
8614 (*iwmmxt_arm_movdi, *iwmmxt_movsi_insn): iWMMXt coexist with vfp.
8615 (iwmmxt_uavgrndv8qi3, iwmmxt_uavgrndv4hi3): Revise the pattern.
8616 (iwmmxt_uavgv8qi3, iwmmxt_uavgv4hi3): Likewise.
8617 (ashr<mode>3_iwmmxt, ashl<mode>3_iwmmxt, lshr<mode>3_iwmmxt): Likewise.
8618 (iwmmxt_tinsrb, iwmmxt_tinsrh, iwmmxt_tinsrw):Likewise.
8619 (eqv8qi3, eqv4hi3, eqv2si3, gtuv8qi3): Likewise.
8620 (gtuv4hi3, gtuv2si3, gtv8qi3, gtv4hi3, gtv2si3): Likewise.
8621 (iwmmxt_wunpckihh, iwmmxt_wunpckihw, iwmmxt_wunpckilh): Likewise.
8622 (iwmmxt_wunpckilw, iwmmxt_wunpckehub, iwmmxt_wunpckehuh): Likewise.
8623 (iwmmxt_wunpckehuw, iwmmxt_wunpckehsb, iwmmxt_wunpckehsh): Likewise.
8624 (iwmmxt_wunpckehsw, iwmmxt_wunpckelub, iwmmxt_wunpckeluh): Likewise.
8625 (iwmmxt_wunpckeluw, iwmmxt_wunpckelsb, iwmmxt_wunpckelsh): Likewise.
8626 (iwmmxt_wunpckelsw, iwmmxt_wmadds, iwmmxt_wmaddu): Likewise.
8627 (iwmmxt_wsadb, iwmmxt_wsadh, iwmmxt_wsadbz, iwmmxt_wsadhz): Likewise.
8628 (iwmmxt2.md): Include.
8629 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Define __IWMMXT2__.
8630 (TARGET_IWMMXT2): New define.
8631 (TARGET_REALLY_IWMMXT2): Likewise.
8632 (arm_arch_iwmmxt2): Declare.
8633 * config/arm/mmintrin.h: Use __IWMMXT__ to enable iWMMXt intrinsics.
8634 Use __IWMMXT2__ to enable iWMMXt2 intrinsics.
8635 Use C name-mangling for intrinsics.
8636 (__v8qi): Redefine.
8637 (_mm_cvtsi32_si64, _mm_andnot_si64, _mm_sad_pu8): Revise.
8638 (_mm_sad_pu16, _mm_align_si64, _mm_setwcx, _mm_getwcx): Likewise.
8639 (_m_from_int): Likewise.
8640 (_mm_sada_pu8, _mm_sada_pu16): New intrinsic.
8641 (_mm_alignr0_si64, _mm_alignr1_si64, _mm_alignr2_si64): Likewise.
8642 (_mm_alignr3_si64, _mm_tandcb, _mm_tandch, _mm_tandcw): Likewise.
8643 (_mm_textrcb, _mm_textrch, _mm_textrcw, _mm_torcb): Likewise.
8644 (_mm_torch, _mm_torcw, _mm_tbcst_pi8, _mm_tbcst_pi16): Likewise.
8645 (_mm_tbcst_pi32): Likewise.
8646 (_mm_abs_pi8, _mm_abs_pi16, _mm_abs_pi32): New iWMMXt2 intrinsic.
8647 (_mm_addsubhx_pi16, _mm_absdiff_pu8, _mm_absdiff_pu16): Likewise.
8648 (_mm_absdiff_pu32, _mm_addc_pu16, _mm_addc_pu32): Likewise.
8649 (_mm_avg4_pu8, _mm_avg4r_pu8, _mm_maddx_pi16, _mm_maddx_pu16): Likewise.
8650 (_mm_msub_pi16, _mm_msub_pu16, _mm_mulhi_pi32): Likewise.
8651 (_mm_mulhi_pu32, _mm_mulhir_pi16, _mm_mulhir_pi32): Likewise.
8652 (_mm_mulhir_pu16, _mm_mulhir_pu32, _mm_mullo_pi32): Likewise.
8653 (_mm_qmulm_pi16, _mm_qmulm_pi32, _mm_qmulmr_pi16): Likewise.
8654 (_mm_qmulmr_pi32, _mm_subaddhx_pi16, _mm_addbhusl_pu8): Likewise.
8655 (_mm_addbhusm_pu8, _mm_qmiabb_pi32, _mm_qmiabbn_pi32): Likewise.
8656 (_mm_qmiabt_pi32, _mm_qmiabtn_pi32, _mm_qmiatb_pi32): Likewise.
8657 (_mm_qmiatbn_pi32, _mm_qmiatt_pi32, _mm_qmiattn_pi32): Likewise.
8658 (_mm_wmiabb_si64, _mm_wmiabbn_si64, _mm_wmiabt_si64): Likewise.
8659 (_mm_wmiabtn_si64, _mm_wmiatb_si64, _mm_wmiatbn_si64): Likewise.
8660 (_mm_wmiatt_si64, _mm_wmiattn_si64, _mm_wmiawbb_si64): Likewise.
8661 (_mm_wmiawbbn_si64, _mm_wmiawbt_si64, _mm_wmiawbtn_si64): Likewise.
8662 (_mm_wmiawtb_si64, _mm_wmiawtbn_si64, _mm_wmiawtt_si64): Likewise.
8663 (_mm_wmiawttn_si64, _mm_merge_si64): Likewise.
8664 (_mm_torvscb, _mm_torvsch, _mm_torvscw): Likewise.
8665 (_m_to_int): New define.
8666 * config/arm/arm-cores.def (iwmmxt2): Add FL_IWMMXT2.
8667 * config/arm/arm-arches.def (iwmmxt2): Likewise.
8668 * config/arm/t-arm (MD_INCLUDES): Add marvell-f-iwmmxt.md and
8669 iwmmxt2.md.
8670 * config/arm/arm.md (marvell-f-iwmmxt.md): Include.
8671 (arch): Add "iwmmxt2".
8672 (arch_enabled): Handle "iwmmxt2".
8673 (wtype): New attribute.
8674 (UNSPEC_WMADDS, UNSPEC_WMADDU): Delete.
8675 (UNSPEC_WALIGNI): New unspec.
8676 * config/arm/predicates.md (imm_or_reg_operand): New predicate.
8677 * config/arm/iterators.md (VMMX2): New mode_iterator.
8678 * config/arm/marvell-f-iwmmxt.md: New file.
8679 * config/arm/iwmmxt2.md: New file.
8680
8681 2012-06-12 Jakub Jelinek <jakub@redhat.com>
8682
8683 PR c/53532
8684 PR c/51034
8685 PR c/53196
8686 * c-decl.c (build_compound_literal): Call c_incomplete_type_error
8687 if type isn't complete.
8688
8689 2012-06-12 Uros Bizjak <ubizjak@gmail.com>
8690
8691 * config/ia64/sync.md (fetchop_name): Change ior attribute to "or".
8692
8693 2012-06-12 Richard Henderson <rth@redhat.com>
8694
8695 * config/rs6000/sync.md (atomic_load, atomic_store): Use INT1 mode
8696 iterator instead of INT.
8697
8698 2012-06-12 Bill Schmidt <wschmidt@linux.ibm.com>
8699
8700 * opts.c: Add -fhoist-adjacent-loads to -O2 and above.
8701 * tree-ssa-phiopt.c (tree_ssa_phiopt_worker): Add argument to forward
8702 declaration.
8703 (hoist_adjacent_loads, gate_hoist_loads): New forward declarations.
8704 (tree_ssa_phiopt): Call gate_hoist_loads.
8705 (tree_ssa_cs_elim): Add parm to tree_ssa_phiopt_worker call.
8706 (tree_ssa_phiopt_worker): Add do_hoist_loads to formal arg list; call
8707 hoist_adjacent_loads.
8708 (local_mem_dependence): New function.
8709 (hoist_adjacent_loads): Likewise.
8710 (gate_hoist_loads): Likewise.
8711 * common.opt (fhoist-adjacent-loads): New switch.
8712 * Makefile.in (tree-ssa-phiopt.o): Added dependencies.
8713
8714 2012-06-12 Michael Matz <matz@suse.de>
8715
8716 * alias.c (nonoverlapping_component_refs_p): Take two rtx arguments.
8717 (nonoverlapping_memrefs_p): Don't call it here ...
8718 (true_dependence_1): ... but here.
8719
8720 2012-06-12 Richard Guenther <rguenther@suse.de>
8721
8722 * emit-rtl.c (set_mem_attributes_minus_bitpos): Remove dead code.
8723 * alias.c (ao_ref_from_mem): MEM_EXPR is conservative, MEM_OFFSET
8724 and MEM_SIZE only refines it. Reflect that and be less conservative
8725 if either of the latter is not known.
8726
8727 2012-06-12 Jakub Jelinek <jakub@redhat.com>
8728
8729 PR rtl-optimization/53589
8730 * cfgrtl.c (force_nonfallthru_and_redirect): Do asm_goto_edge
8731 discovery even when e->dest != target. If any LABEL_REF points
8732 to e->dest label, redirect it to target's label.
8733
8734 2012-06-12 Chung-Lin Tang <cltang@codesourcery.com>
8735
8736 * config/sh/sh.c (output_stack_adjust): Remove !epilogue_p
8737 condition for generating REG_FRAME_RELATED_EXPR note.
8738 (pop): Add code for generating REG_CFA_RESTORE,
8739 REG_CFA_ADJUST_CFA notes. Set RTX_FRAME_RELATED_P to 1.
8740 (sh_expand_epilogue): Use frame_insn() for FP to SP move.
8741 Set 'frame_p' of calls to output_stack_adjust() to 'true'.
8742
8743 2012-06-11 Richard Henderson <rth@redhat.com>
8744
8745 * config/alpha/alpha.c (HWI_HEX2): Add missing shift.
8746 * vmsdbgout.c (VMS_EPOCH_OFFSET): Add LL suffix.
8747
8748 * config/alpha/alpha.c (alpha_trampoline_init): Split large constants.
8749
8750 2012-06-12 Hans-Peter Nilsson <hp@axis.com>
8751
8752 * doc/tm.texi.in (Addressing Modes) <TARGET_LEGITIMIZE_ADDRESS>:
8753 Mention that this hook needs to be defined for native TLS.
8754 * doc/tm.texi: Regenerate.
8755
8756 2012-06-11 Mike Stump <mikestump@comcast.net>
8757
8758 * emit-rtl.c (init_emit_once): Iterate through the
8759 MODE_PARTIAL_INT modes with MIN_MODE_PARTIAL_INT and
8760 MAX_MODE_PARTIAL_INT, as GET_MODE_WIDER_MODE doesn't step through
8761 all the MIN_MODE_PARTIAL_INT modes anymore.
8762
8763 2012-06-12 Maxim Kuvyrkov <maxim@codesourcery.com>
8764
8765 * gcc/config/mips/mips-tables.opt (xlp): Fix merge typo.
8766
8767 2012-06-11 Roland McGrath <mcgrathr@google.com>
8768
8769 * dwarf2out.c (const_ok_for_output_1): Detect a TLS UNSPEC using
8770 SYMBOL_REF_TLS_MODEL rather than DECL_THREAD_LOCAL_P, in case it's
8771 not a VAR_DECL. Also don't limit it to UNSPECs with exactly one
8772 operand.
8773
8774 2012-06-11 Oleg Endo <olegendo@gcc.gnu.org>
8775
8776 PR target/53511
8777 * config/sh/sh.md (fmasf4): New expander.
8778 (*macsf3): Rename to fmasf4_i. Adapt to fma pattern.
8779 (mac_media): Rename to fmasf4_media. Adapt to fma pattern.
8780 * config/sh/sh.opt (mfused-madd): Remove.
8781 * config/sh/sh.c (sh_option_override): Remove mfused-madd handling.
8782 (builtin_description bdesc): Remove __builtin_sh_media_FMAC_S.
8783 * config.gcc (sh[123456789lbe]*-*-* | sh-*-*): Add fused-madd.opt
8784 as extra options.
8785 * doc/invoke.texi (SH Options): Update mfused-madd and mno-fused-madd
8786 descriptions.
8787
8788 2012-06-11 Richard Henderson <rth@redhat.com>
8789
8790 * dwarf2cfi.c (scan_trace): Handle annulled branch-taken delay slots.
8791
8792 2012-06-11 Richard Guenther <rguenther@suse.de>
8793
8794 PR middle-end/53470
8795 * tree.c (free_lang_data_in_type): Do not clear TYPE_CONTEXT but
8796 replace it with the first non-BLOCK context.
8797
8798 2012-06-11 Richard Guenther <rguenther@suse.de>
8799
8800 * alias.c (aliases_everything_p): Remove.
8801 (DIFFERENT_ALIAS_SETS_P): Likewise.
8802 (true_dependence_1): Use mems_in_disjoint_alias_sets_p directly.
8803 Do not use aliases_everything_p or special-case ANDs. Do not
8804 special-case BLKmode moves.
8805 (may_alias_p): Likewise. Handle BLKmode similar like everywhere
8806 - for SCATCH only.
8807
8808 2012-06-09 Hans-Peter Nilsson <hp@axis.com>
8809
8810 Fix CRIS build errors with --enable-build-with-cxx.
8811 * config/cris/cris.c (cris_emit_trap_for_misalignment): Rename
8812 variable "and" to "andop".
8813 * config/cris/sync.md ("atomic_fetch_<atomic_op_name><mode>"): Use
8814 temporary variable for memory model, passing C++-type-correct
8815 parameter type to expand_mem_thread_fence.
8816 ("atomic_compare_and_swap<mode>"): Ditto.
8817
8818 2012-06-09 Richard Henderson <rth@redhat.com>
8819
8820 PR c++/53602
8821 * cfgcleanup.c (execute_jump): Rename from rest_of_handle_jump2.
8822 (pass_jump): Rename from pass_jump2.
8823 (execute_jump2, pass_jump2): New.
8824 * combine-stack-adj.c (rest_of_handle_stack_adjustments): Don't
8825 perform cfg cleanup here. Move the test of PUSH_ROUNDING
8826 and ACCUMULATE_OUTGOING_ARGS test...
8827 (gate_handle_stack_adjustments): ... here.
8828 * passes.c (init_optimization_passes): Update for pass_jump2 rename.
8829 Place new pass_jump2 after pass_stack_adjustments.
8830 * tree-pass.h (pass_jump): Declare.
8831
8832 2012-06-09 Kenneth Zadeck <zadeck@naturalbridge.com>
8833
8834 * simplify-rtx.c (simplify_const_binary_operation): Fixed shift
8835 count trucation.
8836
8837 2012-06-08 Richard Henderson <rth@redhat.com>
8838
8839 PR c++/53602
8840 * combine-stack-adj.c (force_move_args_size_note): Add ARGS_SIZE
8841 note to a clobber insn when no other insn is available.
8842
8843 2012-06-08 Georg-Johann Lay <avr@gjlay.de>
8844
8845 * config/avr/avr.c (avr_case_values_threshold): Return 7.
8846
8847 2012-06-07 Andreas Schwab <schwab@linux-m68k.org>
8848
8849 * genhooks.c (main): Set progname.
8850 (emit_documentation): Remove variable found_start, always bail out
8851 when a place is missing.
8852 * doc/tm.texi.in (C++ ABI): Add @hook TARGET_CXX_DECL_MANGLING_CONTEXT.
8853
8854 2012-06-07 Jakub Jelinek <jakub@redhat.com>
8855
8856 PR middle-end/53580
8857 * omp-low.c (scan_omp): Change first argument to gimple_seq *,
8858 call walk_gimple_seq_mod instead of walk_gimple_seq.
8859 (scan_sharing_clauses, scan_omp_parallel, scan_omp_task,
8860 scan_omp_for, scan_omp_sections, scan_omp_single,
8861 execute_lower_omp): Adjust callers.
8862 (scan_omp_1_stmt): Likewise. If check_omp_nesting_restrictions
8863 returns false, replace stmt with GIMPLE_NOP.
8864 (check_omp_nesting_restrictions): Instead of issuing warnings,
8865 issue errors and return false if any errors were reported.
8866
8867 2012-06-06 Steven Bosscher <steven@gcc.gnu.org>
8868
8869 * doc/invoke.texi (fconserve-space): Remove documentation.
8870
8871 2012-06-06 Edmar Wienskoski <edmar@freescale.com>
8872
8873 * config/rs6000/rs6000-tables.opt: Regenerated.
8874
8875 2012-06-06 Richard Guenther <rguenther@suse.de>
8876
8877 PR tree-optimization/53081
8878 * tree-data-ref.h (adjacent_store_dr_p): Rename to ...
8879 (adjacent_dr_p): ... this and make it work for reads, too.
8880 * tree-loop-distribution.c (enum partition_kind): Add PKIND_MEMCPY.
8881 (struct partition_s): Change main_stmt to main_dr, add
8882 secondary_dr member.
8883 (build_size_arg_loc): Change to date data-reference and not
8884 gimplify here.
8885 (build_addr_arg_loc): New function split out from ...
8886 (generate_memset_builtin): ... here. Use it and simplify.
8887 (generate_memcpy_builtin): New function.
8888 (generate_code_for_partition): Adjust.
8889 (classify_partition): Streamline pattern detection. Detect memcpy.
8890 (ldist_gen): Adjust.
8891 (tree_loop_distribution): Adjust seed statements for memcpy
8892 recognition.
8893
8894 2012-06-06 Matt Turner <mattst88@gmail.com>
8895
8896 * config/arm/mmintrin.h (_mm_empty): New.
8897 (_m_empty): New.
8898
8899 2012-06-06 Richard Sandiford <r.sandiford@uk.ibm.com>
8900
8901 * doc/invoke.texi (sched-pressure-algorithm): Document new --param.
8902 * common.opt (fsched-pressure-algorithm=): Remove.
8903 * flag-types.h (sched_pressure_algorithm): Move to...
8904 * sched-int.h (sched_pressure_algorithm): ...here.
8905 * params.def (sched-pressure-algorithm): New param.
8906 * haifa-sched.c (sched_init): Use it to initialize sched_pressure.
8907 * common/config/s390/s390-common.c (s390_option_optimization_table):
8908 Remove OPT_fsched_pressure_algorithm_ entry.
8909 * config/s390/s390.c (s390_option_override): Set a default value for
8910 PARAM_SCHED_PRESSURE_ALGORITHM.
8911
8912 2012-06-05 Michael Meissner <meissner@linux.vnet.ibm.com>
8913
8914 PR target/53487
8915 * config/rs6000/rs6000.c (rs6000_generate_compare): If we are
8916 doing an unsigned compare, make sure the second argument is not a
8917 negative constant.
8918 (rs6000_emit_cmove): Don't allow floating point comparisons when
8919 generating ISEL moves.
8920
8921 2012-06-05 Edmar Wienskoski <edmar@freescale.com>
8922
8923 * config/rs6000/e5500.md: New file.
8924 * config/rs6000/e6500.md: New file.
8925 * config/rs6000/rs6000.c (processor_costs): Add new costs for
8926 e5500 and e6500.
8927 (rs6000_option_override_internal): Altivec and Spe options not
8928 allowed with e5500. Spe options not allowed with e6500. Increase
8929 move inline limit for e5500 and e6500. Disable string instructions
8930 for e5500 and e6500. Enable branch targets alignment for e5500 and
8931 e6500. Initialize rs6000_cost for e5500 and e6500.
8932 (rs6000_adjust_cost): Add extra scheduling cycles between compare
8933 and brnach for e5500 and e6500.
8934 (rs6000_issue_rate): Set issue rate for e5500 and e6500.
8935 * config/rs6000/rs6000-cpus.def: Add cpu definitions for e5500 and
8936 e6500.
8937 * config/rs6000/rs6000.h (ASM_CPU_SPEC): Add e5500 and e6500.
8938 * config/rs6000/rs6000.md (define_attr "cpu"): Add ppce5500 and
8939 ppce6500.
8940 Include e5500.md and e6500.md.
8941 * config/rs6000/rs6000-opt.h (processor_type): Add
8942 PROCESSOR_PPCE5500 and PROCESSOR_PPCE6500.
8943 * config.gcc (cpu_is_64bit): Add new cores e5500, e6500.
8944 (powerpc*-*-*): Add new cores e5500, e6500.
8945 * doc/invoke.texi: (item -mcpu): Add e5500 and e6500 to list of cpus.
8946
8947 2012-06-05 Richard Guenther <rguenther@suse.de>
8948
8949 * tree-vect-data-refs.c (vect_analyze_data_refs): Fix last change.
8950
8951 2012-06-05 H.J. Lu <hongjiu.lu@intel.com>
8952
8953 PR target/53575
8954 * config.gcc: Select x32 run-time library if --with-abi={x32|mx32}
8955 is used for x86_64-*-*.
8956
8957 2012-06-05 Richard Guenther <rguenther@suse.de>
8958
8959 PR tree-optimization/30442
8960 * tree-vect-data-refs.c (vect_analyze_data_refs): For basic-block
8961 vectorization stop analysis at the first stmt we cannot compute
8962 a data-reference for instead of giving up completely.
8963
8964 2012-06-05 Richard Guenther <rguenther@suse.de>
8965
8966 * tree-loop-distribution.c (struct partition_s): Add has_writes member.
8967 (partition_alloc): Initialize it.
8968 (partition_has_writes): New function.
8969 (rdg_flag_uses): Adjust.
8970 (rdg_flag_vertex): Likewise.
8971 (rdg_flag_vertex_and_dependent): Likewise.
8972 (rdg_flag_loop_exits): Likewise.
8973 (build_rdg_partition_for_component): Likewise.
8974 (rdg_build_partitions): Likewise.
8975
8976 2012-06-05 Richard Guenther <rguenther@suse.de>
8977
8978 PR tree-optimization/53081
8979 * tree-loop-distribution.c (generate_memset_builtin): Handle all
8980 kinds of byte-sized stores.
8981 (classify_partition): Likewise.
8982 (tree_loop_distribution): Adjust seed statements used for
8983 !flag_tree_loop_distribution.
8984
8985 2012-06-05 Alan Modra <amodra@gmail.com>
8986
8987 * config/rs6000/rs6000.c (ptr_regno_for_savres): Comment.
8988 (rs6000_emit_prologue): Ensure register used for inline saves
8989 of vector regs is not the static chain register. Revise comment.
8990
8991 2012-06-04 Oleg Endo <olegendo@gcc.gnu.org>
8992
8993 * doc/md.texi (Standard Pattern Names For Generation): Document
8994 sincos pattern.
8995
8996 2012-06-04 H.J. Lu <hongjiu.lu@intel.com>
8997
8998 PR bootstrap/53555
8999 * config/i386/i386.c (ix86_sched_reorder) Skip debug insns.
9000
9001 2012-06-04 Jason Merrill <jason@redhat.com>
9002
9003 * dwarf2out.c (is_unit_die): New.
9004 (copy_declaration_context, copy_ancestor_tree): Use it.
9005 (copy_decls_walk): Likewise.
9006
9007 2012-06-04 Paolo Carlini <paolo.carlini@oracle.com>
9008
9009 PR c++/53524
9010 * doc/invoke.texi (Wenum-compare): Update documentation.
9011
9012 2012-06-04 Dodji Seketeli <dodji@redhat.com>
9013
9014 PR preprocessor/53463
9015 * parser.c (cp_parser_assignment_expression): Use the location
9016 for the '=' as the default location for the expression.
9017
9018 2012-06-04 Edmar Wienskoski <edmar@freescale.com>
9019
9020 PR target/53559
9021 * config/rs6000/altivec.md (altivec_stvlx): Change machine mode of
9022 operands.
9023 (altivec_stvlxl): Ditto.
9024 (altivec_stvrx): Ditto.
9025 (altivec_stvrxl): Ditto.
9026
9027 2012-06-04 Vladimir Makarov <vmakarov@redhat.com>
9028
9029 * ira-int.h (struct target_ira_int): Add member x_ira_uniform_class_p.
9030 (ira_uniform_class_p): New macro.
9031
9032 * ira.c (setup_uniform_class_p): New function.
9033 (setup_allocno_and_important_classes): Call the function.
9034 (print_unform_and_important_classes): New function.
9035 (print_classes): Rename to print_translated_classes.
9036 (ira_debug_allocno_classes): Add call of
9037 print_unform_and_important_classes.
9038
9039 * ira-costs.c (setup_regno_cost_classes_by_aclass): Use uniform
9040 classes instead of pressure classes.
9041
9042 2012-06-04 Aldy Hernandez <aldyh@redhat.com>
9043
9044 PR middle-end/47530
9045 * trans-mem.c (expand_block_edges): Do not skip the first
9046 statement when resetting the BB.
9047
9048 2012-06-04 Richard Guenther <rguenther@suse.de>
9049
9050 * tree-data-ref.c (stores_from_loop): Remove.
9051 (stmt_with_adjacent_zero_store_dr_p): Likewise.
9052 (stores_zero_from_loop): Likewise.
9053 * tree-data-ref.h (stores_from_loop, stores_zero_from_loop,
9054 stmt_with_adjacent_zero_store_dr_p, stride_of_unit_type_p): Remove.
9055 (adjacent_store_dr_p): New function.
9056 * tree-loop-distribution.c (generate_memset_builtin): Pass
9057 the RDG, use the already available data-reference.
9058 (generate_code_for_partition): Pass down RDG.
9059 (classify_partition): Inline parts of the former
9060 stmt_with_adjacent_zero_store_dr_p here and use adjacent_store_dr_p.
9061 (ldist_gen): Remember if there was any detected builtin and
9062 do less work if not and flag_tree_loop_distribution is not set.
9063 (tree_loop_distribution): Inline and fuse stores_from_loop
9064 and stores_zero_from_loop here.
9065
9066 2012-06-04 Richard Guenther <rguenther@suse.de>
9067
9068 PR middle-end/53471
9069 * dwarf2out.c (dwarf2out_finish): If generating LTO do not
9070 create new assembler names.
9071
9072 2012-06-04 Richard Guenther <rguenther@suse.de>
9073
9074 * tree-data-ref.c (struct rdg_vertex_info): Remove.
9075 (rdg_vertex_for_stmt): Simplify using gimple_uid.
9076 (create_rdg_vertices): Pass loop argument, remove stmt to RDG index
9077 hashtable. Record stmt data-references.
9078 (hash_stmt_vertex_info): Remove.
9079 (eq_stmt_vertex_info): Likewise.
9080 (hash_stmt_vertex_del): Likewise.
9081 (build_empty_rdg): Simplify.
9082 (build_rdg): Adjust.
9083 (free_rdg): Likewise.
9084 (ref_base_address): Remove.
9085 (have_similar_memory_accesses): Likewise.
9086 * tree-data-ref.h (create_rdg_vertices): Remove.
9087 (struct rdg_vertex): Add datarefs member.
9088 (RDGV_DATAREFS): New define.
9089 (RDG_DATAREFS): Likewise.
9090 (have_similar_memory_accesses): Remove.
9091 (rdg_has_similar_memory_accesses): Likewise.
9092 * tree-loop-distribution.c (ref_base_address): Re-implement here.
9093 (similar_memory_accesses): Re-implement using existing data-references.
9094 (tree_loop_distribution): Initialize stmt uids for the stmt to
9095 RDG index mapping.
9096 * tree-vect-loop.c (vect_create_epilog_for_reduction): Only
9097 access stmt vinfo for stmts in loop.
9098
9099 2012-06-04 Andreas Schwab <schwab@linux-m68k.org>
9100
9101 PR target/53461
9102 * config/m68k/m68k.md ("tablejump"): Fix check for
9103 CASE_VECTOR_PC_RELATIVE.
9104
9105 2012-06-04 Steven Bosscher <steven@gcc.gnu.org>
9106
9107 * output.h (merge_weak, assemble_alias,
9108 initializer_constant_valid_p,
9109 initializer_constant_valid_for_bitfield_p): Move protos from here...
9110 * tree.h: ... to here.
9111 * cgraphclones.c: Do not include output.h.
9112 * gimplify.c: Likewise.
9113 * reload.c: Likewise.
9114 * recog.c: Likewise.
9115 * tree-ssa-loop-ivopts.c: Likewise.
9116 * tree-switch-conversion.c: Likewise.
9117 * c-parser.c: Likewise.
9118 * c-typeck.c: Likewise.
9119 * Makefile.in: Fix dependencies.
9120
9121 2012-06-04 Georg-Johann Lay <avr@gjlay.de>
9122
9123 PR target/46261
9124 * config/avr/avr-stdint.h: New file.
9125 * config.gcc (avr-*-*,tm_file): Use avr/avr-stdint.h instead of
9126 newlib-stdint.h
9127
9128 2012-06-04 Jakub Jelinek <jakub@redhat.com>
9129
9130 PR tree-optimization/53550
9131 * tree-ssa-loop-niter.c (number_of_iterations_cond): If type
9132 is POINTER_TYPE_P, use sizetype as step type instead of type.
9133
9134 2012-06-04 Richard Guenther <rguenther@suse.de>
9135
9136 * tree-data-ref.c (have_similar_memory_accesses_1): Remove.
9137 (ref_base_address_1): Likewise.
9138 (remove_similar_memory_refs): Likewise.
9139 * tree-data-ref.h (remove_similar_memory_refs): Remove.
9140 * tree-loop-distribution.c (classify_partition): Do not classify
9141 as builtin if -ftree-loop-distribute-patterns is not enabled.
9142 (fuse_partitions_with_similar_memory_accesses): Inline ...
9143 (ldist_gen): ... here. Fuse all non-builtin partitions if
9144 -ftree-loop-distribution is not enabled. Properly return
9145 the number of created partitions. Do not update SSA form here but ...
9146 (tree_loop_distribution): ... once here for the whole function.
9147 Only walk innermost loops, constrain loops we consider here
9148 further. Do not call remove_similar_memory_refs.
9149 (distribute_loop): Do not check number of loop nodes here.
9150
9151 2012-06-04 Steven Bosscher <steven@gcc.gnu.org>
9152
9153 * Makefile.in (GIMPLE_H): Do not depend on TARGET_H.
9154
9155 2012-06-03 Martin Jambor <mjambor@suse.cz>
9156
9157 * ipa-prop.h (ipa_get_jf_known_type_offset): New function.
9158 (ipa_get_jf_known_type_base_type): Likewise.
9159 (ipa_get_jf_known_type_component_type): Likewise.
9160 (ipa_get_jf_constant): Likewise.
9161 (ipa_get_jf_pass_through_formal_id): Likewise.
9162 (ipa_get_jf_pass_through_operation): Likewise.
9163 (ipa_get_jf_ancestor_offset): Likewise.
9164 (ipa_get_jf_ancestor_type): Likewise.
9165 (ipa_get_jf_ancestor_formal_id): Likewise.
9166 (ipa_get_jf_member_ptr_pfn): Likewise.
9167 * ipa-prop.c (ipa_set_jf_known_type): New function.
9168 (ipa_set_jf_constant): Likewise.
9169 (ipa_set_jf_simple_pass_through): Likewise.
9170 (ipa_set_jf_arith_pass_through): Likewise.
9171 (ipa_set_ancestor_jf): Likewise.
9172 (fill_member_ptr_cst_jump_function): Moved up and renamed to
9173 ipa_set_jf_member_ptr_cst.
9174 (detect_type_change_1): Use the new jump function creation functions.
9175 (compute_complex_assign_jump_func): Likewise.
9176 (compute_complex_ancestor_jump_func): Likewise.
9177 (compute_known_type_jump_func): Likewise.
9178 (compute_scalar_jump_functions): Likewise.
9179 (compute_pass_through_member_ptrs): Likewise.
9180 (determine_cst_member_ptr): Likewise.
9181 (combine_known_type_and_ancestor_jfs): Likewise.
9182 (try_make_edge_direct_simple_call): Likewise.
9183 (try_make_edge_direct_virtual_call): Likewise.
9184 (update_indirect_edges_after_inlining): Likewise.
9185 * ipa-cp.c (ipa_get_jf_pass_through_result): Use jump function
9186 access functions. Incorporat NOP_EXPR and BINFO handling from its
9187 callers.
9188 (ipa_get_jf_ancestor_result): Likewise. Incorporate handling BINFOs
9189 which was in its callers.
9190 (ipa_value_from_jfunc): Use jump function access functions. Some
9191 functionality moved to functions above.
9192 (propagate_vals_accross_ancestor): Likewise.
9193 (propagate_vals_accross_pass_through): Use jump function access
9194 functions.
9195 (propagate_accross_jump_function): Likewise.
9196 * ipa-inline-analysis.c (remap_edge_change_prob): Use jump function
9197 access functions.
9198 (inline_merge_summary): Likewise.
9199
9200 2012-06-03 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
9201
9202 * config/pa/pa.h (MAX_PCREL17F_OFFSET): Define.
9203 * config/pa/pa.c (pa_attr_length_millicode_call): Use
9204 MAX_PCREL17F_OFFSET instead of fixed offset.
9205 (pa_attr_length_call): Likewise.
9206 (pa_attr_length_indirect_call): Likewise.
9207
9208 2012-06-03 Oleg Endo <olegendo@gcc.gnu.org>
9209
9210 PR target/53512
9211 * config/sh/sh.opt (mfsca, mfsrra): New options.
9212 * config/sh/sh.md (rsqrtsf2): Use TARGET_FPU_ANY and TARGET_FSRRA
9213 condition.
9214 (fsca): Use TARGET_FPU_ANY and TARGET_FSCA condition.
9215 (sinssf2, cossf2): Fold expanders to ...
9216 (sincossf3): ... this new expander. Use TARGET_FPU_ANY and
9217 TARGET_FSCA condition.
9218 * config/sh/sh.c (sh_option_override): Handle TARGET_FSRRA and
9219 TARGET_FSCA.
9220 * doc/invoke.texi (SH Options): Add descriptions for -mfsca,
9221 -mno-fsca, -mfsrra, -mno-fsrra.
9222
9223 2012-06-03 Matt Turner <mattst88@gmail.com>
9224
9225 * config/mips/4600.md (r4700_imul_si): New.
9226 (r4700_imul_di): New.
9227 (r4700_fmul_single): New.
9228 (r4700_fmul_double): New.
9229 * config/mips/mips-cpus.def: Add r4700.
9230 * config/mips/mips.c: Likewise.
9231 * config/mips/mips.md: Likewise.
9232 * config/mips/mips-tables.opt: Regenerate.
9233
9234 2012-06-02 Steven Bosscher <steven@gcc.gnu.org>
9235
9236 * config/sparc/sparc.h (INITIAL_ELIMINATION_OFFSET): Split out to
9237 new function sparc_initial_elimination_offset.
9238 * config/sparc/sparc.c (sparc_initial_elimination_offset): New
9239 function.
9240 * config/sparc/sparc-protos.h (sparc_initial_elimination_offset):
9241 Prototype it.
9242
9243 2012-06-02 Kenneth Zadeck <zadeck@naturalbridge.com>
9244
9245 * expmed.c (expand_mult, choose_multiplier): Change
9246 "2 * HOST_BITS_PER_WIDE_INT" to "HOST_BITS_PER_DOUBLE_INT".
9247 * expr.c (convert_modes): Likewise.
9248 * explow.c (plus_constant): Likewise.
9249 * fixed-value.c (fixed_saturate1, fixed_saturate2)
9250 (do_fixed_add, do_fixed_multiply, do_fixed_multiply)
9251 (do_fixed_multiply, do_fixed_multiply, do_fixed_divide)
9252 (do_fixed_divide, do_fixed_divide, do_fixed_divide)
9253 (do_fixed_divide, do_fixed_divide, do_fixed_shift, do_fixed_shift)
9254 (do_fixed_shift, fixed_convert, fixed_convert)
9255 (fixed_convert_from_int, fixed_convert_from_int)
9256 (fixed_convert_from_real): Likewise.
9257 * fold-const.c (fold_convert_const_int_from_fixed, sign_bit_p)
9258 (native_interpret_int, fold_binary_loc, fold_ternary_loc): Likewise.
9259 * varasm.c (output_constructor_bitfield): Likewise.
9260 * tree-vrp.c (register_edge_assert_for_2): Likewise.
9261 * double-int.c (rshift_double, lshift_double): Likewise.
9262 * double-int.h (double_int_fits_in_uhwi_p, double_int, double_int):
9263 Likewise.
9264 * simplify-rtx.c (mode_signbit_p)
9265 (simplify_const_unary_operation, simplify_binary_operation_1)
9266 (simplify_immed_subreg): Likewise.
9267 * builtins.c (c_readstr, fold_builtin_bitop): Likewise.
9268 * tree-vect-generic.c (build_replicated_const): Likewise.
9269 * dbxout.c (stabstr_O): Likewise.
9270 * emit-rtl.c (immed_double_int_const, immed_double_const)
9271 (gen_lowpart_common, init_emit_once): Likewise.
9272 * tree.c (integer_pow2p, tree_log2, tree_floor_log2)
9273 (widest_int_cst_value, upper_bound_in_type): Likewise.
9274 * stor-layout.c (initialize_sizetypes, fixup_signed_type)
9275 (fixup_unsigned_type): Likewise.
9276 * real.c (real_to_integer2, real_from_integer): Likewise.
9277 * dwarf2out.c (size_of_loc_descr, size_of_die, output_die)
9278 (clz_loc_descriptor, mem_loc_descriptor): Likewise.
9279
9280 2012-06-01 Eric Botcazou <ebotcazou@adacore.com>
9281
9282 PR middle-end/53501
9283 * fold-const.c (fold_binary_loc): Refine previous change.
9284
9285 2012-06-01 Olivier Hainque <hainque@adacore.com>
9286
9287 * config/rs6000/vxworks.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Restore
9288 the "do {" part of the do-while(0) loop.
9289
9290 2012-06-01 Yuri Rumyantsev <yuri.s.rumyantsev@intel.com>
9291
9292 * config/i386/i386.c (x86_sched_reorder): New function.
9293 Added new function x86_sched_reorder.
9294
9295 2012-06-01 Richard Guenther <rguenther@suse.de>
9296
9297 * tree-loop-distribution.c (stmt_has_scalar_dependences_outside_loop):
9298 Handle PHIs.
9299 (classify_partition): Likewise.
9300
9301 2012-06-01 Richard Guenther <rguenther@suse.de>
9302
9303 * tree-loop-distribution.c (enum partition_kind): New enum.
9304 (struct partition_s): Add kind and main_stmt members.
9305 (partition_alloc): Initialize kind to PKIND_NORMAL.
9306 (partition_builtin_p): New function.
9307 (copy_loop_before): Remove failure path and assert instead.
9308 (generate_loops_for_partition): Likewise.
9309 (generate_memset_zero): Fold into ...
9310 (generate_memset_builtin): ... this.
9311 (classify_partition): New function with code from
9312 can_generate_builtin and generate_builtin.
9313 (generate_builtin): Remove.
9314 (can_generate_builtin): Likewise.
9315 (fuse_partitions_with_similar_memory_accesses): Call
9316 partition_builtin_p instead of can_generate_builtin.
9317 (rdg_build_partitions): Do not call
9318 fuse_partitions_with_similar_memory_accesses here...
9319 (ldist_gen): ... but here after classifying all partitions.
9320 Remove failure path of generate_code_for_partition.
9321 (generate_code_for_partition): Generate code according
9322 to partition classification.
9323
9324 2012-06-01 Manuel López-Ibáñez <manu@gcc.gnu.org>
9325 Jonathan Wakely <jwakely.gcc@gmail.com>
9326
9327 PR c++/50134
9328 * doc/invoke.texi (Warning Options): Explain purpose and differences
9329 between -Wmissing-prototypes and -Wmissing-declarations.
9330
9331 2012-06-01 Christian Bruel <christian.bruel@st.com>
9332
9333 * gcc.c (save_switch): Add user_p parameter.
9334 (read_specs): Likewise.
9335 (set_specs): Likewise.
9336 (validate_switches): Likewise.
9337 (validate_switches_from_spec): Likewise.
9338 (validate_all_switches): Pass on user_p parameter.
9339 (struct spec_list): Add user_p field.
9340 (struct switchstr): Add known field.
9341 (save_switch): Add known parameter.
9342 (INIT_STATIC_SPEC): Initialize user_p;
9343 (driver_unknown_option_callbac): call save_switch if
9344 OPT_SPECIAL_unknown.
9345 (driver_handle_option): Propagate OPT_specs.
9346 (do_spec_1): Set validated only if known.
9347 (check_live_switch): Likewise.
9348 (validate_switches): Set validated if known or user_spec.
9349
9350 2012-06-01 Hans-Peter Nilsson <hp@axis.com>
9351
9352 Add CRIS atomic patterns for 1, 2, and 4 bytes.
9353 * config/cris/cris.c (cris_emit_trap_for_misalignment): New function.
9354 * config/cris/cris-protos.h: Declare it.
9355 * config/cris/cris.h [!TARGET_DEFAULT, TARGET_CPU_DEFAULT == 32]
9356 (TARGET_DEFAULT): Add alignment by 32.
9357 [!TARGET_DEFAULT, TARGET_CPU_DEFAULT == 10] (TARGET_DEFAULT): New
9358 case, as TARGET_CPU_DEFAULT == 0 but with alignment as for
9359 TARGET_CPU_DEFAULT == 32.
9360 (TARGET_TRAP_UNALIGNED_ATOMIC): New macro.
9361 * config/cris/cris.md: Include sync.md. Avoid allocating specific
9362 numbers by replacing the define_constants for all UNSPECs with the
9363 equivalent define_c_enum construct.
9364 * config/cris/cris.opt (mtrap-unaligned-atomic): New option.
9365 * config/cris/sync.md: New file.
9366
9367 2012-05-31 Matt Turner <mattst88@gmail.com>
9368
9369 * config/mips/4600.md (r4600_imul_si): Rename from r4600_imul.
9370 (r4600_imul_di): New.
9371 (r4600_idiv_si): Rename from r4600_idiv.
9372 (r4600_idiv_di): New.
9373
9374 2012-05-31 Steven Bosscher <steven@gcc.gnu.org>
9375
9376 * output.h (__gcc_host_wide_int__): Move to hwint.h.
9377 (decl_default_tls_model): Move to tree.h
9378 (dump_file): Move to system.h.
9379 (default_stabs_asm_out_destructor, default_stabs_asm_out_constructor,
9380 dbxout_int, dbxout_stabd, dbxout_begin_stabn, dbxout_begin_stabn_sline,
9381 dbxout_begin_empty_stabs, dbxout_begin_simple_stabs,
9382 dbxout_begin_simple_stabs_desc, dbxout_stab_value_zero,
9383 dbxout_stab_value_zero, dbxout_stab_value_label_diff,
9384 dbxout_stab_value_internal_label,
9385 dbxout_stab_value_internal_label_diff): Move from here ...
9386 * dbxout.h: ... to here.
9387 * system.h (dump_file): Moved here from output.h.
9388 * hwint.h (__gcc_host_wide_int__): Moved here from output.h.
9389 * tree.h (decl_default_tls_model): Moved here from output.h.
9390 * varasm.c (default_stabs_asm_out_destructor,
9391 default_stabs_asm_out_constructor): Move from here ...
9392 * dbxout.c: ... to here.
9393
9394 * gcov-dump.c (dump_file): Rename to dump_gcov_file. Update callers.
9395
9396 * collect2.h (dump_file): Rename to dump_ld_file.
9397 * collect2.c: Likewise.
9398 * tlink.c: Likewise.
9399
9400 * alias.c: Do not include output.h.
9401 * auto-inc-dec.c: Likewise.
9402 * bt-load.c: Likewise.
9403 * caller-save.c: Likewise.
9404 * cfg.c: Likewise.
9405 * cfgbuild.c: Likewise.
9406 * cfgcleanup.c: Likewise.
9407 * cfglayout.c: Likewise.
9408 * cfgloop.c: Likewise.
9409 * cfgloopanal.c: Likewise.
9410 * cfgloopmanip.c: Likewise.
9411 * cfgrtl.c: Likewise.
9412 * cgraph.c: Likewise.
9413 * cgraphclones.c: Likewise.
9414 * combine-stack-adj.c: Likewise.
9415 * combine.c: Likewise.
9416 * cprop.c: Likewise.
9417 * cse.c: Likewise.
9418 * cselib.c: Likewise.
9419 * dbgcnt.c: Likewise.
9420 * df-problems.c: Likewise.
9421 * df-scan.c: Likewise.
9422 * dojump.c: Likewise.
9423 * fwprop.c: Likewise.
9424 * gcse.c: Likewise.
9425 * graph.c: Likewise.
9426 * haifa-sched.c: Likewise.
9427 * hw-doloop.c: Likewise.
9428 * ipa-inline-transform.c: Likewise.
9429 * ipa-pure-const.c: Likewise.
9430 * ipa-reference.c: Likewise.
9431 * ipa-utils.c: Likewise.
9432 * ira-build.c: Likewise.
9433 * ira-emit.c: Likewise.
9434 * lcm.c: Likewise.
9435 * loop-doloop.c: Likewise.
9436 * loop-invariant.c: Likewise.
9437 * loop-iv.c: Likewise.
9438 * loop-unroll.c: Likewise.
9439 * loop-unswitch.c: Likewise.
9440 * lto-cgraph.c: Likewise.
9441 * lto-section-in.c: Likewise.
9442 * lto-streamer-in.c: Likewise.
9443 * mcf.c: Likewise.
9444 * mode-switching.c: Likewise.
9445 * postreload-gcse.c: Likewise.
9446 * postreload.c: Likewise.
9447 * predict.c: Likewise.
9448 * profile.c: Likewise.
9449 * ree.c: Likewise.
9450 * reg-stack.c: Likewise.
9451 * regcprop.c: Likewise.
9452 * regmove.c: Likewise.
9453 * regstat.c: Likewise.
9454 * reload1.c: Likewise.
9455 * sched-ebb.c: Likewise.
9456 * sel-sched-dump.c: Likewise.
9457 * simplify-rtx.c: Likewise.
9458 * stor-layout.c: Likewise.
9459 * store-motion.c: Likewise.
9460 * tracer.c: Likewise.
9461 * tree-affine.c: Likewise.
9462 * tree-cfg.c: Likewise.
9463 * tree-cfgcleanup.c: Likewise.
9464 * tree-dfa.c: Likewise.
9465 * tree-into-ssa.c: Likewise.
9466 * tree-nomudflap.c: Likewise.
9467 * tree-optimize.c: Likewise.
9468 * tree-pretty-print.c: Likewise.
9469 * tree-profile.c: Likewise.
9470 * tree-ssa-address.c: Likewise.
9471 * tree-ssa-ccp.c: Likewise.
9472 * tree-ssa-copy.c: Likewise.
9473 * tree-ssa-dom.c: Likewise.
9474 * tree-ssa-loop-ch.c: Likewise.
9475 * tree-ssa-loop-im.c: Likewise.
9476 * tree-ssa-loop-manip.c: Likewise.
9477 * tree-ssa-loop-niter.c: Likewise.
9478 * tree-ssa-loop-prefetch.c: Likewise.
9479 * tree-ssa-loop-unswitch.c: Likewise.
9480 * tree-ssa-loop.c: Likewise.
9481 * tree-ssa-propagate.c: Likewise.
9482 * tree-ssa-structalias.c: Likewise.
9483 * tree-ssa-tail-merge.c: Likewise.
9484 * tree-ssa-threadedge.c: Likewise.
9485 * tree-ssa-threadupdate.c: Likewise.
9486 * tree-ssa-uncprop.c: Likewise.
9487 * tree-ssa-uninit.c: Likewise.
9488 * tree-ssa.c: Likewise.
9489 * value-prof.c: Likewise.
9490 * var-tracking.c: Likewise.
9491 * web.c: Likewise.
9492
9493 * config/m32r/m32r.c: Include dbxout.h.
9494 * config/pa/pa.c: Likewise.
9495 * config/rs6000/rs6000.c: Likewise.
9496
9497 * Makefile.in: Fix dependencies.
9498 * config/rs6000/t-rs5000: Likewise.
9499
9500 2012-05-31 Aldy Hernandez <aldyh@redhat.com>
9501
9502 * tree-ssa-loop-im.c (execute_sm): Do not check flag_tm.
9503 * gimple.h (block_in_transaction): Check for flag_tm.
9504
9505 2012-05-31 Aldy Hernandez <aldyh@redhat.com>
9506
9507 PR tree-optimization/52558
9508 * cfg.c (alloc_aux_for_edge): Fix comment.
9509 (alloc_aux_for_edge): Remove static.
9510 * basic-block.h (alloc_aux_for_edge): Protoize.
9511 * tree-ssa-loop-im.c (execute_sm_if_changed): New.
9512 (execute_sm_if_changed_flag): New.
9513 (execute_sm_if_changed_flag_set): New.
9514 (execute_sm): Do not generate data races unless requested.
9515 (tree_ssa_lim_initialize): Call alloc_aux_for_edges.
9516 (tree_ssa_lim_finalize): Call free_aux_for_edges.
9517 * gimple.h (block_in_transaction): New.
9518 (gimple_in_transaction): Use block_in_transaction.
9519
9520 2012-05-31 Georg-Johann Lay <avr@gjlay.de>
9521
9522 PR target/51345
9523 * config/avr/avr.opt (-msp8): Document it.
9524 * doc/invoke.texi (AVR Options): Ditto. And document related
9525 built-in macros.
9526
9527 2012-05-31 Diego Novillo <dnovillo@google.com>
9528
9529 * configure.ac (CXX_FOR_BUILD): Define and substitute.
9530 (BUILD_CXXFLAGS): Define and substitute.
9531 * Makefile.in (BUILD_CXXFLAGS): Define.
9532 (CXX_FOR_BUILD): Define.
9533 (COMPILER_FOR_BUILD): Set to CXX_FOR_BUILD if building with C++.
9534 (LINKER_FOR_BUILD): Likewise.
9535 (BUILD_COMPILERFLAGS): Set to BUILD_CXXFLAGS if building with C++.
9536 (BUILD_LINKERFLAGS): Likewise.
9537 * configure: Regenerate.
9538
9539 2012-05-31 Steven Bosscher <steven@gcc.gnu.org>
9540
9541 * Makefile.in: Fix many dependencies.
9542 * tree-profile.c: Don't include regs.h.
9543 * tree-vectorizer.c: Don't include cfglayout.h.
9544 * tree-vect-stmts.c: Likewise.
9545 * tree-vect-slp.c: Likewise.
9546 * tree-vect-loop.c: Likewise.
9547 * reg-stack.c: Likewise.
9548 * tree-ssa-loop-manip.c: Likewise.
9549 * toplev.c: Likewise.
9550 * varasm.c: Don't include cfglayout.h, basic-block.h,
9551 and tree-iterator.h.
9552 * tree-cfgcleanup.c: Don't include cfglayout.h.
9553 * passes.c: Don't include cfglayout.h, dwarf2asm.h,
9554 dwarf2out.h, dbxout.h, sdbout.h, and xcoffout.h.
9555 * cgraphclones.c: Don't include plugin.h.
9556
9557 2012-05-31 Georg-Johann Lay <avr@gjlay.de>
9558
9559 * config/avr/t-avr: Correct avr-mmcu.texi dependencies.
9560 (s-avr-mmcu-texi): Don't sed on gen-avr-mmcu-texi output.
9561 * doc/avr-mmcu.texi (svn:eol-style): Set to native.
9562
9563 2012-05-31 Richard Guenther <rguenther@suse.de>
9564
9565 * tree-loop-distribution.c (struct partition_s): New struct,
9566 typedef and vector type.
9567 (partition_alloc, partition_free): New functions.
9568 (generate_loops_for_partition, generate_builtin,
9569 generate_code_for_partition, rdg_flag_uses, rdg_flag_vertex,
9570 rdg_flag_vertex_and_dependent, rdg_flag_loop_exits,
9571 build_rdg_partition_for_component, can_generate_builtin,
9572 similar_memory_accesses, fuse_partitions_with_similar_memory_accesses,
9573 rdg_build_partitions, dump_rdg_partitions, debug_rdg_partitions,
9574 number_of_rw_in_partition, partition_contains_all_rw,
9575 ldist_gen): Use partition_t instead of bitmap.
9576
9577 2012-05-31 Georg-Johann Lay <avr@gjlay.de>
9578
9579 * config/avr/gen-avr-mmcu-texi.c: Sort MCUs.
9580 * doc/avr-mmcu.texi: Regenerate.
9581
9582 2012-05-31 Richard Guenther <rguenther@suse.de>
9583
9584 * tree-loop-distribution.c (stmt_has_scalar_dependences_outside_loop):
9585 Use FOR_EACH_SSA_DEF_OPERAND.
9586 (generate_builtin): Adjust.
9587 (stmt_generated_in_another_partition): Remove.
9588 (add_scalar_computations_to_partition): Likewise.
9589 (rdg_build_partitions): Do not call
9590 add_scalar_computations_to_partition.
9591
9592 2012-05-31 Eric Botcazou <ebotcazou@adacore.com>
9593
9594 * tree-dfa.c (get_ref_base_and_extent): Compute the offset using
9595 double ints throughout.
9596 * tree-sra.c (build_user_friendly_ref_for_offset) <RECORD_TYPE>:
9597 Check that the position of the field is representable as an integer.
9598
9599 2012-05-31 Richard Guenther <rguenther@suse.de>
9600
9601 * tree-data-ref.c (dr_analyze_innermost): Properly convert
9602 the MEM_REF offset to sizetype.
9603
9604 2012-05-31 Georg-Johann Lay <avr@gjlay.de>
9605
9606 * doc/invoke.texi (AVR Options): Fix typos.
9607
9608 2012-05-31 Hans-Peter Nilsson <hp@axis.com>
9609
9610 * config/cris/cris.h (CC1_SPEC): Pass through all -march=
9611 and -mcpu= options.
9612 (ASM_SPEC): Ditto, not just -march=v32, but translate non-v10,
9613 non-v32 into --march=v0_v10.
9614
9615 2012-05-31 Richard Sandiford <rdsandiford@googlemail.com>
9616
9617 * ira-int.h (target_ira_int): Rename x_move_cost to
9618 x_ira_register_move_cost, x_may_move_in_cost to
9619 x_ira_may_move_in_cost and x_may_move_out_cost to
9620 x_ira_may_move_out_cost. Delete the old fields with
9621 those names and also x_ira_max_register_move_cost,
9622 x_ira_max_may_move_in_cost and x_ira_max_may_move_out_cost.
9623 (move_cost, may_move_in_cost, may_move_out_cost)
9624 (ira_max_register_move_cost, ira_max_may_move_in_cost)
9625 (ira_max_may_move_out_cost): Delete.
9626 * ira.c (init_move_cost): Rename to...
9627 (ira_init_register_move_cost): ...this, deleting the old
9628 function with that name. Apply above variable renamings.
9629 Retain asserts for null fields.
9630 (ira_init_once): Don't initialize register move costs here.
9631 (free_register_move_costs): Apply above variable renamings.
9632 Remove code for deleted fields.
9633
9634 2012-05-31 Richard Sandiford <rdsandiford@googlemail.com>
9635
9636 * ira.c (init_move_cost): Adjust choice of subclasses to match
9637 the current ira_init_register_move_cost choice. Use
9638 ira_class_subset_p instead of reg_class_subset_p.
9639 (ira_init_register_move_cost): Assert that move_cost,
9640 may_move_in_cost and may_move_out_cost already hold the desired
9641 values for their ira_* equivalents. For the latter two,
9642 ignore classes that can't store a register of the given mode.
9643
9644 2012-05-31 Richard Sandiford <rdsandiford@googlemail.com>
9645
9646 * ira.c (setup_allocno_and_important_classes): Use
9647 ira_class_hard_regs_num to check whether a class has any
9648 allocatable registers.
9649 (ira_init_register_move_cost): Likewise.
9650
9651 2012-05-31 Richard Sandiford <rdsandiford@googlemail.com>
9652
9653 * ira.c (init_move_cost): Adjust local variable names to match
9654 file conventions. Use ira_assert instead of gcc_assert.
9655
9656 2012-05-31 Richard Sandiford <rdsandiford@googlemail.com>
9657
9658 * regs.h (move_table, move_cost, may_move_in_cost, may_move_out_cost):
9659 Move these definitions and associated target_globals fields to...
9660 * ira-int.h: ...here.
9661 * rtl.h (init_move_cost): Delete.
9662 * reginfo.c (last_mode_for_init_move_cost, init_move_cost): Move to...
9663 * ira.c: ...here, making the latter static.
9664
9665 2012-05-31 Richard Sandiford <rdsandiford@googlemail.com>
9666
9667 * ira-costs.c (copy_cost): Use ira_init_register_move_cost_if_necessary
9668 and ira_register_move_cost instead of init_move_cost and move_cost.
9669
9670 2012-05-31 Richard Sandiford <rdsandiford@googlemail.com>
9671
9672 * ira.h (target_ira): Delete x_ira_available_class_regs.
9673 (ira_available_class_regs): Delete.
9674 * ira.c (setup_available_class_regs): Delete.
9675 (setup_alloc_classes): Don't call it.
9676 (setup_pressure_classes): Use ira_class_hard_regs_num instead of
9677 ira_available_class_regs.
9678 * haifa-sched.c (print_curr_reg_pressure, setup_insn_reg_pressure_info)
9679 (model_spill_cost): Likewise.
9680 * ira-build.c (low_pressure_loop_node_p): Likewise.
9681 * ira-color.c (color_pass): Likewise.
9682 * ira-emit.c (change_loop): Likewise.
9683 * ira-lives.c (inc_register_pressure, dec_register_pressure)
9684 (single_reg_class, ira_implicitly_set_insn_hard_regs)
9685 (process_bb_node_lives): Likewise.
9686 * loop-invariant.c (gain_for_invariant): Likewise.
9687
9688 2012-05-30 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
9689
9690 PR target/52999
9691 * config/pa/pa.c (TARGET_SECTION_TYPE_FLAGS): Define.
9692 (pa_section_type_flags): New.
9693 (pa_legitimate_constant_p): Revert previous change.
9694
9695 2012-05-30 Steven Bosscher <steven@gcc.gnu.org>
9696
9697 * ira.c (allocate_initial_values): Make static.
9698
9699 2012-05-30 Uros Bizjak <ubizjak@gmail.com>
9700
9701 * config/i386/i386.c (legitimize_tls_address) <TLS_MODEL_INITIAL_EXEC>:
9702 Generate tls_initial_exec_64_sun only when !TARGET_X32.
9703
9704 2012-05-30 Richard Guenther <rguenther@suse.de>
9705
9706 PR middle-end/53501
9707 * fold-const.c (fold_binary_loc): Make sure to call
9708 fold_plusminus_mult_expr with the original sign of operands.
9709
9710 2012-05-30 Steven Bosscher <steven@gcc.gnu.org>
9711
9712 * Makefile.in: Fix many dependencies.
9713 (DWARF2_H): Depend on dwarf2.def.
9714 (RTL_ERROR_H): Depend on rtl-error.h.
9715 (TREE_PRETTY_PRINT_H, GIMPLE_PRETTY_PRINT_H): New. Replace
9716 all gimple-pretty-print.h and tree-pretty-print.h references.
9717
9718 2012-05-30 Marc Glisse <marc.glisse@inria.fr>
9719
9720 * simplify-rtx.c (simplify_binary_operation_1): Optimize shuffle of
9721 concatenations.
9722
9723 2012-05-30 Richard Guenther <rguenther@suse.de>
9724
9725 PR middle-end/53522
9726 * tree-emutls.c (gen_emutls_addr): Do not add globals to
9727 referenced-vars.
9728
9729 2012-05-30 Eric Botcazou <ebotcazou@adacore.com>
9730
9731 * explow.c (probe_stack_range): Restore simple control flow and stop
9732 again when the probe cannot be generated if HAVE_check_stack.
9733
9734 2012-05-30 Jakub Jelinek <jakub@redhat.com>
9735
9736 PR rtl-optimization/53519
9737 * combine.c (simplify_shift_const_1) <case NOT>: Use constm1_rtx
9738 instead of GEN_INT (GET_MODE_MASK (mode)) as second operand of XOR.
9739
9740 2012-05-30 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
9741
9742 * config/arm/arm.c (arm_evpc_neon_vrev): Adjust off by one error.
9743
9744 2012-05-29 Jack Howarth <howarth@bromo.med.uc.edu>
9745
9746 PR debug/53453
9747 * doc/tm.texi: Update.
9748 * doc/tm.texi.in (SDB and DWARF) <TARGET_FORCE_AT_COMP_DIR>: Add @hook.
9749 * target.def (force_at_comp_dir): New hook.
9750 * config/darwin.h (TARGET_FORCE_AT_COMP_DIR): Define.
9751 * dwarf2out.c (dwarf2out_finish): Check targetm.force_at_comp_dir.
9752
9753 2012-05-29 Jack Howarth <howarth@bromo.med.uc.edu>
9754
9755 * config/darwin.h (STARTFILE_SPEC): Do not use -lbundle1.o when
9756 Darwin >= 10.
9757 (DARWIN_DYLIB1_SPEC): Do not use -ldylib1.10.5.o when Darwin >= 10.
9758 (DARWIN_CRT1_SPEC): Use -lcrt1.10.6.o when Darwin >= 10.
9759
9760 2012-05-29 Oleg Endo <olegendo@gcc.gnu.org>
9761
9762 PR target/51340
9763 * config/sh/sh.c (sh_option_override): Set TARGET_FMAC if
9764 flag_unsafe_math_optimizations is set.
9765 * doc/invoke.texi (SH Options): Add -mno-fused-madd description.
9766 Update description of -mfused-madd.
9767
9768 2012-05-29 Oleg Endo <olegendo@gcc.gnu.org>
9769
9770 PR target/52941
9771 * config/sh/predicates.md (atomic_arith_operand,
9772 atomic_logical_operand): New predicates.
9773 * config/sh/sh.c (sh_option_override): Check atomic options.
9774 * config/sh/sh.h (TARGET_ANY_ATOMIC, UNSUPPORTED_ATOMIC_OPTIONS,
9775 UNSUPPORTED_HARD_ATOMIC_CPU): New macros.
9776 (DRIVER_SELF_SPECS): Use UNSUPPORTED_ATOMIC_OPTIONS and
9777 UNSUPPORTED_HARD_ATOMIC_CPU.
9778 * config/sh/sync.md: Update description comments.
9779 (I12): New mode iterator.
9780 (fetchop_predicate, fetchop_constraint): New code attributes.
9781 (atomic_compare_and_swapsi_hard, atomic_compare_and_swap<mode>_hard,
9782 atomic_exchangesi_hard, atomic_exchange<mode>_hard,
9783 atomic_fetch_<fetchop_name>si_hard,
9784 atomic_fetch_<fetchop_name><mode>_hard,
9785 atomic_fetch_nandsi_hard, atomic_fetch_nand<mode>_hard,
9786 atomic_<fetchop_name>_fetchsi_hard,
9787 atomic_<fetchop_name>_fetch<mode>_hard,
9788 atomic_nand_fetchsi_hard, atomic_nand_fetch<mode>_hard,
9789 atomic_test_and_set_hard): New insns.
9790 (atomic_compare_and_swap<mode>_soft, atomic_exchange<mode>_soft,
9791 atomic_fetch_<fetchop_name><mode>_soft, atomic_fetch_nand<mode>_soft,
9792 atomic_<fetchop_name>_fetch<mode>_soft, atomic_nand_fetch<mode>_soft,
9793 atomic_test_and_set_soft): Use same formatting for the first line of
9794 the asm block as in new insns above.
9795 (atomic_compare_and_swap<mode>, atomic_exchange<mode>,
9796 atomic_fetch_<fetchop_name><mode>, atomic_<fetchop_name>_fetch<mode>,
9797 atomic_test_and_set): Integrate new *_hard insns into expanders.
9798 * config/sh/sh.opt (mhard-atomic): New option.
9799 * doc/invoke.texi (SH Options): Document it.
9800
9801 2012-05-29 Meador Inge <meadori@codesourcery.com>
9802
9803 * c-decl.c (c_push_function_context): Always create a new language
9804 function.
9805 (c_pop_function_context): Clear the language function created in
9806 c_push_function_context.
9807
9808 2012-05-29 Matt Turner <mattst88@gmail.com>
9809
9810 * config/alpha/ev6.md: (define_bypass "ev6_fmul,ev6_fadd"): New.
9811 (define_bypass "ev6_fcmov"): New.
9812
9813 2012-05-29 Steven Bosscher <steven@gcc.gnu.org>
9814
9815 * integrate.c: Remove.
9816 * integrate.h: Remove.
9817 * Makefile.in: Remove make rules for integrate.c and INTEGRATE_H.
9818 * config/arm/t-arm: Remove INTEGRATE_H dependency for target files.
9819 * config/rs6000/t-rs6000: Likewise
9820 * config/spu/t-spu-elf: Likewise.
9821 * function.h (get_hard_reg_initial_val, has_hard_reg_initial_val,
9822 get_hard_reg_initial_reg, emit_initial_value_sets): Move prototypes
9823 from integrate.h to here.
9824 (initial_value_entry): New prototype.
9825 * reload.h (allocate_initial_values): Remove prototype.
9826 * tree.h (set_decl_abstract_flags, set_decl_origin_self): Likewise.
9827 * cse.c (fixed_base_plus_p): Don't handle virtual registers for
9828 integrate.c.
9829 * dwarf2out.c (set_decl_origin_self, set_block_origin_self,
9830 set_decl_abstract_flags, set_block_abstract_flags): Move from
9831 integrate.c to here, the only user.
9832 * expmed.c (extract_fixed_bit_field): Remove outdated comment
9833 about integrate.c.
9834 * function.c: Don't include integrate.h.
9835 (struct initial_value_pair, struct initial_value_struct,
9836 get_hard_reg_initial_val, has_hard_reg_initial_val,
9837 get_hard_reg_initial_reg, emit_initial_value_sets): Move from
9838 integrate.c to here.
9839 (initial_value_entry): New function.
9840 * genemit.c (main): Don't print integrate.h include line.
9841 * ira.c: Don't include integrate.h.
9842 (allocate_initial_values): Move from integrate.c to here.
9843 (ira): Update allocate_initial_values call.
9844 * tree-inline.c: Don't include integrate.h.
9845 (function_attribute_inlinable_p): Moved from integrate.c to here.
9846 * cfgexpand.c: Don't include integrate.h.
9847 * except.c: Likewise.
9848 * langhooks.c: Likewise.
9849 * passes.c: Likewise.
9850 * toplev.c: Likewise.
9851 * config/frv/frv.c: Likewise.
9852 * config/pa/pa.c: Likewise.
9853 * config/spu/spu.c: Likewise.
9854 * config/epiphany/epiphany.c: Likewise.
9855 * config/mep/mep.c: Likewise.
9856 * config/score/score.c: Likewise.
9857 * config/picochip/picochip.c: Likewise.
9858 * config/sh/sh.c: Likewise.
9859 * config/alpha/alpha.c: Likewise.
9860 * config/microblaze/microblaze.c: Likewise.
9861 * config/mips/mips.c: Likewise.
9862 * config/v850/v850.c: Likewise.
9863 * config/mmix/mmix.c: Likewise.
9864 * config/bfin/bfin.c: Likewise.
9865 * config/arm/arm.c: Likewise.
9866 * config/s390/s390.c: Likewise.
9867 * config/m32r/m32r.c: Likewise.
9868 * config/rs6000/rs6000.c: Likewise.
9869 * config/c6x/c6x.c: Include function.h instead of integrate.h.
9870 * config/tilegx/tilegx.c: Likewise.
9871 * config/tilepro/tilepro.c: Likewise.
9872
9873 2012-05-29 Georg-Johann Lay <avr@gjlay.de>
9874
9875 * config/avr/t-avr (s-avr-mmcu-texi): Call
9876 gen-avr-mmcu-texi$(build_exeext) via ./ and don't assume . is in PATH.
9877
9878 2012-05-29 Michael Matz <matz@suse.de>
9879
9880 * rtl.h (assign_stack_temp, assign_stack_temp_for_type,
9881 assign_temp): Remove 'keep' argument.
9882 (mark_temp_addr_taken): Remove prototype.
9883 * tree.h (expand_decl): Remove prototype.
9884 * function.c (struct temp_slot): Remove addr_taken and keep member.
9885 (assign_stack_temp_for_type) Don't initialize above, remove
9886 keep argument.
9887 (assign_stack_temp, assign_temp): Remove keep argument.
9888 (mark_temp_addr_taken): Remove.
9889 (preserve_temp_slots): Remove handling of addr_taken and keep members.
9890 (free_temp_slots): Ditto.
9891 * expr.c (expand_expr_real_1 <COMPOUND_LITERAL_EXPR>): Remove
9892 dead code.
9893 * stmt.c (expand_asm_operands): Remove dead code.
9894 (expand_decl): Remove.
9895 * c-decl.c (finish_struct): Don't call expand_decl.
9896 * builtins.c (expand_builtin_cexpi): Adjust calls to assign_temp
9897 and assign_stack_temp.
9898 * calls.c (save_fixed_argument_area, initialize_argument_information,
9899 expand_call, emit_library_call_value_1, store_one_arg): Ditto.
9900 * expmed.c (extract_bit_field_1): Ditto.
9901 * expr.c (emit_group_load_1, emit_group_store,
9902 copy_blkmode_from_reg, emit_push_insn, expand_assignment,
9903 store_field, expand_constructor, expand_cond_expr_using_cmove,
9904 expand_expr_real_2, expand_expr_real_1): Ditto.
9905 * stmt.c (expand_asm_operands, expand_return): Ditto.
9906
9907 * function.c (pop_temp_slots): Call free_temp_slots.
9908 * calls.c (store_one_arg): Don't call preserve_temp_slots or
9909 free_temp_slots.
9910 * expr.c (expand_assignment): Don't call free_temp_slots.
9911
9912 * config/arm/arm.c (neon_expand_vector_init): Ditto.
9913 * config/i386/i386.c (ix86_expand_vector_set): Ditto.
9914 (ix86_expand_vector_extract): Ditto.
9915 * config/ia64/ia64.c (spill_xfmode_rfmode_operand,
9916 ia64_expand_movxf_movrf): Ditto.
9917 * config/mips/mips.c (mips_expand_vi_general): Ditto.
9918 * config/mmix/mmix.md (floatdisf2, floatunsdisf2, truncdfsf2,
9919 extendsfdf2): Ditto.
9920 * config/rs6000/rs6000.c (rs6000_expand_vector_init,
9921 rs6000_expand_vector_set, rs6000_expand_vector_extract,
9922 rs6000_allocate_stack_temp): Ditto.
9923 * config/rs6000/rs6000.md (fix_trunctfsi2_fprs): Ditto.
9924 * config/sparc/sparc.c (emit_soft_tfmode_libcall,
9925 sparc_emit_float_lib_cmp, sparc_emit_float_lib_cmp,
9926 sparc_expand_vector_init): Ditto.
9927
9928 2012-05-29 Michael Matz <matz@suse.de>
9929
9930 * c-tree.h (c_expand_decl): Remove prototype.
9931
9932 * expr.c (expand_expr_real_1 <normal_inner_ref>): Don't allocate
9933 a kept temp.
9934 (expand_expr_real_1 <COMPOUND_LITERAL_EXPR>): Make unreachable.
9935 * gimple-fold.c (canonicalize_constructor_val): Canonicalize
9936 COMPOUND_LITERAL_EXPR.
9937 * function.c (expand_function_start): Don't call expand_decl,
9938 instead assert that we have RTL assigned.
9939 * tree-ssa-live.c (remove_unused_locals): Clear
9940 nonlocal_goto_save_area if its backing variable is removed.
9941 * stmt.c (expand_asm_operands): Remove handling of non-lvalues
9942 as mem inputs.
9943 (expand_decl): Assert that this does nothing.
9944 * calls.c (expand_call): Don't call mark_temp_addr_taken.
9945
9946 2012-05-29 Richard Guenther <rguenther@suse.de>
9947
9948 PR tree-optimization/53516
9949 * tree-data-ref.c (stmt_with_adjacent_zero_store_dr_p): Reject
9950 bitfield accesses.
9951 * tree-vect-data-refs.c (vect_analyze_data_refs): Likewise.
9952
9953 2012-05-29 Joseph Myers <joseph@codesourcery.com>
9954
9955 * LANGUAGES: Fix typos.
9956 * Makefile.in: Fix typos.
9957 * alias.c: Fix typos.
9958 * auto-inc-dec.c: Fix typos.
9959 * bb-reorder.c: Fix typos.
9960 * cfgcleanup.c: Fix typos.
9961 * cgraph.c: Fix typos.
9962 * cgraph.h: Fix typos.
9963 * cgraphunit.c: Fix typos.
9964 * collect2-aix.h: Fix typos.
9965 * collect2.c: Fix typos.
9966 * compare-elim.c: Fix typos.
9967 * config/alpha/vms.h: Fix typos.
9968 * config/arm/README-interworking: Fix typos.
9969 * config/arm/arm.c: Fix typos.
9970 * config/arm/iterators.md: Fix typos.
9971 * config/arm/vxworks.h: Fix typos.
9972 * config/avr/avr.c: Fix typos.
9973 * config/avr/avr.h: Fix typos.
9974 * config/avr/avr.md: Fix typos.
9975 * config/avr/builtins.def: Fix typos.
9976 * config/c6x/c6x.c: Fix typos.
9977 * config/cr16/cr16.c: Fix typos.
9978 * config/cr16/cr16.md: Fix typos.
9979 * config/cris/cris.md: Fix typos.
9980 * config/darwin.c: Fix typos.
9981 * config/darwin.opt: Fix typos.
9982 * config/i386/i386-c.c: Fix typos.
9983 * config/i386/i386.c: Fix typos.
9984 * config/ia64/ia64.c: Fix typos.
9985 * config/m68k/cf.md: Fix typos.
9986 * config/mep/mep.c: Fix typos.
9987 * config/microblaze/microblaze.c: Fix typos.
9988 * config/microblaze/microblaze.h: Fix typos.
9989 * config/mn10300/mn10300.c: Fix typos.
9990 * config/mn10300/mn10300.md: Fix typos.
9991 * config/pa/pa.c: Fix typos.
9992 * config/picochip/picochip.h: Fix typos.
9993 * config/rs6000/a2.md: Fix typos.
9994 * config/rs6000/rs6000.c: Fix typos.
9995 * config/rs6000/vector.md: Fix typos.
9996 * config/rx/rx.md: Fix typos.
9997 * config/rx/rx.opt: Fix typos.
9998 * config/s390/2097.md: Fix typos.
9999 * config/s390/s390.c: Fix typos.
10000 * config/s390/s390.h: Fix typos.
10001 * config/sh/sh.c: Fix typos.
10002 * config/sh/sh.md: Fix typos.
10003 * config/sparc/sync.md: Fix typos.
10004 * config/spu/spu.c: Fix typos.
10005 * config/spu/spu.md: Fix typos.
10006 * config/vms/vms.c: Fix typos.
10007 * config/vxworks-dummy.h: Fix typos.
10008 * config/vxworks.h: Fix typos.
10009 * cselib.c: Fix typos.
10010 * df-scan.c: Fix typos.
10011 * df.h: Fix typos.
10012 * doc/extend.texi: Fix typos.
10013 * doc/install.texi: Fix typos.
10014 * doc/invoke.texi: Fix typos.
10015 * doc/md.texi: Fix typos.
10016 * doc/plugins.texi: Fix typos.
10017 * doc/rtl.texi: Fix typos.
10018 * dse.c: Fix typos.
10019 * dwarf2asm.c: Fix typos.
10020 * dwarf2out.c: Fix typos.
10021 * except.h: Fix typos.
10022 * expr.c: Fix typos.
10023 * fold-const.c: Fix typos.
10024 * gcc.c: Fix typos.
10025 * gcse.c: Fix typos.
10026 * genautomata.c: Fix typos.
10027 * gengtype-state.c: Fix typos.
10028 * gengtype.c: Fix typos.
10029 * genhooks.c: Fix typos.
10030 * gimple-fold.c: Fix typos.
10031 * gimple-pretty-print.c: Fix typos.
10032 * gimple.c: Fix typos.
10033 * gimple.h: Fix typos.
10034 * gimplify.c: Fix typos.
10035 * graphite-interchange.c: Fix typos.
10036 * graphite-sese-to-poly.c: Fix typos.
10037 * ifcvt.c: Fix typos.
10038 * input.c: Fix typos.
10039 * ipa-cp.c: Fix typos.
10040 * ipa-inline-analysis.c: Fix typos.
10041 * ipa-inline-transform.c: Fix typos.
10042 * ipa-inline.c: Fix typos.
10043 * ipa-pure-const.c: Fix typos.
10044 * ipa-ref.h: Fix typos.
10045 * ipa-reference.c: Fix typos.
10046 * ipa-utils.c: Fix typos.
10047 * ipa.c: Fix typos.
10048 * ira-emit.c: Fix typos.
10049 * ira-lives.c: Fix typos.
10050 * lto-streamer.c: Fix typos.
10051 * lto-streamer.h: Fix typos.
10052 * lto-wrapper.c: Fix typos.
10053 * mcf.c: Fix typos.
10054 * mode-switching.c: Fix typos.
10055 * modulo-sched.c: Fix typos.
10056 * plugin.c: Fix typos.
10057 * postreload.c: Fix typos.
10058 * sched-deps.c: Fix typos.
10059 * sel-sched-ir.c: Fix typos.
10060 * sel-sched-ir.h: Fix typos.
10061 * sel-sched.c: Fix typos.
10062 * sese.c: Fix typos.
10063 * stor-layout.c: Fix typos.
10064 * target-hooks-macros.h: Fix typos.
10065 * target.def: Fix typos.
10066 * trans-mem.c: Fix typos.
10067 * tree-eh.c: Fix typos.
10068 * tree-predcom.c: Fix typos.
10069 * tree-sra.c: Fix typos.
10070 * tree-ssa-address.c: Fix typos.
10071 * tree-ssa-loop-ivopts.c: Fix typos.
10072 * tree-ssa-loop-niter.c: Fix typos.
10073 * tree-ssa-math-opts.c: Fix typos.
10074 * tree-ssa-pre.c: Fix typos.
10075 * tree-ssa-propagate.c: Fix typos.
10076 * tree-ssa-reassoc.c: Fix typos.
10077 * tree-ssa-sccvn.c: Fix typos.
10078 * tree-ssa-ter.c: Fix typos.
10079 * tree-ssa-uninit.c: Fix typos.
10080 * tree-ssanames.c: Fix typos.
10081 * tree-vect-generic.c: Fix typos.
10082 * tree-vect-slp.c: Fix typos.
10083 * tree.c: Fix typos.
10084 * tree.h: Fix typos.
10085 * varasm.c: Fix typos.
10086 * varpool.c: Fix typos.
10087
10088 2012-05-29 Joseph Myers <joseph@codesourcery.com>
10089
10090 * doc/include/texinfo.tex: Update to version 2012-05-16.16.
10091
10092 2012-05-29 Richard Guenther <rguenther@suse.de>
10093
10094 * tree-dfa.c (find_vars_r): Do not call add_referenced_vars
10095 for globals.
10096 (add_referenced_var_1): Re-organize. Assert we are not
10097 called for globals.
10098 (remove_referenced_var): Likewise.
10099 * varpool.c (add_new_static_var): Use create_tmp_var_raw.
10100 * tree-mudflap.c (execute_mudflap_function_ops): Do not
10101 call add_referenced_var on globals.
10102 * matrix-reorg.c (transform_access_sites): Likewise.
10103
10104 2012-05-29 Steven Bosscher <steven@gcc.gnu.org>
10105
10106 * alias.c (reg_known_value): Make this a VEC.
10107 (reg_known_equiv_p): Make this an sbitmap.
10108 (reg_known_value_size): Remove.
10109 (get_reg_known_value, set_reg_known_value, get_reg_known_equiv_p,
10110 set_reg_known_equiv_p): Update for reg_known_value and
10111 reg_known_value_size data structure change.
10112 (init_alias_analysis, end_alias_analysis): Likewise.
10113
10114 2012-05-29 Jakub Jelinek <jakub@redhat.com>
10115
10116 PR middle-end/53510
10117 * input.c (read_line): Use XRESIZEVEC instead of XNEWVEC
10118 to avoid leaking memory. No need to handle memory allocation
10119 failure. Double string_len on each reallocation instead of adding 2.
10120 * gcov.c (read_line): Likewise.
10121
10122 2012-05-29 Hans-Peter Nilsson <hp@axis.com>
10123
10124 * config/cris/cris.h (TARGET_HAS_BREAK, TARGET_TRAP_USING_BREAK8):
10125 New macros.
10126 * config/cris/cris.md ("trap"): Define, enabled for
10127 TARGET_TRAP_USING_BREAK8.
10128 * config/cris/cris.opt (mtrap-using-break8): New option.
10129
10130 2012-05-28 Paolo Carlini <paolo.carlini@oracle.com>
10131
10132 PR c++/25137
10133 * doc/invoke.texi: Document -Wmissing-braces not enabled by -Wall
10134 for C++.
10135
10136 2012-05-28 Hans-Peter Nilsson <hp@axis.com>
10137
10138 * doc/md.texi (stack_protect_test): Remove negation of branch to label.
10139 (Standard Names): Fix typos in documentation of atomic patterns.
10140
10141 2012-05-27 Nathan Sidwell <nathan@acm.org>
10142
10143 * tree.c (build_constructor): Propagate TREE_SIDE_EFFECTS.
10144
10145 2012-05-26 Jason Merrill <jason@redhat.com>
10146
10147 PR c++/53220
10148 * c-typeck.c (array_to_pointer_conversion): Give -Wc++-compat warning
10149 about array compound literals.
10150
10151 2012-05-26 Eric Botcazou <ebotcazou@adacore.com>
10152
10153 * cfgcleanup.c (try_optimize_cfg): Do not delete forwarder blocks
10154 if CLEANUP_NO_INSN_DEL.
10155 * cfgrtl.c (unique_locus_on_edge_between_p): New function extracted
10156 from cfg_layout_merge_blocks.
10157 (emit_nop_for_unique_locus_between): New function.
10158 (rtl_merge_blocks): Invoke emit_nop_for_unique_locus_between.
10159 (cfg_layout_merge_blocks): Likewise.
10160
10161 2012-05-26 Dimitrios Apostolou <jimis@gmx.net>
10162 Paolo Bonzini <bonzini@gnu.org>
10163
10164 * df-scan.c (df_def_record_1): Assert a parallel must contain an
10165 EXPR_LIST at this point. Receive the LOC and move its extraction...
10166 (df_defs_record): ... here. Change if-else to a switch statement.
10167 (df_find_hard_reg_defs, df_find_hard_reg_defs_1): New.
10168 (df_get_call_refs): Changed defs_generated from bitmap to HARD_REG_SET
10169 and compute it from df_find_hard_reg_defs(). Record DF_REF_BASE
10170 DEFs in REGNO order. Use HARD_REG_SET instead of bitmap for
10171 regs_invalidated_by_call.
10172 (df_insn_refs_collect): Record DF_REF_REGULAR DEFs after
10173 df_get_call_refs().
10174
10175 2012-05-25 Eric Botcazou <ebotcazou@adacore.com>
10176
10177 PR lto/52178
10178 * tree-inline.c (remap_gimple_op_r): Fix handling of FIELD_DECL.
10179 * tree.c (RETURN_TRUE_IF_VAR): Do not return true for PLACEHOLDER_EXPR.
10180
10181 2012-05-25 Michael Meissner <meissner@linux.vnet.ibm.com>
10182
10183 * config/rs6000/t-linux64: Delete the 32-bit multilib that uses
10184 software floating point emulation. No longer build the multilibs
10185 with -mstrict-align.
10186
10187 2012-05-25 Aldy Hernandez <aldyh@redhat.com>
10188
10189 PR middle-end/53008
10190 * trans-mem.c (ipa_tm_create_version_alias): Output new_node if
10191 accessed indirectly.
10192 (ipa_tm_create_version): Same.
10193
10194 2012-05-25 Uros Bizjak <ubizjak@gmail.com>
10195
10196 PR target/53474
10197 * config/i386/i386.c (ix86_print_operand) <case 'O'>: Print '.' here.
10198 <case 'C', case 'c', case 'F', case 'f'>: Print '.' only for C and c.
10199
10200 2012-05-25 Alexander Ivchenko <alexander.ivchenko@intel.com>
10201
10202 PR target/53435
10203 * config/i386/i386.c (ix86_expand_vec_perm): Use correct op.
10204 (ix86_expand_vec_perm): Use int mode instead of float.
10205 (expand_vec_perm_pshufb): Remove handling of useseless type
10206 conversion.
10207
10208 2012-05-25 Eric Botcazou <ebotcazou@adacore.com>
10209
10210 PR ada/52362
10211 * config.gcc (i[34567]86-*-mingw* | x86_64-*-mingw*): Set gas and
10212 gnu_ld variables to yes.
10213 * configure.ac (HAVE_GNU_LD): Move to after config.gcc inclusion.
10214 (HAVE_GNU_AS): Likewise.
10215 * config.in: Regenerate.
10216 * configure: Likewise.
10217
10218 2012-05-25 Tristan Gingold <gingold@adacore.com>
10219
10220 * config/i386/i386.c (struct ix86_frame): Remove unused frame field.
10221 (ix86_compute_frame_layout): Fix type of stack_alignment_needed
10222 and preferred_alignment.
10223
10224 2012-05-25 Tristan Gingold <gingold@adacore.com>
10225
10226 * common/config/ia64/ia64-common.c (ia64_except_unwind_info): Fix typo.
10227
10228 2012-05-25 Thomas Schwinge <thomas@codesourcery.com>
10229
10230 * fold-const.c (optimize_bit_field_compare): Abort early in the strict
10231 volatile bitfields case.
10232
10233 2012-05-24 Pat Haugen <pthaugen@us.ibm.com>
10234
10235 * config/rs6000/rs6000.c (rs6000_option_override_internal): Change
10236 rs6000_sched_costly_dep default to true_store_to_load_dep_costly.
10237 (adjacent_mem_locations): Move some code to and call...
10238 (get_memref_parts): ...new function.
10239 (mem_locations_overlap): New function.
10240 (rs6000_adjust_priority): Adjust calls to is_load_insn/is_store_insn.
10241 (is_mem_ref): Rename to...
10242 (find_mem_ref): ...this. Return MEM rtx.
10243 (get_store_dest): Remove function.
10244 (is_load_insn1, is_load_insn, is_store_insn1, is_store_insn): Add
10245 new parameter and adjust calls.
10246 (rs6000_is_costly_dependence): Update calls for extra arg. Make sure
10247 mem refs overlap for true_store_to_load_dep_costly.
10248 (rs6000_sched_reorder2): Update calls for extra arg. Adjust args
10249 passed to adjacent_mem_locations.
10250 (is_costly_group): Walk resolved dependency list.
10251 (force_new_group): Emit group ending nop for Power6/Power7.
10252 * config/rs6000/rs6000.md (UNSPEC_GRP_END_NOP): New enum value.
10253 (group_ending_nop): New define_insn.
10254
10255 2012-05-24 Dodji Seketeli <dodji@redhat.com>
10256
10257 Make unwound macro expansion trace less redundant
10258 * tree-diagnostic.c (maybe_unwind_expanded_macro_loc): Don't print
10259 context of macro definition in the trace, when it's redundant.
10260 Update comments.
10261
10262 2012-05-24 Richard Guenther <rguenther@suse.de>
10263
10264 PR middle-end/53460
10265 * tree-profile.c (tree_profiling): Cleanup the CFG if
10266 execute_fixup_cfg requests it.
10267
10268 2012-05-24 Richard Guenther <rguenther@suse.de>
10269
10270 * tree-flow.h (create_var_ann): Remove.
10271 * tree-dfa.c (create_var_ann): Remove and inline into its
10272 single caller ...
10273 (add_referenced_var_1): ... here.
10274 * varpool.c (add_new_static_var): Do not call add_referenced_var
10275 for global vars.
10276 * gimple-fold.c (canonicalize_constructor_val): Likewise.
10277 * tree-switch-conversion.c (build_one_array): Likewise.
10278 * tree-profile.c (gimple_gen_ic_profiler): Likewise.
10279 * tree-flow-inline.h (gimple_referenced_vars): Guard against
10280 NULL fn argument.
10281 * tree-inline.c (remap_gimple_op_r): Likewise. Check
10282 gimple_referenced_vars instead of gimple_in_ssa_p.
10283 (copy_tree_body_r): Likewise.
10284 (setup_one_parameter): Likewise.
10285 (declare_return_variable): Likewise.
10286 (tree_function_versioning): Likewise.
10287
10288 2012-05-24 Jakub Jelinek <jakub@redhat.com>
10289
10290 PR tree-optimization/53465
10291 * tree-vrp.c (extract_range_from_cond_expr): First copy_value_range
10292 vr0 into *vr, then vrp_meet that.
10293 (vrp_meet): If one vr type is VR_UNDEFINED, ensure the result doesn't
10294 have any equivalences.
10295 (vrp_visit_phi_node): Call copy_value_range instead of vrp_meet the
10296 first time.
10297
10298 2012-05-24 Jim MacArthur <jim.macarthur@arm.com>
10299
10300 * recog.c (reg_fits_class_p): Check both regno and regno + offset are
10301 hard registers.
10302 * regs.h (in_hard_reg_set_p): Assert that regno is a hard register and
10303 check end_regno - 1 is a hard register.
10304
10305 2012-05-24 Richard Guenther <rguenther@suse.de>
10306
10307 * varpool.c (add_new_static_var): Remove call to create_var_ann.
10308 * tree-ssa-operands.c (create_vop_var): Likewise.
10309
10310 2012-05-24 Richard Guenther <rguenther@suse.de>
10311
10312 PR bootstrap/53466
10313 * tree-ssa-live.c (remove_unused_scope_block_p): Properly
10314 handle globals.
10315 (remove_unused_locals): Pass global_unused_vars to
10316 remove_unused_scope_block_p. Restore code walking all
10317 referenced vars and pruning them.
10318
10319 2012-05-23 Jan Hubicka <jh@suse.cz>
10320
10321 * tree.h (alias_diag_flags): Remove.
10322 (alias_pair): Remove emitted_diags.
10323 (finish_aliases_1, finish_aliases_2, remove_unreachable_alias_pairs,
10324 symbol_alias_set_t, symbol_alias_set_destroy,
10325 symbol_alias_set_contains, propagate_aliases_backward): Remove.
10326 * toplev.c (compile_file): Do not call finish_aliases_2
10327 * cgraphunit.c (cgraph_process_new_functions): Do not call
10328 finish_aliases_1.
10329 (handle_alias_pairs): Output diagnostics about aliases to externals.
10330 (assemble_thunks_and_aliases): Use do_assemble_alias.
10331 (output_weakrefs): Likewise.
10332 (finalize_compilation_unit): Do not call finish_aliases_1.
10333 * ipa.c (symtab_remove_unreachable_nodes): De not call
10334 remove_unreachable_alias_pairs.
10335 * varasm.c (do_assemble_alias): Export.
10336 (symbol_alias_set_create, symbol_alias_set_destroy,
10337 symbol_alias_set_contains, symbol_alias_set_insert,
10338 propagate_aliases_forward, propagate_aliases_backward,
10339 propagate_aliases_backward, trivially_visible_alias,
10340 trivially_defined_alias, remove_unreachable_alias_pairs,
10341 finish_aliases_1, finish_aliases_2, assemble_alias): Remove.
10342 * output.h (do_assemble_alias): Declare.
10343 * varpool.c (varpool_remove_unreferenced_decls): Do not call
10344 finish_aliases_1.
10345
10346 2012-05-23 Martin Jambor <mjambor@suse.cz>
10347
10348 * ipa-inline-analysis.c (inline_merge_summary): Free operand_map.
10349
10350 2012-05-23 Eric Botcazou <ebotcazou@adacore.com>
10351
10352 * gimple.c (gimple_types_compatible_p_1) <ARRAY_TYPE>: Remove bogus
10353 size handling.
10354 (gimple_canonical_types_compatible_p) <ARRAY_TYPE>: Likewise.
10355 (iterative_hash_gimple_type): Adjust comment.
10356 (iterative_hash_canonical_type): Likewise. Hash the bounds of the
10357 domain for an array type instead of the domain type itself.
10358
10359 2012-05-23 Richard Guenther <rguenther@suse.de>
10360
10361 PR tree-optimization/53438
10362 * tree-sra.c (analyze_access_subtree): Correct bitfield exclusion.
10363
10364 2012-05-23 Georg-Johann Lay <avr@gjlay.de>
10365
10366 PR target/53448
10367 * config/avr/avr.h (ASM_OUTPUT_ALIGN): Don't inhibit .p2align 1.
10368 * config/avr/elf.h (ASM_OUTPUT_BEFORE_CASE_LABEL): Use
10369 ASM_OUTPUT_ALIGN.
10370
10371 2012-05-23 Richard Guenther <rguenther@suse.de>
10372
10373 * tree-dfa.c (add_referenced_var_1): Do not add global vars.
10374 * tree-ssa-live.c (mark_all_vars_used_1): Handle global vars
10375 via the global_unused_vars bitmap.
10376 (remove_unused_locals): Handle global vars in local-decls via
10377 a global_unused_vars bitmap instead of the used flag in the
10378 var annotation. Simplify global variable handling and removal.
10379
10380 2012-05-22 Jan Hubicka <jh@suse.cz>
10381
10382 PR middle-end/53426
10383 * tree-ssa-structalias.c (create_variable_info_for): Skip constructors
10384 from other partitions.
10385
10386 2012-05-22 Jan Hubicka <jh@suse.cz>
10387
10388 PR middle-end/53161
10389 * symtab.c (symtab_register_node): Fix ordering issue.
10390
10391 2012-05-22 Steven Drake <sbd@NetBSD.org>
10392
10393 * gcc.c (do_spec_1): Add %M spec token to output multilib_os_dir.
10394
10395 2012-05-22 David Edelsohn <dje.gcc@gmail.com>
10396
10397 * config/rs6000/rs6000.c (rs6000_aix_asm_output_dwarf_table_ref):
10398 Use strip_name_encoding target hook.
10399
10400 2012-05-22 Richard Guenther <rguenther@suse.de>
10401
10402 * tree.h (VAR_DECL_IS_VIRTUAL_OPERAND): New.
10403 (init_function_for_compilation): Remove.
10404 * tree-dfa.c (find_vars_r): Take struct function argument.
10405 (find_referenced_vars_in): Adjust.
10406 * tree-ssa-operands.c (clobber_stats): Remove.
10407 (create_vop_var): Take struct function argument. Mark
10408 virtual operand with VAR_DECL_IS_VIRTUAL_OPERAND.
10409 (init_ssa_operands): Take struct function argument.
10410 (fini_ssa_operands): Do not dump dead stats.
10411 * tree-ssa-operands.h (init_ssa_operands): Take struct function
10412 argument.
10413 * cgraphunit.c (init_lowered_empty_function): Adjust.
10414 * lto-streamer-in.c (input_cfg): Likewise.
10415 * tree-inline.c (initialize_cfun): Likewise.
10416 * tree-into-ssa.c (rewrite_into_ssa): Likewise.
10417 * omp-low.c (expand_omp_taskreg): Likewise. Avoid switching cfun.
10418 * gimple.c (is_gimple_reg): Optimize the SSA_NAME case,
10419 virtual operands are not registers.
10420
10421 2012-05-22 Richard Guenther <rguenther@suse.de>
10422
10423 * tree-cfg.c (verify_gimple_assign_unary): Fix typo in previous commit.
10424
10425 2012-05-22 Richard Guenther <rguenther@suse.de>
10426
10427 PR middle-end/53437
10428 * tree-inline.c (setup_one_parameter): Create a dummy init
10429 statement for unused parameters when not optimizing.
10430
10431 2012-05-22 Richard Guenther <rguenther@suse.de>
10432
10433 * tree-flow.h (add_referenced_var_1): Declare.
10434 (add_referenced_var): Define.
10435 * tree-dfa.c (referenced_var_check_and_insert): Avoid one hash lookup.
10436 (add_referenced_var): Rename to ...
10437 (add_referenced_var_1): ... this. Take struct function argument.
10438
10439 2012-05-22 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
10440
10441 PR target/53334
10442 * config/arm/arm-protos.h (arm_validize_comparison): Declare.
10443 * config/arm/arm.c (arm_validize_comparison): Define.
10444 * config/arm/arm.md ("cbranchsi4"): Cleanup expansion and use
10445 arm_validize_comparison.
10446 ("cbranchdi4"): Likewise.
10447 ("cstoredi4"): Likewise.
10448 ("movsicc"): Likewise.
10449 ("movsfcc"): Likewise.
10450 ("movdfcc"): Likewise.
10451
10452 2012-05-22 Dimitrios Apostolou <jimis@gmx.net>
10453
10454 * df-scan.c (df_scan_alloc): Round up allocation pools size, reduce
10455 the mw_reg_pool size.
10456
10457 2012-05-22 Paolo Bonzini <bonzini@gnu.org>
10458
10459 PR tree-optimization/53336
10460 * tree-cfg.c (verify_gimple_assign_unary): Allow conversion from
10461 non-integer integral types to offset type and vice versa.
10462
10463 2012-05-22 Alan Modra <amodra@gmail.com>
10464
10465 * config/rs6000/aix.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Delete.
10466 * config/rs6000/darwin.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Delete.
10467 * config/rs6000/sysv4.h (FP_SAVE_INLINE, GP_SAVE_INLINE,
10468 V_SAVE_INLINE): Delete.
10469 * config/rs6000/rs6000.c (V_SAVE_INLINE): Delete.
10470 (rs6000_savres_strategy): Reimplement GP/FP/V_SAVE_INLINE logic.
10471 For ELF targets, use out-of-line restores for -Os and any number
10472 of regs if the restore exits, and out-of-line gp save for two or
10473 more regs. Use save_reg_p to test for holes in reg restore set.
10474 Replace "#if" with "if".
10475
10476 2012-05-22 Alan Modra <amodra@gmail.com>
10477
10478 * config/rs6000/rs6000.c (save_reg_p): New function.
10479 (first_reg_to_save, first_fp_reg_to_save): Use it here.
10480 (first_altivec_reg_to_save, restore_saved_cr): Likewise.
10481 (emit_frame_save): Use gen_frame_store.
10482 (gen_frame_mem_offset): Correct SPE condition requiring reg+reg.
10483 (rs6000_emit_prologue): Use save_reg_p. Use gen_frame_store for
10484 vrsave and toc.
10485 (rs6000_emit_epilogue): Use save_reg_p. Use gen_frame_load for
10486 vrsave, toc, gp and fp restores.
10487
10488 2012-05-22 Alan Modra <amodra@gmail.com>
10489
10490 * config/rs6000/rs6000.c: Delete unnecessary forward declarations.
10491 Move those with ATTRIBUTE_UNUSED to immediately before definitions.
10492 Move function pointer variables after forward declarations.
10493 (rs6000_builtin_support_vector_misalignment): Make static.
10494 (rs6000_legitimate_address_p, rs6000_gimplify_va_arg): Likewise.
10495 (rs6000_function_value, rs6000_can_eliminate): Likewise.
10496
10497 2012-05-21 Bernd Schmidt <bernds@codesourcery.com>
10498
10499 PR rtl-optimization/53373
10500 * caller-save.c (save_call_clobbered_regs): Look into a possible
10501 PARALLEL manually rather than using single_set on a call insn.
10502
10503 2012-05-21 Jakub Jelinek <jakub@redhat.com>
10504
10505 PR tree-optimization/53436
10506 * omp-low.c (omp_build_component_ref): New function.
10507 (build_receiver_ref, build_sender_ref, create_task_copyfn): Use it.
10508
10509 2012-05-21 Uros Bizjak <ubizjak@gmail.com>
10510
10511 * config/i386/i386.c (put_condition_code): Change "reverse" and "fp"
10512 arguments to bool.
10513 (ix86_print_operand) <case 'O'>: Look at mode size of the operand.
10514 Do not print '.' here. Output operand lossage error for unhandled
10515 sizes. Move.
10516 <case '*'>: Move.
10517 <case '&'>: Ditto.
10518 <case 'Y'>: Ditto.
10519 <case 'z'>: Hardcode "code" argument into error strings.
10520 <case 'Z'>: Ditto.
10521 <case 'D'>: Merge AVX and non-AVX codes.
10522 <case 'C', case 'c', case 'F', case 'f'>: Merge. Fix error string.
10523 Update call to put_condition_code.
10524
10525 2012-05-21 Andreas Schwab <schwab@linux-m68k.org>
10526
10527 * config/m68k/m68k.md (*clzsi2_cf): Renamed from clzsi2. Call
10528 CC_STATUS_INIT.
10529 (clzsi2): New expander.
10530 (*clzsi2_68k): New insn.
10531 * config/m68k/m68k.h: Update comment about CLZ_DEFINED_VALUE_AT_ZERO.
10532
10533 2012-05-21 Aldy Hernandez <aldyh@redhat.com>
10534
10535 * gimple.h (gimple_set_in_transaction): Remove.
10536 (gimple_in_transaction): Look in BB instead.
10537 (gimple_statement_base): Remove in_transaction field.
10538 * basic-block.h (enum bb_flags): Add BB_IN_TRANSACTION.
10539 * trans-mem.c (compute_transaction_bits): Place transaction bit
10540 information into basic blocks.
10541
10542 2012-05-21 Andreas Schwab <schwab@linux-m68k.org>
10543
10544 * expr.c (get_def_for_expr_class): Define only if
10545 HAVE_conditional_move.
10546 (convert_tree_comp_to_rtx): Likewise.
10547
10548 2012-05-21 Uros Bizjak <ubizjak@gmail.com>
10549
10550 PR target/53399
10551 * config/i386/i386.md (ffs<mode>2): Generate CCCmode compare
10552 for TARGET_BMI.
10553 (ffssi2_no_cmove): Ditto.
10554 (*ffs<mode>_1): Remove insn pattern.
10555 (*tzcnt<mode>_1): New insn pattern.
10556 (*bsf<mode>1): Ditto.
10557
10558 2012-05-21 Richard Guenther <rguenther@suse.de>
10559
10560 * tree-dfa.c (add_referenced_var): Do not walk DECL_INITIAL for
10561 more referenced vars.
10562 * tree-ssa-live.c (mark_all_vars_used_1): Only set the used
10563 flag on variables that have a var-annotation.
10564
10565 2012-05-21 Joseph Myers <joseph@codesourcery.com>
10566
10567 PR c/53418
10568 * c-typeck.c (build_conditional_expr): Remove C_MAYBE_CONST_EXPR
10569 from folded operands before wrapping another around the
10570 conditional expression.
10571
10572 2012-05-21 Jakub Jelinek <jakub@redhat.com>
10573
10574 PR tree-optimization/53366
10575 * tree-vect-slp.c (vect_supported_load_permutation_p): Don't shortcut
10576 tests if complex_numbers == 2, but there are non-complex number loads
10577 too.
10578
10579 PR tree-optimization/53409
10580 * tree-vect-loop.c (vect_analyze_loop_operations): Don't check
10581 vinfo_for_stmt (op_def_stmt) if op_def_stmt isn't inside loop.
10582
10583 PR tree-optimization/53410
10584 * fold-const.c (fold_binary_loc): Use build_zero_cst (type)
10585 instead of build_int_cst (type, 0) where vector types might be
10586 involved. Instead of build_int_cst (type, 1) convert the original
10587 integer_onep argument to the desired type.
10588
10589 2012-05-21 Michael Matz <matz@suse.de>
10590
10591 * genattrtab.c (attr_rtx_cost): Move earlier, start with cost being 1.
10592 (simplify_test_exp): Handle one more case of distributive law,
10593 decrease cost threshold.
10594 (tests_attr_p, get_attr_order): New functions.
10595 (optimize_attrs): Use topological order, inline only cheap values.
10596 (write_attr_set): Reset our_known_true after some time.
10597
10598 2012-05-21 H.J. Lu <hongjiu.lu@intel.com>
10599
10600 PR target/53425
10601 * config/i386/i386.c (type_natural_mode): Warn passing SSE
10602 vector argument without SSE enabled changes the ABI.
10603
10604 2012-05-21 Richard Guenther <rguenther@suse.de>
10605
10606 PR tree-optimization/53408
10607 * tree-vect-loop.c (vectorizable_induction): Properly check
10608 the restriction that we cannot handle induction results from
10609 the inner loop outside of the outer loop.
10610
10611 2012-05-21 H.J. Lu <hongjiu.lu@intel.com>
10612
10613 PR target/53416
10614 * config/i386/i386.md (UNSPEC_RDRAND): Renamed to ...
10615 (UNSPECV_RDRAND): This.
10616 (rdrand<mode>_1): Updated.
10617
10618 2012-05-21 Richard Guenther <rguenther@suse.de>
10619
10620 * tree-loop-distribution.c (can_generate_builtin): Reject
10621 volatile stmts.
10622
10623 2012-05-21 Chung-Lin Tang <cltang@codesourcery.com>
10624
10625 * Makefile.in (options.c): Add options.h to included header
10626 files, before tm.h.
10627
10628 2012-05-21 Razya Ladelsky <razya@il.ibm.com>
10629
10630 * tree-parloops.c : Add myself to contributors, update
10631 TODO list, add link to wiki.
10632
10633 2012-05-21 Alan Modra <amodra@gmail.com>
10634
10635 * config/rs6000/predicates.md (input_operand): Don't match
10636 constant pool addresses. Remove label_ref, high and plus from
10637 match_code list. Remove redundant CONSTANT_P test.
10638 (splat_input_operand): Similarly update match_code list.
10639 (small_toc_ref): New predicate.
10640 * config/rs6000/rs6000-protos.h (toc_relative_expr_p): Update prototype.
10641 * config/rs6000/rs6000.c (tocrel_base, tocrel_offset): Make const.
10642 (legitimate_constant_pool_address_p): Move TARGET_TOC test and
10643 register checks to..
10644 (toc_relative_expr_p): ..here. Add "strict" param. Match new rtl
10645 generated by create_TOC_reference.
10646 (rs6000_legitimize_address): Update cerate_TOC_reference call.
10647 (rs6000_delegitimize_address): Handle new rtl for toc refs.
10648 (rs6000_cannot_force_const_mem, rs6000_find_base_term): Likewise.
10649 (use_toc_relative_ref): New function, split out from..
10650 (rs6000_emit_move): ..here. Remove redundant tests. Update
10651 create_TOC_reference calls.
10652 (rs6000_legitimize_reload_address): Formatting. Handle splitting
10653 of medium/large model toc addresses. Use use_toc_relative_ref.
10654 (print_operand): Formatting, style. Adjust for toc changes.
10655 (print_operand_address): Likewise.
10656 (rs6000_output_addr_const_extra): Likewise.
10657 (create_TOC_reference): Put TOC_REGISTER in UNSPEC_TOCREL rather
10658 than a PLUS. Use this formulation for both high and low part
10659 of -mcmodel=medium/large toc reference too. Before reload,
10660 always use the small model formulation.
10661 * config/rs6000/rs6000.md (tls_gd, tls_gd_high): Similarly avoid
10662 a PLUS in high part of addresses here.
10663 (tls_ld, tls_ld_high, tls_got_dtprel, tls_got_dtprel_high): Likewise.
10664 (tls_got_tprel, tls_got_tprel_high, largetoc_high): Likewise.
10665 (largetoc_high, largetoc_low): Move earlier. Cope when no
10666 base reg available.
10667 (largetoc_high_plus): New insn.
10668 (movsi_internal1, movsi_internal1_single, movsf_softfloat,
10669 movdi_mfpgpr, movdi_internal64): Don't handle 'R' constraint here..
10670 (tocref): ..instead do so here, new insn and split.
10671
10672 2012-05-20 H.J. Lu <hongjiu.lu@intel.com>
10673
10674 * config/i386/driver-i386.c (host_detect_local_cpu): Support
10675 RDRND, F16C and FSGSBASE.
10676
10677 2012-05-20 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
10678
10679 PR rtl-optimzation/53373
10680 * config/pa/pa.md (call_symref_pic): Don't expose PIC register save in
10681 call pattern. Update split patterns.
10682 (call_symref_64bit, call_reg_pic, call_reg_64bit, call_val_symref_pic,
10683 call_val_symref_64bit, call_val_reg_pic, call_val_reg_64bit): Likewise.
10684
10685 2012-05-20 Razya Ladelsky <razya@il.ibm.com>
10686
10687 * tree-parloops.c (gen_parallel_loop): Change many_iterations_cond
10688 for outer loops.
10689
10690 2012-05-18 Jan Hubicka <jh@suse.cz>
10691
10692 * cgraphunit.c (handle_alias_pairs): Declare; free alias_pairs
10693 (cgraph_process_new_functions): Process also aliases.
10694 * lto-streamer-out.c (struct sets): Remove.
10695 (trivally_defined_alias): Remove.
10696 (output_alias_pair_p): Remove.
10697 (output_unreferenced_globals): Remove.
10698 (produce_symtab); Do not handle alias pairs.
10699 (produce_asm_for_decls): Likewise.
10700 * lto-streamer-in.c (input_alias_pairs): Remove.
10701 (lto_read_body): Do not input alias pairs.
10702 (lto_input_constructors_and_inits): Remove.
10703
10704 2012-05-18 Jan Hubicka <jh@suse.cz>
10705
10706 * cgraphunit.c (handle_alias_pairs): Cleanup; handle all types of
10707 aliases.
10708
10709 2012-05-18 Jan Hubicka <jh@suse.cz>
10710
10711 * cgraphbuild.c (record_reference): Update.
10712 * lto-cgraph.c (lto_output_varpool_node): External vars
10713 are not in other partition even if they are not output
10714 in current partition.
10715 * gimple-fold.c (can_refer_decl_in_current_unit_p): Take FROM_DECL
10716 argument; fix.
10717 (canonicalize_constructor_val): Take FROM_DECL argument.
10718 (fold_ctor_reference, fold_string_cst_ctor_reference,
10719 fold_array_ctor_reference, fold_nonarray_ctor_reference,
10720 fold_ctor_reference): Likewise.
10721 (fold_const_aggregate_ref_1, gimple_get_virt_method_for_binfo): Update.
10722 * gimple.h (gimple_fold_builtin): Likewise.
10723
10724 2012-05-18 Olivier Hainque <hainque@adacore.com>
10725
10726 * Makefile.in (FLAGS_TO_PASS): Pass $(libexecsubdir) instead of
10727 $(libsubdir) as libexecsubdir.
10728
10729 2012-05-18 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
10730
10731 * config/rs6000/rs6000.c (print_operand): Revise code that unsafely
10732 relied on signed overflow behavior.
10733
10734 2012-05-18 Richard Guenther <rguenther@suse.de>
10735
10736 PR tree-optimization/53346
10737 * tree-loop-distribution.c (ldist_gen): Make sure to apply
10738 builtin transform even when only a single partition with
10739 all reads/writes exists.
10740
10741 2012-05-18 Richard Guenther <rguenther@suse.de>
10742
10743 PR tree-optimization/53390
10744 * tree-vect-data-refs.c (vect_compute_data_ref_alignment): Ignore
10745 strided loads.
10746
10747 2012-05-18 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
10748
10749 * tree-ssa-reassoc.c (bip_map): Remove decl.
10750 (completely_remove_stmt): Remove function.
10751 (remove_def_if_absorbed_call): Remove function.
10752 (remove_visited_stmt_chain): Remove __builtin_powi handling.
10753 (possibly_move_powi): Remove function.
10754 (rewrite_expr_tree): Remove calls to possibly_move_powi.
10755 (rewrite_expr_tree_parallel): Likewise.
10756 (attempt_builtin_powi): Build multiplies explicitly rather than
10757 relying on the ops vector and rank system.
10758 (transform_stmt_to_copy): New function.
10759 (transform_stmt_to_multiply): Likewise.
10760 (reassociate_bb): Handle leftover operations after __builtin_powi
10761 optimization; build a final multiply if necessary.
10762
10763 2012-05-18 Jan Hubicka <jh@suse.cz>
10764
10765 * cgraphunit.c (varpool_finalize_decl): Allow external decls.
10766 (mark_functions_to_output): Fix sanity check.
10767 * ipa.c (function_and_variable_visibility): Remove TREE_STATIC check.
10768
10769 2012-05-18 Richard Guenther <rguenther@suse.de>
10770
10771 * tree-flow.h (mark_symbols_for_renaming): Remove.
10772 * tree-dfa.c (mark_symbols_for_renaming): Likewise.
10773 * tree-inline.c (copy_edges_for_bb): Do not mark symbols for renaming.
10774 (copy_debug_stmt): Likewise.
10775 (expand_call_inline): Likewise.
10776 (declare_return_variable): Mark the return variable for renaming
10777 if necessary.
10778
10779 2012-05-18 Andrew Stubbs <ams@codesourcery.com>
10780
10781 * config/arm/arm-protos.h (arm_emit_coreregs_64bit_shift): New
10782 prototype.
10783 * config/arm/arm.c (arm_emit_coreregs_64bit_shift): New function.
10784 * config/arm/arm.md (ashldi3): Use arm_emit_coreregs_64bit_shift.
10785 (ashrdi3,lshrdi3): Likewise.
10786 (arm_cond_branch): Remove '*' to enable gen_arm_cond_branch.
10787
10788 2012-05-18 Meador Inge <meadori@codesourcery.com>
10789
10790 PR rtl-optimization/53352
10791 * cse.c (equiv_constant): Ignore paradoxical subregs.
10792
10793 2012-05-17 Steven Bosscher <steven@gcc.gnu.org>
10794
10795 PR rtl-optimization/53125
10796 * regstat.c (regstat_bb_compute_ri): Take new local_live_last_luid
10797 argument. Simplify calculation of REG_LIVE_LENGTH for regnos that
10798 die in the basic block. Correctly top off REG_FREQ and
10799 REG_FREQ_CALLS_CROSSED.
10800 Remove do_not_gen.
10801 (regstat_compute_ri): Allocate and free local_live_last_luid.
10802 Remove do_not_gen.
10803 (regstat_bb_compute_calls_crossed): Correctly top off
10804 REG_FREQ_CALLS_CROSSED.
10805
10806 2012-05-17 Jan Hubicka <jh@suse.cz>
10807
10808 * lto-symtab.c (lto_symtab_resolve_symbols): Preffer decl with
10809 constructor over decl without.
10810 * cgraph.c (cgraph_remove_node): Clear also body of unanalyzed nodes.
10811 * cgraph.h (varpool_can_remove_if_no_refs): Handle external correctly.
10812 * cgraphunit.c (process_function_and_variable_attributes): Finalize
10813 extrnal decls.
10814 (mark_functions_to_output): Also accept bodies for functions with
10815 clones.
10816 (output_in_order): Skip external vars.
10817 * lto-cgraph.c (lto_output_node): External functions are never in other
10818 partition.
10819 (lto_output_varpool_node): Likewise.
10820 * lto-streamer-out.c (lto_write_tree): Always use error_mark_nodes for
10821 forgotten initializers.
10822 * ipa.c (process_references): Handle external vars.
10823 (symtab_remove_unreachable_nodes): Update to handle external vars.
10824 (varpool_externally_visible_p): External vars are externally visible.
10825 * gimple-fold.c (can_refer_decl_in_current_unit_p): Update.
10826 * varpool.c (varpool_remove_node): Remove constructor.
10827 (decide_is_variable_needed): Handle externals.
10828 (varpool_remove_unreferenced_decls): Likewise.
10829
10830 2012-05-17 Manuel López-Ibáñez <manu@gcc.gnu.org>
10831
10832 * opts.c (common_handle_option): -pedantic-errors enables -Wpedantic.
10833 (enable_warning_as_error): Do not special case Wuninitialized.
10834 * optc-gen.awk: Add sanity checks.
10835
10836 2012-05-17 Jan Hubicka <jh@suse.cz>
10837
10838 * ipa-reference.c (is_proper_for_analysis): Do not check flags
10839 that might change as result of global optimization.
10840 (analyze_function): Do not check analyzed and externally_visible
10841 flags; be happy about address dereferences.
10842 (propagate): Prune all_module_statics so it really contains just
10843 statics; prune all the local summaries.
10844 (ipa_reference_write_optimization_summary): Simplify.
10845
10846 2012-05-17 Kwok Cheung Yeung <kcy@codesourcery.com>
10847
10848 * config/m68k/m68k-devices.def: Add 51ag, 51je, 51jf, 51jg, 51mm, 51qm.
10849 * config/m68k/m68k-tables.opt: Regenerated.
10850 * doc/invoke.texi (M680x0 Options): Document.
10851
10852 2012-05-16 Dave Boutcher <daveboutcher@gmail.com>
10853 Patrick Marlier <patrick.marlier@gmail.com>
10854
10855 * trans-mem.c (ipa_tm_transform_clone): Transform functions with
10856 indirect calls.
10857
10858 2012-05-16 H.J. Lu <hongjiu.lu@intel.com>
10859
10860 * configure: Regenerated.
10861
10862 2012-05-16 Andrew Pinski <apinski@cavium.com>
10863
10864 * gimple-fold.c (get_maxval_strlen): Move COND_EXPR handling under
10865 GIMPLE_ASSIGN.
10866
10867 2012-05-16 David S. Miller <davem@davemloft.net>
10868
10869 * jump.c (delete_related_insns): If we remove a CALL, make sure
10870 we delete it's NOTE_INSN_CALL_ARG_LOCATION note too.
10871
10872 2012-05-16 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
10873
10874 PR tree-optimization/53217
10875 * tree-ssa-reassoc.c (bip_map): New static variable.
10876 (possibly_move_powi): Move feeding multiplies with __builtin_powi call.
10877 (attempt_builtin_powi): Save feeding multiplies on a stack.
10878 (reassociate_bb): Create and destroy bip_map.
10879
10880 2012-05-16 Olivier Hainque <hainque@adacore.com>
10881
10882 * Makefile.in (install-no-fixedincludes): New target, former toplevel
10883 gcc-no-fixedincludes. Stash "include-fixed" in addition to "include".
10884 Add comments and improve stamp preservation across the whole sequence.
10885 (stmp-int-hdrs): Use move-if-change + cp -p to setup fix_dir/limits.h.
10886
10887 2012-05-16 Richard Guenther <rguenther@suse.de>
10888
10889 * tree-inline.c (insert_init_stmt): Do not call
10890 mark_symbols_for_renaming.
10891 (setup_one_parameter): Avoid initializing unused parameters.
10892 (declare_return_variable): Properly handle DECL_BY_REFERENCE
10893 return vars in SSA form.
10894
10895 2012-05-16 Richard Guenther <rguenther@suse.de>
10896
10897 * tree-flow.h (get_virtual_var): Remove.
10898 * tree-dfa.c (get_virtual_var): Likewise.
10899
10900 2012-05-16 Richard Guenther <rguenther@suse.de>
10901
10902 * tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard1):
10903 Remove set-only bitmap of new names.
10904 (slpeel_tree_peel_loop_to_edge): Likewise. Do not set
10905 CFG hooks.
10906 * tree-flow.h (ssa_names_to_replace): Remove.
10907 * tree-into-ssa.c (ssa_names_to_replace): Likewise.
10908
10909 2012-05-16 Richard Guenther <rguenther@suse.de>
10910
10911 PR tree-optimization/53364
10912 * tree-ssa-alias.c (indirect_ref_may_alias_decl_p): Properly
10913 detect a view-conversion of the decl.
10914
10915 2012-05-16 Dodji Seketeli <dodji@redhat.com>
10916
10917 PR preprocessor/7263
10918 * c-tree.h (enum c_declspec_word): Declare new enum.
10919 (struct c_declspecs::locations): New member.
10920 (declspecs_add_qual, declspecs_add_scspec)
10921 (declspecs_add_addrspace, declspecs_add_alignas): Take a new
10922 location parameter.
10923 * c-decl.c (build_null_declspecs): Initialize the new struct
10924 c_declspecs::locations member.
10925 (declspecs_add_addrspace): Take a location parameter for the
10926 address space. Store it onto declaration specifiers.
10927 (declspecs_add_qual): Likewise, take a location parameter for the
10928 qualifier.
10929 (declspecs_add_type): Likewise, take a location parameter for the
10930 type specifier.
10931 (declspecs_add_scspec): Likewise, take a location parameter for
10932 the storage class specifier.
10933 (declspecs_add_attrs): Likewise, take a location parameter for the
10934 first attribute.
10935 (declspecs_add_alignas): Likewise, take a location parameter for
10936 the alignas token.
10937 (finish_declspecs): For diagnostics, use the location of the
10938 relevant declspec, instead of the global input_location.
10939 * c-parser.c (c_parser_parameter_declaration): Pass the precise
10940 virtual location of the declspec to the declspecs-setters.
10941 (c_parser_declspecs): Likewise. Avoid calling c_parser_peek_token
10942 repeatedly.
10943
10944 2012-05-16 Igor Zamyatin <igor.zamyatin@intel.com>
10945
10946 * configure.ac: Stack protector enabling for Android targets.
10947 * configure: Regenerate.
10948
10949 2012-05-16 Richard Sandiford <r.sandiford@uk.ibm.com>
10950
10951 * ira.c (pseudo_move_insn): Delete.
10952 (find_moveable_pseudos): Don't set it.
10953 (move_unallocated_pseudos): Use DF_REG_DEF_CHAIN to find
10954 the definitions of the original pseudo. Delete all of them.
10955
10956 2012-05-16 Olivier Hainque <hainque@adacore.com>
10957
10958 * config/rs6000/rs6000-opts.h (enum processor_type): Add
10959 PROCESSOR_PPC8548.
10960 * config/rs6000/rs6000-cpus.def: Reference it for cpu="8548".
10961 * config/rs6000/rs6000.md (cpu attribute definition): Add ppc8548.
10962 * config/rs6000/8540.md: indicate that the units/patterns apply to
10963 ppc8548 as well.
10964
10965 * config/rs6000/rs6000.c (rs6000_option_override_internal): Rename
10966 default_cpu into implicit_cpu, conveying what --with-cpu was passed at
10967 configure time. Treat implicit_cpu as have_CPU. Pick defaults for SPE
10968 related flags, check that what is queried is supported by the selected
10969 configuration. Rework the single/double_float and MASK_STRING resets to
10970 hit for all the E500 cores (854x + E500MC variants). Select the ppc8540
10971 costs for PROCESSOR_PPC8548 as well.
10972 (rs6000_issue_rate): case CPU_PPC8548 together with CPU_PPC8540.
10973 (rs6000_use_sched_lookahead): Likewise, rewriting function as a case
10974 statement instead of a sequence of ifs.
10975
10976 * config/rs6000/rs6000.h (TARGET_E500): Remove.
10977 (TARGET_NO_LWSYNC): Adjust accordingly.
10978 * config/rs6000/e500.h (TARGET_E500): Remove.
10979 (CHECK_E500_OPTIONS): Adjust accordingly.
10980 * config/rs6000/eabispe.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Remove.
10981 (TARGET_DEFAULT): Reformat definition to match the one in linuxspe.h.
10982 * config/rs6000/linuxspe.h: Likewise.
10983 * config/rs6000/vxworks.h: Remove bogus TARGET_E500 overrides and
10984 superfluous comments.
10985 * config/rs6000/e500-double.h: Remove.
10986
10987 * config.gcc (pick a default with_cpu): For powerpc*-*-*spe*,
10988 default to with_cpu=8548 if --enable-e500-double, and to 8540
10989 otherwise.
10990 (set misc flags section): For powerpc*|rs6000*, remove inclusion
10991 of e500-double.h for --enable-e500-double.
10992
10993 2012-05-16 Olivier Hainque <hainque@adacore.com>
10994
10995 * Makefile.in (s-header-vars): Resort to -n instead of trailing
10996 -e d in sed invocation.
10997
10998 2012-05-16 Hans-Peter Nilsson <hp@axis.com>
10999
11000 * doc/tm.texi.in (Type Layout) <SIZE_TYPE>: Update reference to
11001 source-code.
11002 * doc/tm.texi: Regenerate.
11003
11004 2012-05-15 Paolo Carlini <paolo.carlini@oracle.com>
11005
11006 * tree.h (EXPR_LOCATION): Use CAN_HAVE_LOCATION_P.
11007
11008 2012-05-15 Jakub Jelinek <jakub@redhat.com>
11009
11010 PR target/53358
11011 * config/i386/i386.md (*addqi_2 peephole with QImode addition): Check
11012 that operands[2] is either immediate, or q_regs_operand.
11013
11014 2012-05-15 Richard Guenther <rguenther@suse.de>
11015
11016 * cgraphunit.c (thunk_adjust): Use make_rename_temp.
11017 (assemble_thunk): Likewise. Manually rename and register
11018 function arguments.
11019
11020 2012-05-15 Richard Guenther <rguenther@suse.de>
11021
11022 PR tree-optimization/53355
11023 * tree-vrp.c (extract_range_from_binary_expr_1): Handle LSHIFT_EXPRs
11024 by constants.
11025
11026 2012-05-15 Tristan Gingold <gingold@adacore.com>
11027
11028 * tree-ssa-strlen.c (get_string_length): Convert lhs if needed.
11029
11030 2012-05-15 Richard Guenther <rguenther@suse.de>
11031
11032 * gimple.c (gimple_set_modified): Move ...
11033 * gimple.h (gimple_set_modified): ... here.
11034
11035 2012-05-15 Tristan Gingold <gingold@adacore.com>
11036
11037 * ira-color.c (move_spill_restore): Add a guard.
11038
11039 2012-05-15 Tristan Gingold <gingold@adacore.com>
11040
11041 * config/ia64/ia64.c (ia64_emit_probe_stack_range): Adjust calls to
11042 plus_constant.
11043
11044 2012-05-15 Eric Botcazou <ebotcazou@adacore.com>
11045
11046 * gimplify.c (gimplify_init_constructor): Do a block move for very
11047 small objects as well.
11048
11049 2012-05-15 Bernd Schmidt <bernds@codesourcery.com>
11050
11051 * ira.c (find_moveable_pseudos): Skip registers whose
11052 DF_REG_EQ_USE_COUNT is nonzero.
11053
11054 2012-05-15 Kenneth Zadeck <zadeck@naturalbridge.com>
11055
11056 * doc/md.texi (fma): Define to only be applicable for single rounding.
11057
11058 2012-05-14 Uros Bizjak <ubizjak@gmail.com>
11059
11060 PR target/46098
11061 * config/i386/i386.c (ix86_expand_special_args_builtin): Always
11062 generate target register for "load" class builtins.
11063
11064 Revert:
11065 2010-10-22 Uros Bizjak <ubizjak@gmail.com>
11066
11067 PR target/46098
11068 * config/i386/sse.md (*avx_movu<ssemodesuffix><avxmodesuffix>):
11069 Rename from avx_movu<ssemodesuffix><avxmodesuffix>.
11070 (avx_movu<ssemodesuffix><avxmodesuffix>): New expander.
11071 (*<sse>_movu<ssemodesuffix>): Rename from <sse>_movu<ssemodesuffix>.
11072 (<sse>_movu<ssemodesuffix>): New expander.
11073 (*avx_movdqu<avxmodesuffix>): Rename from avx_movdqu<avxmodesuffix>.
11074 (avx_movdqu<avxmodesuffix>): New expander.
11075 (*sse2_movdqu): Rename from sse2_movdqu.
11076 (sse2_movdqu): New expander.
11077
11078 2012-05-14 Marc Glisse <marc.glisse@inria.fr>
11079
11080 PR target/52607
11081 * config/i386/i386.c (ix86_expand_vec_perm_const): Move code to ...
11082 (canonicalize_perm): ... new function.
11083 (expand_vec_perm_2vperm2f128_vshuf): New function.
11084 (ix86_expand_vec_perm_const_1): Call it.
11085
11086 2012-05-14 Andrew Pinski <apinski@cavium.com>
11087 H.J. Lu <hongjiu.lu@intel.com>
11088 Jakub Jelinek <jakub@redhat.com>
11089
11090 PR target/53315
11091 * config/i386/i386.md (xbegin_1): Use + in constraint and match_dup.
11092 (xbegin): Updated.
11093
11094 2012-05-14 Jakub Jelinek <jakub@redhat.com>
11095
11096 * dwarf2out.c (dwarf2out_define, dwarf2out_undef): Treat
11097 lineno 1 the same as lineno 0 before first start file directive.
11098 (optimize_macinfo_range): Likewise.
11099
11100 * dwarf2out.c (have_macinfo): Define.
11101 (dwarf2out_finish): Don't emit DW_AT_GNU_macros or DW_AT_macro_info
11102 attribute, don't force empty compilation unit and don't emit any
11103 .debug_macinfo/.debug_macro section if macinfo_table is empty.
11104
11105 2012-05-14 Georg-Johann Lay <avr@gjlay.de>
11106
11107 PR target/53344
11108 * config/avr/avr.c (avr_const_address_lo16): Remove.
11109 (avr_assemble_integer): Print ".byte lo8(x)",
11110 ".byte hi8(x)", ".byte hh8(x)" instead of emit an assembler
11111 .warning if 3-byte address is assembled.
11112 * doc/extend.texi (AVR Named Address Spaces): Document that
11113 binutils 2.23 is needed to assemble 3-byte addresses.
11114
11115 2012-05-14 Richard Guenther <rguenther@suse.de>
11116
11117 * tree-vect-data-refs.c (vect_setup_realignment): Remove
11118 call to mark_symbols_for_renaming.
11119 (vect_permute_load_chain): Likewise.
11120 * tree-vect-loop.c (vect_is_slp_reduction): Update stmt
11121 instead of calling mark_symbols_for_renaming.
11122 * tree-vect-stmts.c (read_vector_array): Remove call to
11123 mark_symbols_for_renaming.
11124 (write_vector_array): Likewise.
11125 (vectorizable_call): Likewise.
11126 (vectorizable_store): Likewise.
11127 (vectorizable_load): Likewise.
11128 * matrix-reorg.c (transform_allocation_sites): Likewise.
11129 * tree-ssa-pre.c (create_expression_by_pieces): Likewise.
11130 (create_expression_by_pieces): Likewise.
11131
11132 2012-05-14 Richard Guenther <rguenther@suse.de>
11133
11134 * gimplify.c (gimple_regimplify_operands): Only mark the LHS
11135 of statements for renaming.
11136 (force_gimple_operand_1): Likewise, consistently for both
11137 calls to force_gimple_operand and force_gimple_operand_gsi.
11138
11139 2012-05-14 Richard Guenther <rguenther@suse.de>
11140
11141 * tree-dfa.c (make_rename_temp): Be forgiving if not in SSA form.
11142 * omp-low.c (expand_omp_taskreg): Properly conditionalize call
11143 to update_ssa.
11144 (expand_omp_for): Likewise.
11145 (expand_omp_for_generic): Adjust conditional add to referenced vars.
11146 Use make_rename_temp for temporaries that should be rewritten into
11147 SSA form.
11148 (expand_omp_for_static_nochunk): Likewise.
11149 (expand_omp_atomic_pipeline): Likewise.
11150
11151 2012-05-14 Richard Guenther <rguenther@suse.de>
11152
11153 PR tree-optimization/53331
11154 * tree-vect-data-refs.c (vect_verify_datarefs_alignment): Ignore
11155 strided loads.
11156 * tree-vect-stmts.c (vect_model_load_cost): Handle strided loads.
11157
11158 2012-05-14 Manuel López-Ibáñez <manu@gcc.gnu.org>
11159
11160 PR 53063
11161 * doc/options.texi: (LangEnabledBy): Document it.
11162 * optc-gen.awk: Handle LangEnabledBy.
11163 * opth-gen.awk: Generate declaration for lang-specific functions.
11164 * opt-read.awk: Record lang numbers.
11165 * opt-functions.awk (flag_set_p): Ignore the arguments of flags.
11166 (lang_sanitized_name): New.
11167
11168 2012-05-14 Bernd Schmidt <bernds@codesourcery.com>
11169
11170 * attribs.c (decl_attributes): Avoid emitting a warning if
11171 ATTR_FLAG_BUILT_IN.
11172 * doc/rtl.texi (CALL_INSN_FUNCTION_USAGE): Use lowercase for rtx
11173 codes. Document meaning of sets inside CALL_INSN_FUNCTION_USAGE.
11174 * builtin-attrs.def (DEF_ATTR_FOR_STRING): Define. Use it to
11175 define a string "1".
11176 (ATTR_RET1_NOTHROW_NONNULL_LEAF): New attr definition.
11177 * builtins.def (BUILT_IN_MEMCPY, BUILT_IN_MEMMOVE, BUILT_IN_MEMSET,
11178 BUILT_IN_STRCPY): Use it for these functions.
11179 * postreload.c (reload_combine): Deal with SETs inside
11180 CALL_INSN_FUNCTION_USAGE.
11181 * caller-save.c (setup_save_areas, save_call_clobbered_regs):
11182 Look for REG_RETURNED notes and use a cheap restore if possible.
11183 * ira-int.h (struct ira_allocno): New member cheap_calls_crossed_num.
11184 (ALLOCNO_CHEAP_CALLS_CROSSED_NUM): New macro.
11185 * ira-build.c (ira_create_allocno, create_cap_allocno,
11186 propagate_allocno_info, propagate_some_info_from_allocno,
11187 copy_info_to_removed_store_destination, ira_flattening): Handle it.
11188 * ira-lives.c (pseudo_regno_single_word_and_live_p,
11189 find_call_crossed_cheap_reg): New static functions.
11190 (process_bb_node_lives): Look for SETs in CALL_INSN_FUNCTION_USAGE,
11191 and set ALLOCNO_CHEAP_CALLS_CROSSED_NUM if possible. Also make
11192 a REG_RETURNED note in that case.
11193 * ira.c (setup_reg_renumber): Change assert to allow cases where
11194 allocnos only cross calls for which they are cheap to restore.
11195 * ira-costs.c (ira_tune_allocno_costs): Compare
11196 ALLOCNO_CALLS_CROSSED_NUM to ALLOCNO_CHEAP_CALLS_CROSSED_NUM rather
11197 than 0.
11198 * reg-notes.def (REG_RETURNED): New note.
11199 * cse.c (cse_insn): Likewise.
11200 * sched-deps.c (sched_analyze_insn): Likewise.
11201 * expr.c (init_block_move_fn): Set a "fn spec" attribute.
11202 * calls.c (decl_return_flags): New static function.
11203 (expand_call): Generate a SET in CALL_INSN_FUNCTION_USAGE for
11204 functions that return one of their arguments.
11205 * regcprop.c (struct kill_set_value_data): New.
11206 (kill_set_value): Interpret data as a pointer to such a struct.
11207 Do nothing if the caller wants the register to be ignored.
11208 (copyprop_hardreg_forward_1): Handle SETs in CALL_INSN_FUNCTION_USAGE.
11209
11210 2012-05-14 Richard Guenther <rguenther@suse.de>
11211
11212 PR tree-optimization/53340
11213 * tree-ssa-pre.c (op_valid_in_sets): Fix error in last commit.
11214
11215 2012-05-14 Richard Guenther <rguenther@suse.de>
11216
11217 * gimplify.c (gimplify_expr): Remove odd code.
11218
11219 2012-05-14 Eric Botcazou <ebotcazou@adacore.com>
11220
11221 * stor-layout.c (bit_from_pos): Distribute conversion to bitsizetype
11222 into a PLUS_EXPR byte offset.
11223
11224 * tree-ssa-pre.c (can_value_number_call): Delete.
11225 (compute_avail): Skip all statements with side effects.
11226 <GIMPLE_CALL>: Skip calls to internal functions.
11227
11228 2012-05-13 Steven Bosscher <steven@gcc.gnu.org>
11229
11230 * config/pa/pa.md: Use define_c_enum for "unspec" and "unspecv".
11231
11232 2012-05-13 Manuel López-Ibáñez <manu@gcc.gnu.org>
11233
11234 * common.opt (Wtype-limits): Use EnabledBy.
11235
11236 2012-05-13 Uros Bizjak <ubizjak@gmail.com>
11237
11238 * config/i386/i386.md (*pushtf): Enable for TARGET_SSE.
11239 (pushtf splitter): Ditto.
11240 (movtf): Ditto.
11241 (*movtf_internal): Ditto. Use V4SFmode for !TARGET_SSE2.
11242 (<code>tf2): Enable for TARGET_SSE.
11243 (*absnegtf2_sse): Ditto.
11244 (copysign<mode>3): Enable TFmode for TARGET_SSE.
11245 (copysign<mode>3_const): Ditto.
11246 (copysign<mode>3_var): Ditto.
11247 * config/i386/sse.md (<code>tf3): Enable for TARGET_SSE.
11248 (*andnottf3): Ditto. Use V4SFmode for !TARGET_SSE2.
11249 (*<code>tf3): Ditto.
11250 * config/i386/i386.c (struct builtin_description bdesc_args)
11251 <IX86_BUILTIN_FABSQ>: Enable for TARGET_SSE.
11252 <IX86_BUILTIN_COPYSIGNQ>: Ditto.
11253 (ix86_expand_builtin) <IX86_BUILTIN_FABSQ, IX86_BUILTIN_COPYSIGNQ>:
11254 Emit a normal call if SSE isn't available.
11255
11256 2012-05-13 Uros Bizjak <ubizjak@gmail.com>
11257
11258 * config/i386/sse.md (<sse>_andnot<mode>3): Handle
11259 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL.
11260 (<code><mode>3): Ditto.
11261 (*andnot<mode>3): Ditto.
11262 (*andnottf3): Ditto.
11263 (*<code><mode>3): Ditto.
11264 (<code>tf3): Ditto.
11265
11266 2012-05-13 Manuel López-Ibáñez <manu@gcc.gnu.org>
11267
11268 * optc-gen.awk: Error instead of warning for conflicting help.
11269
11270 2012-05-12 Jason Merrill <jason@redhat.com>
11271
11272 PR debug/53235
11273 * dwarf2out.c (build_local_stub): Prefer DW_AT_signature for
11274 comdat types.
11275
11276 2012-05-12 Eric Botcazou <ebotcazou@adacore.com>
11277
11278 * function.c (requires_stack_frame_p): If the function can throw
11279 non-call exceptions, return true if the insn can throw internally.
11280
11281 2012-05-12 Paolo Carlini <paolo.carlini@oracle.com>
11282
11283 * doc/generic.texi: Rename TYPE_PTRMEM_P to TYPE_PTRDATAMEM_P.
11284
11285 2012-05-12 Uros Bizjak <ubizjak@gmail.com>
11286
11287 * config/alpha/alpha.c (alpha_emit_conditional_branch): Handle
11288 ORDERED and UNORDERED conditions.
11289
11290 2012-05-11 Richard Guenther <rguenther@suse.de>
11291
11292 * tree-flow.h (referenced_var_check_and_insert): Remove.
11293 (find_new_referenced_vars): Likewise.
11294 * tree-dfa.c (referenced_var_check_and_insert): Make static.
11295 (find_new_referenced_vars_1, find_new_referenced_vars): Remove.
11296 * tree-inline.c (copy_bb): Use find_referenced_vars_in
11297 instead of find_new_referenced_vars.
11298 * gimple-fold.c (gimplify_and_update_call_from_tree): Likewise.
11299
11300 2012-05-11 Richard Guenther <rguenther@suse.de>
11301
11302 * tree-pass.h (pass_rest_of_compilation,
11303 pass_all_optimizations, pass_postreload, pass_all_early_optimizations):
11304 Remove.
11305 * passes.c (pass_all_optimizations, pass_postreload,
11306 pass_all_early_optimizations): Make static.
11307 (pass_rest_of_compilation): Likewise. Make it an RTL_PASS.
11308 * tree-phinodes.c (init_phinodes, fini_phinodes): Remove.
11309 * tree-ssa.c (init_tree_ssa): Do not call init_phinodes.
11310 (delete_tree_ssa): Do not call fini_phinodes.
11311 * tree-flow.h (init_phinodes, fini_phinodes): Remove.
11312
11313 2012-05-11 Manuel López-Ibáñez <manu@gcc.gnu.org>
11314
11315 PR 53063
11316 * doc/options.texi (EnabledBy): Document
11317 * opts.c: Include opts.h and options.h before tm.h.
11318 (finish_options): Do not handle some sub-options here...
11319 (common_handle_option): ... instead call common_handle_option_auto
11320 here.
11321 * optc-gen.awk: Handle EnabledBy.
11322 * opth-gen.awk: Declare common_handle_option_auto.
11323 * common.opt (Wuninitialized): Use EnabledBy. Delete Init.
11324 (Wmaybe-uninitialized): Likewise.
11325 (Wunused-but-set-variable): Likewise.
11326 (Wunused-function): Likewise.
11327 (Wunused-label): Likewise.
11328 (Wunused-value): Likewise.
11329 (Wunused-variable): Likewise.
11330 * opt-read.awk: Create opt_numbers array.
11331
11332 2012-05-11 Richard Guenther <rguenther@suse.de>
11333
11334 PR tree-optimization/53295
11335 * tree-data-ref.h (stride_of_unit_type_p): Handle non-constant
11336 strides.
11337 * tree-data-ref.c (dr_analyze_innermost): Allow non-constant
11338 strides when analyzing data-references in a loop context.
11339 * tree-vect-data-refs.c (vect_mark_for_runtime_alias_test): Reject
11340 non-constant strides for now.
11341 (vect_enhance_data_refs_alignment): Ignore data references
11342 that are strided loads.
11343 (vect_analyze_data_ref_access): Handle non-constant strides.
11344 (vect_check_strided_load): Verify the data-reference is a load.
11345 (vect_analyze_data_refs): Restructure to make strided load
11346 support not dependent on gather support.
11347 * tree-vect-stmts.c (vectorizable_load): Avoid useless work
11348 when doing strided or gather loads.
11349 * tree-vect-loop-manip.c (vect_vfa_segment_size): Use
11350 integer_zerop to compare stride with zero.
11351
11352 2012-05-11 H.J. Lu <hongjiu.lu@intel.com>
11353
11354 * config/i386/driver-i386.c (host_detect_local_cpu): Support RTM.
11355
11356 2012-05-11 Jan Hubicka <jh@suse.cz>
11357
11358 PR bootstrap/53300
11359 * varpool.c (varpool_assemble_decl): Also output constat pool entries
11360 that output_constant_pool missed.
11361
11362 2012-05-11 Mingjie Xing <mingjie.xing@gmail.com>
11363
11364 * config/mips/t-vxworks: Change MUTLILIB_EXTRA_OPTS to
11365 MULTILIB_EXTRA_OPTS.
11366
11367 2012-05-11 Uros Bizjak <ubizjak@gmail.com>
11368
11369 PR target/53291
11370 * config/i386/i386.md (xtest): Use NE condition in ix86_expand_setcc.
11371
11372 2012-05-11 Uros Bizjak <ubizjak@gmail.com>
11373
11374 * config/i386/i386.md (*movti_internal_rex64): Avoid MOVAPS size
11375 optimization for TARGET_AVX.
11376 (*movti_internal_sse): Ditto.
11377 (*movdi_internal_rex64): Handle TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL.
11378 (*movdi_internal): Ditto.
11379 (*movsi_internal): Ditto.
11380 (*movtf_internal): Avoid MOVAPS size optimization for TARGET_AVX.
11381 (*movdf_internal_rex64): Ditto.
11382 (*movfd_internal): Ditto.
11383 (*movsf_internal): Ditto.
11384 * config/i386/sse.md (mov<mode>): Handle TARGET_SSE_LOAD0_BY_PXOR.
11385
11386 2012-05-10 Eric Botcazou <ebotcazou@adacore.com>
11387
11388 * dwarf2out.c (add_byte_size_attribute) <RECORD_TYPE>: Handle variable
11389 reference as size attribute.
11390
11391 2012-05-10 Eric Botcazou <ebotcazou@adacore.com>
11392 Tristan Gingold <gingold@adacore.com>
11393
11394 * doc/md.texi (Standard Names): Document probe_stack_address.
11395 * explow.c (emit_stack_probe): Handle probe_stack_address.
11396 * config/ia64/ia64.md (UNSPECV_PROBE_STACK_ADDRESS): New constant.
11397 (UNSPECV_PROBE_STACK_RANGE): Likewise.
11398 (probe_stack_address): New insn.
11399 (probe_stack_range): Likewise.
11400 * config/ia64/ia64.c: Include common/common-target.h.
11401 (ia64_compute_frame_size): Mark r2 and r3 as used if static stack
11402 checking is enabled.
11403 (ia64_emit_probe_stack_range): New function.
11404 (output_probe_stack_range): Likewise.
11405 (ia64_expand_prologue): Invoke ia64_emit_probe_stack_range if static
11406 builtin stack checking is enabled.
11407 (rtx_needs_barrier) <UNSPEC_VOLATILE>: Handle UNSPECV_PROBE_STACK_RANGE
11408 and UNSPECV_PROBE_STACK_ADDRESS.
11409 (unknown_for_bundling_p): New predicate.
11410 (group_barrier_needed): Use important_for_bundling_p.
11411 (ia64_dfa_new_cycle): Use unknown_for_bundling_p.
11412 (issue_nops_and_insn): Likewise.
11413 (bundling): Likewise.
11414 (final_emit_insn_group_barriers): Likewise.
11415 * config/ia64/ia64-protos.h (output_probe_stack_range): Declare.
11416 * config/ia64/hpux.h (STACK_CHECK_STATIC_BUILTIN): Define.
11417 (STACK_CHECK_PROTECT): Likewise.
11418 * config/ia64/linux.h (STACK_CHECK_STATIC_BUILTIN): Likewise.
11419
11420 2012-05-10 Jan Hubicka <jh@suse.cz>
11421
11422 * ipa-inline.c (update_all_callee_keys): Remove.
11423 (inline_small_functions): Simplify priority updating.
11424
11425 2012-05-10 Jan Hubicka <jh@suse.cz>
11426
11427 * ipa.c (symtab_remove_unreachable_nodes): Fix marking of clones.
11428
11429 2012-05-10 Jan Hubicka <jh@suse.cz>
11430
11431 * cgraph.h (cgraph_remove_unreachable_nodes): Rename to ...
11432 (symtab_remove_unreachable_nodes): ... this one.
11433 * ipa-cp.c (ipcp_driver): Do not remove unreachable nodes.
11434 * cgraphunit.c (ipa_passes): Update.
11435 * cgraphclones.c (cgraph_materialize_all_clones): Update.
11436 * cgraph.c (cgraph_release_function_body): Only turn initial
11437 into error mark when initial was previously set.
11438 * ipa-inline.c (ipa_inline): Update.
11439 * ipa.c: Include ipa-inline.h
11440 (enqueue_cgraph_node, enqueue_varpool_node): Remove.
11441 (enqueue_node): New function.
11442 (process_references): Update.
11443 (symtab_remove_unreachable_nodes): Cleanup.
11444 * passes.c (execute_todo, execute_one_pass): Update.
11445
11446 2012-05-10 Vladimir Makarov <vmakarov@redhat.com>
11447
11448 PR rtl-optimization/53125
11449 * ira.c (ira): Call find_moveable_pseudos and
11450 move_unallocated_pseudos if only ira_conflicts_p is true.
11451
11452 2012-05-10 Uros Bizjak <ubizjak@gmail.com>
11453
11454 * config/i386/i386.md (*movoi_internal_avx): Handle
11455 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL and TARGET_SSE_TYPELESS_STORES.
11456 (*movti_internal_rex64): Handle TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL.
11457 (*movti_internal_sse): Ditto.
11458 (*movtf_internal): Ditto.
11459 * config/i386/sse.md (ssePSmode): New mode attribute.
11460 (*move<mode>_internal): Use ssePSmode.
11461 (*<sse>_movu<ssemodesuffix><avxsizesuffix>): Ditto.
11462 (*<sse2>_movdqu<avxsizesuffix>): Ditto.
11463 * config/i386/i386.c (standard_sse_constant_opcode): Do not handle
11464 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL here.
11465
11466 2012-05-10 Eric Botcazou <ebotcazou@adacore.com>
11467
11468 * gimplify.c (gimplify_decl_expr): For a TYPE_DECL, also gimplify the
11469 DECL_ORIGINAL_TYPE if it is present.
11470
11471 2012-05-10 Nick Clifton <nickc@redhat.com>
11472
11473 PR target/53120
11474 * config/m32c/bitops.md (bset_qi): Change operand 2 from having
11475 a "0" constraint to being a (match_dup 0).
11476
11477 2012-05-10 Richard Guenther <rguenther@suse.de>
11478
11479 * stor-layout.c (byte_from_pos): Amend comment.
11480
11481 2012-05-10 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
11482
11483 * doc/extend.texi (X86 Built-in Functions, __builtin_cpu_init):
11484 Document requirement to call in constructors.
11485
11486 * config/i386/i386.c: Update comments for i386-cpuinfo.c name change.
11487
11488 2012-05-10 Richard Guenther <rguenther@suse.de>
11489
11490 * tree.h (TYPE_IS_SIZETYPE): Remove.
11491 * fold-const.c (int_const_binop_1): Remove TYPE_IS_SIZETYPE use.
11492 (extract_muldiv_1): Likewise.
11493 * gimple.c (gtc_visit): Likewise.
11494 (gimple_types_compatible_p): Likewise.
11495 (iterative_hash_canonical_type): Likewise.
11496 (gimple_canonical_types_compatible_p): Likewise.
11497 * gimplify.c (gimplify_one_sizepos): Likewise.
11498 * print-tree.c (print_node): Likewise.
11499 * stor-layout.c (initialize_sizetypes): Do not set TYPE_IS_SIZETYPE.
11500
11501 2012-05-09 Uros Bizjak <ubizjak@gmail.com>
11502
11503 PR target/52908
11504 * config/i386/sse.md (vec_widen_smult_hi_v4si): Expand using
11505 xop_pmacsdqh insn pattern instead of xop_mulv2div2di3_high.
11506 (vec_widen_smult_lo_v4si): Expand using xop_pmacsdql insn pattern
11507 instead of xop_mulv2div2di3_low.
11508 (xop_p<macs>dql): Fix vec_select selector.
11509 (xop_p<macs>dqh): Ditto.
11510 (xop_mulv2div2di3_low): Remove insn_and_split pattern.
11511 (xop_mulv2div2di3_high): Ditto.
11512
11513 2012-05-09 Manuel López-Ibáñez <manu@gcc.gnu.org>
11514
11515 PR c++/53289
11516 * diagnostic.h (diagnostic_context): Add last_location.
11517 * diagnostic.c (diagnostic_initialize): Initialize it.
11518 (diagnostic_show_locus): Use it.
11519
11520 2012-05-09 Manuel López-Ibáñez <manu@gcc.gnu.org>
11521
11522 * doc/extend.texi (Function Attributes): Point xref to section
11523 about Pragmas.
11524
11525 2012-05-09 Uros Bizjak <ubizjak@gmail.com>
11526
11527 * config/i386/i386.c (*movdf_internal_rex64): Remove
11528 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL handling from asm output code.
11529 Calculate "mode" attribute according to
11530 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL flag.
11531 (*movdf_internal): Ditto.
11532
11533 2012-05-09 Uros Bizjak <ubizjak@gmail.com>
11534
11535 PR target/44141
11536 * config/i386/i386.c (ix86_expand_vector_move_misalign): Do not handle
11537 128 bit vectors specially for TARGET_AVX. Emit sse2_movupd and
11538 sse_movupd RTXes for TARGET_AVX, TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL
11539 or when optimizing for size.
11540 * config/i386/sse.md (*mov<mode>_internal): Remove
11541 TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL handling from asm output code.
11542 Calculate "mode" attribute according to optimize_function_for_size_p
11543 and TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL flag.
11544 (*<sse>_movu<ssemodesuffix><avxsizesuffix>): Choose asm template
11545 depending on the mode of the instruction. Calculate "mode" attribute
11546 according to optimize_function_for_size_p, TARGET_SSE_TYPELESS_STORES
11547 and TARGET_SSE_PACKED_SINGLE_INSN_OPTIMAL flags.
11548 (*<sse2>_movdqu<avxsizesuffix>): Ditto.
11549
11550 2012-05-09 Georg-Johann Lay <avr@gjlay.de>
11551
11552 PR target/53256
11553 * config/avr/elf.h (ASM_DECLARE_FUNCTION_NAME): Remove.
11554 * config/avr/avr-protos.h (avr_asm_declare_function_name): Remove.
11555 * config/avr/avr.h (struct machine_function): Add attributes_checked_p.
11556 * config/avr/avr.c (avr_asm_declare_function_name): Remove.
11557 (expand_prologue): Move initialization of cfun->machine->is_naked,
11558 is_interrupt, is_signal, is_OS_task, is_OS_main from here to...
11559 (avr_set_current_function): ...this new static function.
11560 (TARGET_SET_CURRENT_FUNCTION): New define.
11561 (avr_function_ok_for_sibcall): Use cfun->machine->is_* instead of
11562 checking attributes of current_function_decl.
11563 (avr_regs_to_save): Ditto.
11564 (signal_function_p): Rename to avr_signal_function_p.
11565 (interrupt_function_p): Rename to avr_interrupt_function_p.
11566
11567 * doc/extend.texi (Function Attributes): Better explanation of
11568 'interrupt' and 'signal' for AVR. Move 'ifunc' down to establish
11569 alphabetical order.
11570
11571 2012-05-09 Michael Matz <matz@suse.de>
11572
11573 PR tree-optimization/53185
11574 * tree-vect-data-refs.c (vect_enhance_data_refs_alignment): Disable
11575 peeling when we see strided loads.
11576
11577 2012-05-09 Matthias Klose <doko@ubuntu.com>
11578
11579 * gcc-ar.c (main): Don't check for execute bits for the plugin.
11580
11581 2012-05-09 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
11582
11583 * tree-ssa-loop-ivopts.c (add_autoinc_candidates, get_address_cost):
11584 Replace use of HAVE_{POST/PRE}_{INCREMENT/DECREMENT} with
11585 USE_{LOAD/STORE}_{PRE/POST}_{INCREMENT/DECREMENT} appropriately.
11586 * config/arm/arm.h (ARM_AUTOINC_VALID_FOR_MODE_P): New.
11587 (USE_LOAD_POST_INCREMENT): Define.
11588 (USE_LOAD_PRE_INCREMENT): Define.
11589 (USE_LOAD_POST_DECREMENT): Define.
11590 (USE_LOAD_PRE_DECREMENT): Define.
11591 (USE_STORE_PRE_DECREMENT): Define.
11592 (USE_STORE_PRE_INCREMENT): Define.
11593 (USE_STORE_POST_DECREMENT): Define.
11594 (USE_STORE_POST_INCREMENT): Define.
11595 (arm_auto_incmodes): Add enumeration.
11596 * config/arm/arm-protos.h (arm_autoinc_modes_ok_p): Declare.
11597 * config/arm/arm.c (arm_autoinc_modes_ok_p): Define.
11598
11599 2012-05-09 Jakub Jelinek <jakub@redhat.com>
11600
11601 PR tree-optimization/53226
11602 * tree-ssa-forwprop.c (ssa_forward_propagate_and_combine): Remove
11603 prev and prev_initialized vars, gimple_set_plf (stmt, GF_PLF_1, false)
11604 before processing it and gimple_set_plf (stmt, GF_PLF_1, true) if it
11605 doesn't need to be revisited, look for earliest stmt with
11606 !gimple_plf (stmt, GF_PLF_1) if something changed.
11607
11608 2012-05-09 Terry Guo <terry.guo@arm.com>
11609
11610 * genmultilib: Update copyright dates.
11611 * doc/fragments.texi: Ditto.
11612
11613 2012-05-09 Terry Guo <terry.guo@arm.com>
11614
11615 * Makefile.in (s-mlib): Add new argument MULTILIB_REQUIRED.
11616 * genmultilib (MULTILIB_REQUIRED): New.
11617 * doc/fragments.texi: Document the MULTILIB_REQUIRED.
11618
11619 2012-05-09 Richard Guenther <rguenther@suse.de>
11620
11621 * tree-vectorizer.h (vect_loop_versioning): Adjust prototype.
11622 (vect_do_peeling_for_loop_bound): Likewise.
11623 (vect_do_peeling_for_alignment): Likewise.
11624 * tree-vect-loop-manip.c (conservative_cost_threshold): Remove.
11625 (vect_do_peeling_for_loop_bound): Get check_profitability and
11626 threshold as parameters.
11627 (vect_do_peeling_for_alignment): Likewise.
11628 (vect_loop_versioning): Likewise.
11629 * tree-vect-loop.c (vect_transform_loop): Compute check_profitability
11630 and threshold here. Control where to put the check here.
11631
11632 2012-05-09 Richard Sandiford <rdsandiford@googlemail.com>
11633
11634 PR middle-end/53249
11635 * dwarf2out.h (get_address_mode): Move declaration to...
11636 * rtl.h: ...here.
11637 * dwarf2out.c (get_address_mode): Move definition to...
11638 * rtlanal.c: ...here.
11639 * var-tracking.c (get_address_mode): Delete.
11640 * combine.c (find_split_point): Use get_address_mode instead of
11641 targetm.addr_space.address_mode.
11642 * cselib.c (cselib_record_sets): Likewise.
11643 * dse.c (canon_address, record_store): Likewise.
11644 * emit-rtl.c (adjust_address_1, offset_address): Likewise.
11645 * expr.c (move_by_pieces, emit_block_move_via_loop, store_by_pieces)
11646 (store_by_pieces_1, expand_assignment, store_expr, store_constructor)
11647 (expand_expr_real_1): Likewise.
11648 * ifcvt.c (noce_try_cmove_arith): Likewise.
11649 * optabs.c (maybe_legitimize_operand_same_code): Likewise.
11650 * reload.c (find_reloads): Likewise.
11651 * sched-deps.c (sched_analyze_1, sched_analyze_2): Likewise.
11652 * sel-sched-dump.c (debug_mem_addr_value): Likewise.
11653
11654 2012-05-09 Maciej W. Rozycki <macro@codesourcery.com>
11655
11656 * config/mips/mips.c (mips16_gp_pseudo_reg): Remove line
11657 information from the instruction produced.
11658
11659 2012-05-09 Richard Guenther <rguenther@suse.de>
11660
11661 * stor-layout.c (bit_from_pos): Document.
11662 (byte_from_pos): Likewise. Optimize.
11663 (pos_from_bit): Likewise.
11664 (normalize_offset): Use pos_from_bit instead of replicating it.
11665
11666 2012-05-09 Alan Modra <amodra@gmail.com>
11667
11668 PR target/53271
11669 * config/rs6000/rs6000.c (gen_frame_set): New function.
11670 (gen_frame_load, gen_frame_store): New functions.
11671 (rs6000_savres_rtx): Use the above.
11672 (rs6000_emit_epilogue, rs6000_emit_prologue): Here too.
11673 Correct mode used for CR2 in save/restore_world patterns.
11674 Don't emit instructions for eh_return frame unwind reg info.
11675
11676 2012-05-08 Jan Hubicka <jh@suse.cz>
11677
11678 * cgraphbuild.c (build_cgraph_edges): Do not finalize vars
11679 with VALUE_EXPR.
11680 * cgraph.h (varpool_can_remove_if_no_refs): Vars with VALUE_EXPR
11681 are removable.
11682 * toplev.c (wrapup_global_declaration_2): Vars with VALUE_EXPR
11683 need to wrapup.
11684 (compile_file): Do not output variables.
11685 * cgraphbuild.c (varpool_finalize_decl): When var is finalized late,
11686 output it.
11687 * langhooks.c: Include timevar.h
11688 (write_global_declarations): Finalize compilation unit after wrapup;
11689 set timevars correctly.
11690 * passes.c (rest_of_decl_compilation): Decls with VALUE_EXPR needs
11691 not to be added to varpool.
11692 * varpool.c (varpool_assemble_decl): Sanity check that we are called
11693 only on cases where it makes sense; skip constant pool and value expr
11694 vars.
11695
11696 2012-05-08 David S. Miller <davem@davemloft.net>
11697
11698 * config/sparc/linux.h (LINK_SPEC): Don't pass "-Y" option.
11699 * config/sparc/linux64.h (LINK_ARCH32_SPEC): Likewise.
11700 * config/sparc/linux64.h (LINK_ARCH64_SPEC): Likewise.
11701
11702 2012-05-08 Richard Sandiford <rdsandiford@googlemail.com>
11703
11704 PR rtl-optimization/53278
11705 * lower-subreg.c (decompose_multiword_subregs): Remove left-over
11706 speed_p code from earlier patch.
11707
11708 2012-05-08 Oleg Endo <olegendo@gcc.gnu.org>
11709
11710 PR target/51244
11711 * config/sh/sh.md (*branch_true, *branch_false): New insns.
11712
11713 2012-05-08 Teresa Johnson <tejohnson@google.com>
11714
11715 * gcov-io.h (__gcov_reset, __gcov_dump): Declare.
11716 * doc/gcov.texi: Add note on using __gcov_reset and __gcov_dump.
11717
11718 2012-05-08 Jan Hubicka <jh@suse.cz>
11719
11720 * cgraph.c (cgraph_call_edge_duplication_hooks): Export.
11721 (cgraph_create_node_1): Rename to ...
11722 (cgraph_create_empty_node): ... this one; export.
11723 (cgraph_create_node): Update.
11724 (cgraph_set_call_stmt_including_clones): Move to cgraphclones.c
11725 (cgraph_create_edge_including_clones): Likewise.
11726 (cgraph_find_replacement_node): Likewise.
11727 (cgraph_clone_edge): Likewise.
11728 (cgraph_clone_node): Likewise.
11729 (clone_function_name): Likewise.
11730 (cgraph_create_virtual_clone): Likewise.
11731 (cgraph_remove_node_and_inline_clones): Likewise.
11732 (cgraph_redirect_edge_call_stmt_to_callee): Move here from cgraphunit.c
11733 * cgraph.h: Reorder declarations so they match file of origin.
11734 (cgraph_create_empty_node): Declare.
11735 * cgraphunit.c (update_call_expr): Move to cgraphclones.c
11736 (cgraph_copy_node_for_versioning): Likewise.
11737 (cgraph_function_versioning): Likewise.
11738 (cgraph_materialize_clone): Likewise.
11739 (cgraph_redirect_edge_call_stmt_to_callee): Likewise.
11740 (cgraph_materialize_all_clones): Likewise.
11741 * cgraphclones.c: New file.
11742 * Makefile.in: Update for cgraphclones.
11743
11744 2012-05-08 Uros Bizjak <ubizjak@gmail.com>
11745
11746 PR target/53176
11747 * config/i386/i386.c (ix86_set_reg_reg_cost): New function.
11748 (ix86_rtx_costs): Handle SET.
11749
11750 2012-05-08 Michael Matz <matz@suse.de>
11751
11752 * basic-block.h (struct rtl_bb_info): Remove visited member and
11753 move head_ member to ...
11754 (struct basic_block_def.basic_block_il_dependent): ... the new
11755 member x, replacing but containing old member rtl.
11756 (enum bb_flags): New BB_VISITED flag.
11757 (BB_HEADER, BB_FOOTER): New macros.
11758
11759 * jump.c (mark_all_labels): Adjust.
11760 * cfgcleanup.c (try_optimize_cfg): Adjust.
11761 * cfglayout.c (record_effective_endpoints): Adjust.
11762 (relink_block_chain): Ditto (and don't fiddle with visited).
11763 (fixup_reorder_chain): Adjust.
11764 (fixup_fallthru_exit_predecessor): Ditto.
11765 (cfg_layout_duplicate_bb): Ditto.
11766 * combine.c (update_cfg_for_uncondjump): Adjust.
11767 * bb-reorder.c (struct bbro_basic_block_data_def): Add visited member.
11768 (bb_visited_trace): New accessor.
11769 (mark_bb_visited): Move in front.
11770 (rotate_loop): Use bb_visited_trace.
11771 (find_traces_1_round): Ditto.
11772 (emit_barrier_after): Ditto.
11773 (copy_bb): Ditto, and initialize visited on resize.
11774 (reorder_basic_blocks): Initize visited member.
11775 (duplicate_computed_gotos): Clear bb flags at start, use
11776 BB_VISITED flags.
11777
11778 * cfgrtl.c (try_redirect_by_replacing_jump): Adjust.
11779 (rtl_verify_flow_info_1): Ditto.
11780 (cfg_layout_split_block): Ditto.
11781 (cfg_layout_delete_block): Ditto.
11782 (cfg_layout_merge_blocks): Ditto.
11783 (init_rtl_bb_info): Adjust and initialize il.x.head_ member.
11784
11785 2012-05-08 Hans-Peter Nilsson <hp@axis.com>
11786
11787 PR target/53272
11788 * config/cris/cris.c (cris_normal_notice_update_cc): For TARGET_V32,
11789 when a constant source operand matches an "I" constraint, the "no
11790 CC0 change" applies to a register-destination only, not a
11791 strict_low_part-destination.
11792
11793 2012-05-08 Richard Guenther <rguenther@suse.de>
11794
11795 * fold-const.c (fold_binary_loc): Fold (X * CST1) & CST2
11796 to zero or to (X * CST1) & CST2' when CST1 has trailing zeros.
11797
11798 2012-05-08 Georg-Johann Lay <avr@gjlay.de>
11799
11800 * Makefile.in (TEXI_GCC_FILES): Add avr-mmcu.texi.
11801
11802 * doc/avr-mmcu.texi: New auto-generated file.
11803 * doc/invoke.texi (AVR Options): Include avr-mmcu.texi in order
11804 to document all valid -mmcu= arguments.
11805
11806 * config/avr/avr.h (arch_info_s): New struct definition.
11807 * config/avr/avr-devices.c (avr_texinfo): New variable.
11808 * config/avr/gen-avr-mmcu-texi.c: New file.
11809 * config/avr/t-avr: New rules and dependencies to build avr-mmcu.texi.
11810
11811 2012-05-08 Dehao Chen <dehao@google.com>
11812
11813 * predict.c (find_qualified_ssa_name): New.
11814 (find_ssa_name_in_expr): New.
11815 (find_ssa_name_in_assign_stmt): New.
11816 (is_comparison_with_loop_invariant_p): New.
11817 (is_bound_expr_similar): New.
11818 (predict_iv_comparison): New.
11819 (predict_loops): Add heuristic for loop-nested branches that compare an
11820 induction variable to a loop bound variable.
11821 * predict.def (PRED_LOOP_IV_COMPARE): New macro.
11822
11823 2012-05-08 Uros Bizjak <ubizjak@gmail.com>
11824
11825 * config/i386/i386.c (has_dispatch): Use TARGET_BDVER1 and
11826 TARGET_BDVER2 defines where appropriate.
11827
11828 2012-05-07 Eric Botcazou <ebotcazou@adacore.com>
11829
11830 * configure.ac (PLUGIN_LD): Rename into...
11831 (PLUGIN_LD_SUFFIX): ...this and strip the target_alias triplet.
11832 * config.in: Regenerate.
11833 * configure: Likewise.
11834 * collect2.c (main): Set plugin_ld_suffix to PLUGIN_LD_SUFFIX.
11835
11836 2012-05-07 Eric Botcazou <ebotcazou@adacore.com>
11837
11838 * tree-dfa.c (get_ref_base_and_extent) <ARRAY_REF>: Do the offset
11839 computation using the precision of the index type.
11840 * gimple-fold.c (fold_const_aggregate_ref_1) <ARRAY_REF>: Likewise.
11841 (fold_array_ctor_reference): Do index computations in the index type.
11842
11843 2012-05-07 Georg-Johann Lay <avr@gjlay.de>
11844
11845 * config/avr/avr.c (avr_prologue_setup_frame): Fix mode passed
11846 down to plus_constant.
11847 (expand_epilogue): Ditto.
11848
11849 2012-05-07 Steven Bosscher <steven@gcc.gnu.org>
11850
11851 * postreload.c (reload_cse_regs): Make static.
11852 * reload.h (reload_cse_regs): Remove prototype.
11853
11854 2012-05-07 Richard Henderson <rth@redhat.com>
11855
11856 * config/alpha/alpha.md (clear_cache): New pattern.
11857
11858 2012-05-07 Steven Bosscher <steven@gcc.gnu.org>
11859
11860 PR middle-end/53245
11861 * gimplify.c (preprocess_case_label_vec_for_gimple): If low or high
11862 is folded to a type boundary value, verify that the resulting case
11863 label is still a care range.
11864
11865 2012-05-07 Uros Bizjak <ubizjak@gmail.com>
11866
11867 * config/i386/i386.md (ctz<mode>2): Emit rep;bsf
11868 only for TARGET_GENERIC, when not optimizing for size.
11869 (*ffs<mode>_1): Ditto.
11870
11871 2012-05-07 Steven Bosscher <steven@gcc.gnu.org>
11872
11873 * tree-cfg.c (verify_gimple_switch): Tighten checks.
11874
11875 2012-05-07 Jakub Jelinek <jakub@redhat.com>
11876
11877 PR tree-optimization/53239
11878 * tree-vrp.c (get_value_range): Set VR of SSA_NAME_IS_DEFAULT_DEF
11879 of DECL_BY_REFERENCE RESULT_DECL to nonnull.
11880
11881 2012-05-07 Richard Guenther <rguenther@suse.de>
11882
11883 PR tree-optimization/53195
11884 * tree-inline.c (setup_one_parameter): Properly add referenced
11885 vars from the parameters new known value.
11886
11887 2012-05-07 Steven Bosscher <steven@gcc.gnu.org>
11888
11889 * config/m68k/m68k.c (m68k_sched_branch_type): Remove.
11890 (sched_branch_type): Remove.
11891 (m68k_sched_md_init_global): Don't allocate it.
11892 (m68k_sched_md_finish_global): Don't free it.
11893 * config/m68k/m68k.h (m68k_sched_branch_type): Remove prototype.
11894 * config/m68k/m68k.md: Set the type of insns using
11895 m68k_sched_branch_type to bcc directly.
11896
11897 2012-05-07 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
11898
11899 * config/sol2.c (solaris_override_options): New function.
11900 * config/sol2-protos.h (solaris_override_options): Declare.
11901 * config/sol2.h (SUBTARGET_OVERRIDE_OPTIONS): Define.
11902
11903 2012-05-07 Richard Guenther <rguenther@suse.de>
11904
11905 * tree-ssa-loop-prefetch.c (determine_loop_nest_reuse): Return
11906 whether we failed to compute data dependences.
11907 (loop_prefetch_arrays): Fail if we failed.
11908
11909 2012-05-07 Uros Bizjak <ubizjak@gmail.com>
11910 Paolo Bonzini <bonzini@gnu.org>
11911
11912 * config/i386/i386.md (ctz<mode>2): Emit rep;bsf even for !TARGET_BMI.
11913 Emit bsf when optimizing for size.
11914 (*ffs<mode>_1): Ditto.
11915
11916 2012-05-07 Oleg Endo <olegendo@gcc.gnu.org>
11917
11918 PR target/53250
11919 * config/sh/sh.c (sh_rtx_costs): Handle SET.
11920
11921 2012-05-06 Uros Bizjak <ubizjak@gmail.com>
11922
11923 PR target/53227
11924 * config/i386/i386.md (swap<mode>): Rename from *swap<mode>.
11925 (bswapdi2): Split from bswap<mode>2. Use nonnimediate_operand
11926 predicate for operand 1. Force operand 1 to register for TARGET_BSWAP.
11927 (bswapsi2): Ditto.
11928 (*bswapdi2_doubleword): New insn pattern.
11929 (*bswap<mode>2): Rename from *bswap<mode>2_1.
11930
11931 2012-05-06 Richard Sandiford <rdsandiford@googlemail.com>
11932
11933 * config/mips/mips.c (mips_set_reg_reg_piece_cost): New function.
11934 (mips_set_reg_reg_cost): Likewise.
11935 (mips_rtx_costs): Handle SET.
11936
11937 2012-05-06 Richard Sandiford <rdsandiford@googlemail.com>
11938
11939 * lower-subreg.c (shift_cost): Use set_src_cost, avoiding the SET.
11940 (compute_costs): Likewise for the zero extension. Use set_rtx_cost
11941 to compute the cost of moves. Set the mode of the target register.
11942
11943 2012-05-05 Richard Sandiford <rdsandiford@googlemail.com>
11944
11945 * rtl.h (plus_constant, plus_constant_mode): Merge into a single
11946 plus_constant function.
11947 * explow.c (plus_constant, plus_constant_mode): Likewise. Assert
11948 that the mode is sensible.
11949 (use_anchored_address, round_push, allocate_dynamic_stack_space)
11950 (probe_stack_range, anti_adjust_stack_and_probe): Update calls to
11951 plus_constant.
11952
11953 * alias.c (canon_rtx): Likewise.
11954 (init_alias_analysis): Likewise.
11955 * builtins.c (expand_builtin_return_addr)
11956 (expand_builtin_setjmp_setup, expand_builtin_longjmp)
11957 (expand_builtin_nonlocal_goto, expand_builtin_update_setjmp_buf)
11958 (expand_builtin_apply_args_1, expand_builtin_apply, expand_movstr)
11959 (expand_builtin_stpcpy): Likewise.
11960 * calls.c (save_fixed_argument_area, restore_fixed_argument_area)
11961 (compute_argument_addresses, internal_arg_pointer_based_exp)
11962 (expand_call, emit_library_call_value_1): Likewise.
11963 * cfgexpand.c (expand_one_stack_var_at, expand_debug_expr): Likewise.
11964 * combine-stack-adj.c (try_apply_stack_adjustment): Likewise.
11965 * combine.c (combine_simplify_rtx, force_to_mode): Likewise.
11966 * cse.c (insert_const_anchor, find_reg_offset_for_const)
11967 (use_related_value, fold_rtx): Likewise.
11968 * cselib.c (cselib_subst_to_values): Likewise.
11969 * dse.c (record_store, check_mem_read_rtx): Likewise.
11970 * dwarf2out.c (rtl_for_decl_location, gen_variable_die): Likewise.
11971 * emit-rtl.c (adjust_address_1): Likewise.
11972 * except.c (sjlj_emit_function_enter)
11973 (expand_builtin_extract_return_addr)
11974 (expand_builtin_frob_return_addr): Likewise.
11975 * expmed.c (expand_divmod): Likewise.
11976 * expr.c (move_by_pieces, store_by_pieces, store_by_pieces_1)
11977 (emit_move_resolve_push, push_block, emit_push_insn, store_expr)
11978 (expand_expr_addr_expr_1, expand_expr_real_1): Likewise.
11979 * function.c (assign_stack_local_1)
11980 (instantiate_virtual_regs_in_rtx): Likewise.
11981 * optabs.c (prepare_cmp_insn): Likewise.
11982 * recog.c (offsettable_address_addr_space_p): Likewise.
11983 * reload.c (find_reloads_address, form_sum)
11984 (find_reloads_subreg_address): Likewise.
11985 * reload1.c (init_reload, eliminate_regs_1)
11986 (eliminate_regs_in_insn): Likewise.
11987 * simplify-rtx.c (simplify_unary_operation_1)
11988 (simplify_binary_operation_1, simplify_plus_minus): Likewise.
11989 * var-tracking.c (compute_cfa_pointer, prepare_call_arguments)
11990 (vt_add_function_parameter): Likewise.
11991
11992 * config/alpha/alpha.h (EH_RETURN_HANDLER_RTX): Likewise.
11993 * config/alpha/vms.h (EH_RETURN_HANDLER_RTX): Likewise.
11994 * config/alpha/alpha.c (alpha_legitimize_address_1)
11995 (get_unaligned_address, alpha_expand_unaligned_load)
11996 (alpha_expand_unaligned_store, alpha_expand_unaligned_load_words)
11997 (alpha_expand_unaligned_store_words, alpha_expand_block_clear)
11998 (alpha_expand_builtin_establish_vms_condition_handler)
11999 (alpha_setup_incoming_varargs, emit_frame_store_1)
12000 (alpha_expand_prologue, alpha_expand_epilogue)
12001 (alpha_use_linkage): Likewise.
12002 * config/alpha/alpha.md: Likewise.
12003
12004 * config/arm/arm.c (arm_trampoline_init, legitimize_pic_address)
12005 (arm_load_pic_register, arm_pic_static_addr, arm_legitimize_address)
12006 (thumb_legitimize_address, arm_gen_load_multiple_1)
12007 (arm_gen_store_multiple_1, arm_gen_multiple_op, gen_ldm_seq)
12008 (gen_stm_seq, gen_const_stm_seq, arm_block_move_unaligned_straight)
12009 (arm_block_move_unaligned_loop, arm_gen_movmemqi, arm_reload_in_hi)
12010 (arm_reload_out_hi, arm_reorg, vfp_emit_fstmd, emit_multi_reg_push)
12011 (emit_sfm, thumb_set_frame_pointer, arm_expand_prologue)
12012 (thumb1_emit_multi_reg_push, thumb1_expand_prologue)
12013 (thumb_expand_movmemqi, arm_set_return_address)
12014 (thumb_set_return_address): Likewise.
12015 * config/arm/arm.md: Likewise.
12016
12017 * config/avr/avr.c (avr_incoming_return_addr_rtx)
12018 (avr_prologue_setup_frame, expand_epilogue)
12019 (avr_const_address_lo16): Likewise.
12020
12021 * config/bfin/bfin.h (EH_RETURN_HANDLER_RTX): Likewise.
12022 * config/bfin/bfin.c (setup_incoming_varargs, bfin_load_pic_reg)
12023 (bfin_expand_prologue, bfin_trampoline_init, bfin_expand_call)
12024 (bfin_output_mi_thunk): Likewise.
12025
12026 * config/c6x/c6x.c (c6x_initialize_trampoline)
12027 (c6x_output_mi_thunk): Likewise.
12028
12029 * config/cr16/cr16.h (EH_RETURN_HANDLER_RTX): Likewise.
12030 * config/cr16/cr16.c (cr16_create_dwarf_for_multi_push): Likewise.
12031
12032 * config/cris/cris.c (cris_return_addr_rtx, cris_split_movdx)
12033 (cris_expand_prologue, cris_expand_epilogue, cris_gen_movem_load)
12034 (cris_emit_movem_store, cris_trampoline_init): Likewise.
12035 * config/cris/cris.md: Likewise.
12036
12037 * config/darwin.c (machopic_indirect_data_reference)
12038 (machopic_legitimize_pic_address): Likewise.
12039
12040 * config/epiphany/epiphany.c (epiphany_emit_save_restore)
12041 (epiphany_expand_prologue, epiphany_expand_epilogue)
12042 (epiphany_trampoline_init): Likewise.
12043 * config/epiphany/epiphany.md: Likewise.
12044
12045 * config/fr30/fr30.c (fr30_move_double): Likewise.
12046
12047 * config/frv/frv.c (frv_dwarf_store, frv_expand_prologue)
12048 (frv_expand_block_move, frv_expand_block_clear, frv_return_addr_rtx)
12049 (frv_index_memory, unspec_got_name, frv_find_base_term)
12050 (frv_output_dwarf_dtprel): Likewise.
12051
12052 * config/h8300/h8300.c (h8300_push_pop, h8300_return_addr_rtx)
12053 (h8300_swap_into_er6, h8300_swap_out_of_er6): Likewise.
12054
12055 * config/i386/i386.h (RETURN_ADDR_RTX): Likewise.
12056 * config/i386/i386.c (setup_incoming_varargs_64)
12057 (setup_incoming_varargs_ms_64, choose_baseaddr)
12058 (ix86_emit_save_reg_using_mov, ix86_adjust_stack_and_probe)
12059 (ix86_emit_probe_stack_range, ix86_expand_prologue)
12060 (ix86_emit_restore_reg_using_pop, ix86_emit_leave)
12061 (ix86_expand_epilogue, legitimize_pic_address, ix86_legitimize_address)
12062 (ix86_split_long_move, ix86_expand_movmem, ix86_expand_setmem)
12063 (ix86_static_chain, ix86_trampoline_init, x86_this_parameter)
12064 (x86_output_mi_thunk): Likewise.
12065 * config/i386/i386.md: Likewise.
12066
12067 * config/ia64/ia64.c (ia64_expand_load_address)
12068 (ia64_expand_tls_address, ia64_expand_move, ia64_split_tmode)
12069 (do_spill, ia64_trampoline_init): Likewise.
12070
12071 * config/iq2000/iq2000.c (iq2000_va_start)
12072 (iq2000_emit_frame_related_store, iq2000_expand_prologue)
12073 (iq2000_expand_eh_return, iq2000_setup_incoming_varargs)
12074 (iq2000_print_operand, iq2000_legitimize_address): Likewise.
12075
12076 * config/lm32/lm32.c (lm32_setup_incoming_varargs): Likewise.
12077
12078 * config/m32c/m32c.c (m32c_return_addr_rtx)
12079 (m32c_expand_insv): Likewise.
12080
12081 * config/m32r/m32r.c (m32r_setup_incoming_varargs)
12082 (m32r_legitimize_pic_address, m32r_print_operand)
12083 (m32r_print_operand_address): Likewise.
12084
12085 * config/m68k/linux.h (FINALIZE_TRAMPOLINE): Likewise.
12086 * config/m68k/m68k.h (RETURN_ADDR_RTX): Likewise.
12087 (EH_RETURN_HANDLER_RTX): Likewise.
12088 * config/m68k/m68k.c (m68k_emit_movem, m68k_expand_prologue)
12089 (m68k_expand_epilogue, legitimize_pic_address)
12090 (m68k_output_mi_thunk): Likewise.
12091 * config/m68k/m68k.md: Likewise.
12092
12093 * config/mcore/mcore.c (mcore_expand_prolog): Likewise.
12094 (mcore_expand_epilog): Likewise.
12095 * config/mcore/mcore.md: Likewise.
12096
12097 * config/mep/mep.c (mep_allocate_initial_value)
12098 (mep_expand_prologue, mep_expand_epilogue): Likewise.
12099
12100 * config/microblaze/microblaze.c (double_memory_operand)
12101 (microblaze_block_move_loop): Likewise.
12102
12103 * config/mips/mips.c (mips_strip_unspec_address, mips_add_offset)
12104 (mips_setup_incoming_varargs, mips_va_start, mips_block_move_loop)
12105 (mips_print_operand, mips16e_save_restore_reg, mips_save_restore_reg)
12106 (mips_expand_prologue, mips_epilogue_set_cfa)
12107 (mips_expand_epilogue): Likewise.
12108 * config/mips/mips.md: Likewise.
12109
12110 * config/mmix/mmix.c (mmix_dynamic_chain_address, mmix_return_addr_rtx)
12111 (mmix_expand_prologue, mmix_expand_epilogue): Likewise.
12112
12113 * config/mn10300/mn10300.c (mn10300_gen_multiple_store)
12114 (mn10300_builtin_saveregs, mn10300_trampoline_init): Likewise.
12115
12116 * config/moxie/moxie.h (INCOMING_RETURN_ADDR_RTX): Likewise.
12117 (EH_RETURN_HANDLER_RTX): Likewise.
12118 * config/moxie/moxie.c (moxie_static_chain): Likewise.
12119
12120 * config/pa/pa.c (legitimize_pic_address, hppa_legitimize_address)
12121 (store_reg, set_reg_plus_d, pa_expand_prologue, load_reg)
12122 (pa_return_addr_rtx, hppa_builtin_saveregs)
12123 (pa_trampoline_init): Likewise.
12124 * config/pa/pa.md: Likewise.
12125
12126 * config/pdp11/pdp11.c (pdp11_expand_epilogue): Likewise.
12127
12128 * config/picochip/picochip.c (picochip_static_chain): Likewise.
12129
12130 * config/rs6000/rs6000.h (RS6000_SAVE_TOC): Likewise.
12131 * config/rs6000/rs6000.c (rs6000_legitimize_address)
12132 (setup_incoming_varargs, print_operand, rs6000_return_addr)
12133 (rs6000_emit_eh_reg_restore, rs6000_emit_probe_stack_range)
12134 (rs6000_emit_epilogue)
12135 (rs6000_machopic_legitimize_pic_address): Likewise.
12136
12137 * config/rx/rx.c (gen_rx_rtsd_vector, gen_rx_popm_vector): Likewise.
12138
12139 * config/s390/s390.h (INITIAL_FRAME_ADDRESS_RTX): Likewise.
12140 (DYNAMIC_CHAIN_ADDRESS): Likewise.
12141 * config/s390/s390.c (s390_decompose_address, legitimize_pic_address)
12142 (s390_delegitimize_address, print_operand, annotate_constant_pool_refs)
12143 (replace_constant_pool_ref, s390_return_addr_rtx, s390_back_chain_rtx)
12144 (save_fpr, restore_fpr, save_gprs, restore_gprs, s390_emit_prologue)
12145 (s390_emit_epilogue, s390_function_profiler): Likewise.
12146 * config/s390/s390.md: Likewise.
12147
12148 * config/score/score.c (score_add_offset, score_prologue): Likewise.
12149
12150 * config/sh/sh.c (expand_block_move, push_regs, sh_builtin_saveregs)
12151 (sh_output_mi_thunk): Likewise.
12152 * config/sh/sh.md: Likewise.
12153
12154 * config/sparc/sparc.h (DYNAMIC_CHAIN_ADDRESS, FRAME_ADDR_RTX)
12155 (RETURN_ADDR_RTX, INCOMING_RETURN_ADDR_RTX): Likewise.
12156 * config/sparc/sparc.c (sparc_legitimize_pic_address)
12157 (sparc_emit_probe_stack_range, emit_save_or_restore_regs)
12158 (emit_window_save, sparc_flat_expand_prologue, sparc_struct_value_rtx)
12159 (emit_and_preserve): Likewise.
12160 * config/sparc/sparc.md: Likewise.
12161
12162 * config/spu/spu.h (DYNAMIC_CHAIN_ADDRESS): Likewise.
12163 * config/spu/spu.c (spu_expand_insv, spu_machine_dependent_reorg)
12164 (spu_setup_incoming_varargs, ea_load_store_inline)
12165 (spu_expand_load): Likewise.
12166
12167 * config/stormy16/stormy16.c (xstormy16_expand_prologue)
12168 (combine_bnp): Likewise.
12169
12170 * config/tilegx/tilegx.h (DYNAMIC_CHAIN_ADDRESS): Likewise.
12171 * config/tilegx/tilegx.c (tilegx_setup_incoming_varargs)
12172 (tilegx_expand_unaligned_load, tilegx_trampoline_init): Likewise.
12173
12174 * config/tilepro/tilepro.h (DYNAMIC_CHAIN_ADDRESS): Likewise.
12175 * config/tilepro/tilepro.c (tilepro_setup_incoming_varargs)
12176 (tilepro_expand_unaligned_load, tilepro_trampoline_init): Likewise.
12177
12178 * config/v850/v850.c (expand_prologue, expand_epilogue): Likewise.
12179 * config/v850/v850.md: Likewise.
12180
12181 * config/vax/elf.h (EH_RETURN_STACKADJ_RTX): Likewise.
12182 (EH_RETURN_HANDLER_RTX): Likewise.
12183 * config/vax/vax.h (DYNAMIC_CHAIN_ADDRESS, RETURN_ADDR_RTX): Likewise.
12184 * config/vax/vax.c (vax_add_reg_cfa_offset, vax_expand_prologue)
12185 (print_operand_address, vax_trampoline_init): Likewise.
12186
12187 * config/xtensa/xtensa.c (xtensa_expand_prologue, xtensa_return_addr)
12188 (xtensa_function_value_regno_p): Likewise.
12189
12190 2012-05-04 Andrew Pinski <apinski@cavium.com>
12191
12192 * expr.c (get_def_for_expr_class): New function.
12193 (convert_tree_comp_to_rtx): New function.
12194 (expand_cond_expr_using_cmove): New function.
12195 (expand_expr_real_2 <case COND_EXPR>): Call
12196 expand_cond_expr_using_cmove first and return if it succeeds.
12197 Remove the check for HAVE_conditional_move since we should have
12198 already converted it to a conditional move.
12199 * config/i386/i386.c (ix86_expand_int_movcc): Disallow comparison
12200 modes of DImode for 32bits and TImode.
12201
12202 2012-05-04 Steven Bosscher <steven@gcc.gnu.org>
12203
12204 PR other/29442
12205 * read-md.c (fprint_md_ptr_loc, fprint_c_condition): New functions.
12206 (print_md_ptr_loc, print_c_condition): Use them.
12207 * read-md.h (fprint_md_ptr_loc, fprint_c_condition): New prototypes.
12208 * genattrtab.c (attr_file_name, dfa_file_name, latency_file_name,
12209 attr_file, dfa_file, latency_file): New global variables.
12210 (write_attr_valueq, write_attr_set, write_attr_case, write_attr_value,
12211 write_upcase, write_indent, write_length_unit_log, write_test_expr,
12212 write_attr_get, write_insn_cases, write_eligible_delay,
12213 write_const_num_delay_slots): Accept FILE pointer and toss it around.
12214 Update all callers.
12215 (write_header, open_outfile, handle_arg): New funcions.
12216 (make_automaton_attrs): Write prototypes as extern to the output
12217 files.
12218 (main): Use init_rtx_reader_args_cb with handle_arg to take 3 file
12219 names from the command line. Open the output files and write out
12220 internal functions for DFA functions to dfa_file_name, insn latency
12221 functions to latency_file_name, and everything else to attr_file.
12222 * Makefile.in (OBJS): Add insn-dfatab.o and insn-latencytab.o.
12223 (BACKEND): Build libbackend first.
12224 (MOSTLYCLEANFILES): Add insn-dfatab.c and insn-latencytab.c.
12225 (.PRECIOUS): Likewise.
12226 (insn-dfatab.o): New rule.
12227 (insn-latencytab.o): New rule.
12228 (simple_rtl_generated_c): Do not include insn-attrtab.c.
12229 (s-attrtab): New rule.
12230
12231 2012-05-04 Steven Bosscher <steven@gcc.gnu.org>
12232
12233 * rtl.def (ATTR_FLAG): Remove probability indicating flags.
12234 * genattr.c (main): Remove ATTR_FLAG_likely, ATTR_FLAG_unlikely,
12235 ATTR_FLAG_very_likely, and ATTR_FLAG_very_unlikely.
12236 * reorg.c (get_jump_flags): Do not set the removed flags.
12237
12238 * doc/md.texi (attr_flag): Update for abovementioned changes.
12239
12240 2012-05-04 Uros Bizjak <ubizjak@gmail.com>
12241
12242 PR target/53228
12243 * config/i386/i386.h (X86_ARCH_CMOV): Rename from X86_ARCH_CMOVE.
12244 (TARGET_CMOV): Rename from TARGET_CMOVE.
12245 (TARGET_CMOVE): New define.
12246 * config/i386/i386.c (ix86_option_override_internal): Use TARGET_CMOV.
12247 Do not set TARGET_CMOVE here.
12248
12249 2012-05-04 Dodji Seketeli <dodji@redhat.com>
12250
12251 Enable -Wunused-local-typedefs when -Wall or -Wunused is on
12252 * opts.c (finish_options): Activate -Wunused-local-typedefs if
12253 -Wunused is activated.
12254 * doc/invoke.texi: Update blurb of -Wunused-local-typedefs.
12255
12256 2012-05-04 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
12257
12258 * config/s390/s390.md (*movmem_short, *clrmem_short)
12259 (*cmpmem_short): Move the mode check from the insn condition to
12260 the match_scratch.
12261
12262 2012-05-04 Ulrich Weigand <ulrich.weigand@linaro.org>
12263
12264 PR tree-optimization/52633
12265 * tree-vect-patterns.c (vect_vect_recog_func_ptrs): Swap order of
12266 vect_recog_widen_shift_pattern and vect_recog_over_widening_pattern.
12267 (vect_recog_over_widening_pattern): Remove handling of code that was
12268 already detected as over-widening pattern. Remove special handling
12269 of "unsigned" cases. Instead, support general case of conversion
12270 of the shift result to another type.
12271
12272 2012-05-04 Ulrich Weigand <ulrich.weigand@linaro.org>
12273
12274 * tree-vect-patterns.c (vect_single_imm_use): New function.
12275 (vect_recog_widen_mult_pattern): Use it instead of open-coding loop.
12276 (vect_recog_over_widening_pattern): Likewise.
12277 (vect_recog_widen_shift_pattern): Likewise.
12278
12279 2012-05-04 Ulrich Weigand <ulrich.weigand@linaro.org>
12280
12281 * tree-vect-patterns.c (vect_same_loop_or_bb_p): New function.
12282 (vect_handle_widen_op_by_const): Use it instead of open-coding test.
12283 (vect_recog_widen_mult_pattern): Likewise.
12284 (vect_operation_fits_smaller_type): Likewise.
12285 (vect_recog_over_widening_pattern): Likewise.
12286 (vect_recog_widen_shift_pattern): Add to vect_same_loop_or_bb_p test.
12287
12288 2012-05-04 Richard Guenther <rguenther@suse.de>
12289
12290 PR lto/50602
12291 * lto-wrapper.c (merge_and_complain): Complain about mismatches
12292 of -freg-struct-return and -fpcc-struct-return.
12293 (run_gcc): Pass through -freg-struct-return and -fpcc-struct-return
12294 from the input file options and ignore those from the link
12295 command line.
12296
12297 2012-05-04 Richard Guenther <rguenther@suse.de>
12298
12299 PR tree-optimization/53168
12300 * tree-ssa-pre.c (phi_translate_1): Only handle type-punned
12301 memory reads when the result is a constant we can pun.
12302
12303 2012-05-04 Richard Guenther <rguenther@suse.de>
12304
12305 * common.opt (flto-report): Do not mark as Optimization.
12306
12307 2012-05-04 Eric Botcazou <ebotcazou@adacore.com>
12308
12309 PR target/48496
12310 * recog.c (constrain_operands): If extra constraints are present, also
12311 accept pseudo-registers with equivalent memory locations during reload.
12312
12313 2012-05-04 Olivier Hainque <hainque@adacore.com>
12314
12315 * collect2.c (may_unlink_output_file): New global.
12316 (maybe_unlink): Honor it.
12317 * collect2.h: Add extern for it.
12318 * tlink.c (do_tlink): Set it to true if the link succeeded.
12319
12320 2012-05-04 Olivier Hainque <hainque@adacore.com>
12321
12322 * gcc.c (eval_spec_function): Finalize/restore the current string
12323 obstack state as part of the context push/pop operations.
12324
12325 2012-05-04 Bin Cheng <bin.cheng@arm.com>
12326
12327 PR rtl-optimization/52804
12328 * reload1.c (reload_reg_reaches_end_p): Check whether successor
12329 reload with type RELOAD_FOR_INPUT_ADDRESS kills reload register
12330 of current one with type RELOAD_FOR_INPADDR_ADDRESS.
12331 Same stands for reloads with type RELOAD_FOR_OUTPUT_ADDRESS and
12332 RELOAD_FOR_OUTADDR_ADDRESS.
12333
12334 2012-05-04 Manuel López-Ibáñez <manu@gcc.gnu.org>
12335
12336 PR c++/24985
12337 * tree-diagnostic.c (maybe_unwind_expanded_macro_loc): Show caret
12338 for macro expansion.
12339
12340 2012-05-03 Manuel López-Ibáñez <manu@gcc.gnu.org>
12341
12342 * flags.h (flag_permissive): Do not declare.
12343 * diagnostic.c (diagnostic_report_diagnostic): Handle fpermissive
12344 option specially.
12345 * toplev.c (flag_permissive): Do not define.
12346 * c-tree.h (system_header_p): Delete unused.
12347
12348 2012-05-03 David S. Miller <davem@davemloft.net>
12349
12350 PR target/52684
12351 * config/sparc/sparc.c (emit_soft_tfmode_libcall): If we pass a
12352 MEM directly into a libcall, mark it's MEM_EXPR as addressable.
12353 (sparc_emit_float_lib_cmp): Likewise.
12354
12355 2012-05-03 Michael Meissner <meissner@linux.vnet.ibm.com>
12356
12357 PR target/53199
12358 * config/rs6000/rs6000.md (bswapdi splitters): If
12359 -mavoid-indexed-addresses (or -mcpu=power6 which sets it by
12360 default) is used, generate an alternate sequence that does not
12361 depend on using indexed addressing.
12362
12363 2012-05-03 Jason Merrill <jason@redhat.com>
12364
12365 * gengtype.c (write_types): Fix warning message.
12366 (write_local): Likewise.
12367
12368 2012-05-02 Jason Merrill <jason@redhat.com>
12369
12370 * dwarf2out.c (struct external_ref, build_local_stub): New.
12371 (hash_external_ref, external_ref_eq, lookup_external_ref): New.
12372 (optimize_external_refs, optimize_external_refs_1): New.
12373 (change_AT_die_ref): New.
12374 (clone_as_declaration): Add DW_AT_signature when cloning a declaration.
12375 (build_abbrev_table): Take the external refs hashtable.
12376 (output_comp_unit): Get it from optimize_external_refs and pass it in.
12377
12378 2012-05-03 Jan Hubicka <jh@suse.cz>
12379
12380 PR middle-end/53093
12381 * tree-emutls.c (new_emutls_decl): Fix handling of aliases.
12382
12383 2012-05-03 Jan Hubicka <jh@suse.cz>
12384
12385 PR middle-end/53106
12386 * ipa.c (cgraph_remove_unreachable_nodes): Fix handling of clones.
12387
12388 2012-05-03 Jason Merrill <jason@redhat.com>
12389
12390 * dwarf2out.c (die_struct): Add comdat_type_p flag. Use it instead of
12391 use_debug_types to discriminate the die_id union.
12392 (print_die, assign_symbol_names, copy_decls_walk): Likewise.
12393 (build_abbrev_table, output_die): Likewise.
12394 (prune_unused_types_walk_attribs): Likewise.
12395 (generate_type_signature, copy_declaration_context): Set it.
12396 (remove_child_or_replace_with_skeleton): Set it.
12397 (dwarf2out_start_source_file, dwarf2out_end_source_file): Don't
12398 check use_debug_types.
12399 (dwarf2out_finish): Do break_out_includes after .debug_types.
12400
12401 2012-05-03 Jason Merrill <jason@redhat.com>
12402
12403 * dwarf2out.c (modified_type_die): Use scope_die_for.
12404 (gen_type_die_with_usage, dwarf2out_finish): Likewise.
12405 (uses_local_type_r, uses_local_type): New.
12406 (scope_die_for): Keep a type that uses a local type in local scope.
12407 Use get_context_die for namespace and type scope.
12408
12409 2012-05-03 Jason Merrill <jason@redhat.com>
12410
12411 * config/i386/i386.c (ix86_code_end): Set DECL_IGNORED_P on the
12412 pc thunk.
12413 * dwarf2out.c (output_aranges): Skip DECL_IGNORED_P functions.
12414 (dwarf2out_finish): Likewise.
12415
12416 2012-05-03 Martin Jambor <mjambor@suse.cz>
12417
12418 * builtins.c (get_object_alignment_1): Return whether we can determine
12419 the alignment or conservatively assume byte alignment. Return the
12420 alignment by reference. Use get_pointer_alignment_1 for dereference
12421 alignment.
12422 (get_pointer_alignment_1): Return whether we can determine the
12423 alignment or conservatively assume byte alignment. Return the
12424 alignment by reference. Use get_ptr_info_alignment to get SSA name
12425 alignment.
12426 (get_object_alignment): Update call to get_object_alignment_1.
12427 (get_object_or_type_alignment): Likewise, fall back to type alignment
12428 only when it returned false.
12429 (get_pointer_alignment): Update call to get_pointer_alignment_1.
12430 * fold-const.c (get_pointer_modulus_and_residue): Update call to
12431 get_object_alignment_1.
12432 * ipa-prop.c (ipa_modify_call_arguments): Update call to
12433 get_pointer_alignment_1.
12434 * tree-sra.c (build_ref_for_offset): Likewise, fall back to the type
12435 of MEM_REF or TARGET_MEM_REF only when it returns false.
12436 * tree-ssa-ccp.c (get_value_from_alignment): Update call to
12437 get_object_alignment_1.
12438 (ccp_finalize): Use set_ptr_info_alignment.
12439 * tree.h (get_object_alignment_1): Update declaration.
12440 (get_pointer_alignment_1): Likewise.
12441 * gimple-pretty-print.c (dump_gimple_phi): Use get_ptr_info_alignment.
12442 (dump_gimple_stmt): Likewise.
12443 * tree-flow.h (ptr_info_def): Updated comments of fields align and
12444 misalign.
12445 (get_ptr_info_alignment): Declared.
12446 (mark_ptr_info_alignment_unknown): Likewise.
12447 (set_ptr_info_alignment): Likewise.
12448 (adjust_ptr_info_misalignment): Likewise.
12449 * tree-ssa-address.c (copy_ref_info): Use new access functions to get
12450 and set alignment of SSA names.
12451 * tree-ssa-loop-ivopts.c (rewrite_use_nonlinear_expr): Call
12452 mark_ptr_info_alignment_unknown.
12453 * tree-ssanames.c (get_ptr_info_alignment): New function.
12454 (mark_ptr_info_alignment_unknown): Likewise.
12455 (set_ptr_info_alignment): Likewise.
12456 (adjust_ptr_info_misalignment): Likewise.
12457 (get_ptr_info): Call mark_ptr_info_alignment_unknown.
12458 * tree-vect-data-refs.c (vect_create_addr_base_for_vector_ref):
12459 Likewise.
12460 (bump_vector_ptr): Likewise.
12461 * tree-vect-stmts.c (create_array_ref): Use set_ptr_info_alignment.
12462 (vectorizable_store): Likewise.
12463 (vectorizable_load): Likewise.
12464
12465 2012-05-03 Michael Matz <matz@suse.de>
12466
12467 * basic-block.h (struct rtl_bb_info, struct gimple_bb_info): Move
12468 in front of basic_block_def.
12469 (struct basic_block_def): Make il.gimple the full struct, not a
12470 pointer.
12471 (__assert_gimple_bb_smaller_rtl_bb): Asserting typedef.
12472
12473 * cfgexpand.c (expand_gimple_basic_block): Clear all il.gimple members.
12474 * gimple-iterator.c (gimple_stmt_iterator): Don't special case
12475 NULL il.gimple, which can't happen anymore.
12476 * gimple.h (bb_seq): il.gimple can't be NULL.
12477 (bb_seq_add): Ditto.
12478 (set_bb_seq): Adjust.
12479 (gsi_start_bb, gsi_last_bb): Tidy.
12480 * lto-streamer-in.c (make_new_block): Don't zero members that
12481 are zeroed already, don't allocate a gimple_bb_info.
12482 * tree-cfg.c (create_bb): Don't allocate a gimple_bb_info.
12483 (remove_bb): Clear all il.gimple members.
12484 (gimple_verify_flow_info): Adjust for flat il.gimple.
12485 * tree-flow-inline.h (phi_nodes, phi_nodes_ptr, set_phi_nodes): Adjust.
12486
12487 * coretypes.h (const_gimple_seq): Remove typedef.
12488 * gimple.h (gimple_seq_first): Take gimple_seq.
12489 (gimple_seq_first_stmt): Ditto.
12490 (gimple_seq_last): Ditto.
12491 (gimple_seq_last_stmt): Ditto.
12492 (gimple_seq_empty_p): Ditto.
12493
12494 2012-05-03 Richard Guenther <rguenther@suse.de>
12495
12496 * tree-ssa-pre.c (valid_in_sets): Remove checking of trapping
12497 operations.
12498 (prune_clobbered_mems): Do it here. Do not uselessly sort expressions.
12499 (compute_avail): Do not add possibly trapping operations to
12500 EXP_GEN if they might not be executed in the block.
12501
12502 2012-05-03 Uros Bizjak <ubizjak@gmail.com>
12503
12504 * config/alpha/elf.h (MAX_OFILE_ALIGNMENT): Remove.
12505
12506 2012-05-03 Steven Bosscher <steven@gcc.gnu.org>
12507
12508 * tree-switch-conversion.c (gen_inbound_check): Free post-dominance
12509 information as early as possible. Update dominance info instead of
12510 discarding it.
12511
12512 2012-05-03 Richard Guenther <rguenther@suse.de>
12513
12514 * tree-ssa-pre.c (debug_bitmap_sets_for): New function.
12515 (union_contains_value): Remove.
12516 (vro_valid_in_sets): Likewise.
12517 (op_valid_in_sets): New function.
12518 (valid_in_sets): Use op_valid_in_sets.
12519 (insert_into_preds_of_block): Move dumping ...
12520 (do_regular_insertion): ... here.
12521 (do_partial_partial_insertion): ... and here. Dump that
12522 we've found a partial partial redundancy.
12523 (insert): Dump the current insert iteration.
12524
12525 2012-05-03 Jakub Jelinek <jakub@redhat.com>
12526
12527 PR plugins/53126
12528 * gcc-ar.c (main): If GCC_EXEC_PREFIX is set in env,
12529 append program name to it and pass that as first argument
12530 to make_relative_prefix. Always pass standard_libexec_prefix
12531 as last argument to make_relative_prefix. If
12532 make_relative_prefix returns NULL, fall back to
12533 standard_libexec_prefix.
12534
12535 PR debug/53174
12536 * tree-predcom.c (remove_stmt): Call reset_debug_uses on stmts being
12537 removed.
12538
12539 PR target/53187
12540 * config/arm/arm.c (arm_select_cc_mode): If x has MODE_CC class
12541 mode, return that mode.
12542
12543 PR target/53194
12544 * config/i386/i386-c.c (ix86_target_macros_internal): Don't
12545 define __ATOMIC_HLE_* macros here.
12546 (ix86_target_macros): But here, using cpp_define_formatted.
12547
12548 2012-05-03 Richard Guenther <rguenther@suse.de>
12549
12550 PR tree-optimization/53144
12551 * tree-ssa-sccvn.c (vn_reference_lookup_or_insert_constant_for_pieces):
12552 Rename to ...
12553 (vn_reference_lookup_or_insert_for_pieces): ... this. Properly deal
12554 with SSA name values.
12555 (vn_reference_lookup_3): Adjust callers.
12556
12557 2012-05-03 Ganesh Gopalasubramanian <Ganesh.Gopalasubramanian@amd.com>
12558
12559 * config/i386/driver-i386.c (host_detect_local_cpu): Reset
12560 has_fma4 for AMD processors with both fma3 and fma4 support.
12561
12562 2012-05-03 Kirill Yukhin <kirill.yukhin@intel.com>
12563
12564 PR target/53201
12565 * config/i386/driver-i386.c (host_detect_local_cpu): Add space to
12566 "-mno-hle".
12567
12568 2012-05-03 Michael Matz <matz@suse.de>
12569
12570 PR bootstrap/53197
12571 * tree-ssa-dse.c (dse_optimize_stmt): Take pointer to iterator.
12572 (dse_enter_block): Properly iterate the whole sequence even
12573 if the last statement was removed.
12574
12575 2012-05-02 Steven Bosscher <steven@gcc.gnu.org>
12576
12577 * config/alpha/vms.h (SUBTARGET_OVERRIDE_OPTIONS): For pic code,
12578 unset flag_jump_tables.
12579 * stmt.c (expand_case): Remove special flag_pic case conditional
12580 on ASM_OUTPUT_ADDR_DIFF_ELT not being defined.
12581
12582 2012-05-02 Ulrich Weigand <ulrich.weigand@linaro.org>
12583
12584 * common/config/s390/s390-common.c (s390_option_optimization_table):
12585 Enable -fsched-pressure using -fsched-pressure-algorithm=model by
12586 default when optimizing.
12587
12588 2012-05-02 Martin Jambor <mjambor@suse.cz>
12589
12590 PR lto/52605
12591 * dwarf2out.c (dwarf2out_decl): Only lookup die representing context
12592 of a variable when the contect is a function.
12593
12594 2012-05-02 Michael Matz <matz@suse.de>
12595
12596 * coretypes.h (gimple_seq, const_gimple_seq): Typedef as gimple.
12597 * gimple.h (struct gimple_seq_node_d, struct gimple_seq_d): Remove.
12598 (const_gimple_seq_node): Remove.
12599 (gimple_seq_node): Typedef as gimple.
12600 (struct gimple_statement_base): Add next and prev members,
12601 adjust all WORD markers in using structs.
12602 (union gimple_statement_d): Link via gsbase.next field for GC and PCH.
12603 (gimple_seq_first, gimple_seq_first_stmt, gimple_seq_last,
12604 gimple_seq_last_stmt): Adjust as gimple_seq, gimple_seq_node and
12605 gimple are the same.
12606 (gimple_seq_set_last, gimple_seq_set_first): Don't allocate
12607 gimple_seq, adjust.
12608 (gimple_init_singleton): New function.
12609 (gsi_start_1, gsi_last_1, gsi_end_p, gsi_one_before_end_p): Adjust.
12610 (gsi_next, gsi_prev): Adjust, handle prev cyclic list correctly.
12611 (gsi_stmt): Adjust.
12612 (gsi_stmt_ptr): Remove.
12613 (enum gimple_alloc_kind): Remove gimple_alloc_kind_seq member.
12614
12615 * gimple-iterator.c (update_bb_for_stmts): Take last parameter
12616 again, adjust for above changes.
12617 (update_call_edge_frequencies): Adjust for above changes.
12618 (gsi_insert_seq_nodes_before): Rewrite for new data structure.
12619 (gsi_insert_seq_nodes_after): Ditto.
12620 (gsi_split_seq_after): Ditto.
12621 (gsi_set_stmt): Ditto.
12622 (gsi_split_seq_before): Ditto.
12623 (gsi_remove): Ditto.
12624 (gsi_insert_seq_before_without_update): Don't free sequence.
12625 (gsi_insert_seq_after_without_update): Ditto.
12626 (gsi_replace): Assert some more invariants.
12627 (gsi_insert_before_without_update, gsi_insert_after_without_update):
12628 Tidy.
12629 (gsi_for_stmt): Don't search for stmt.
12630 (gsi_insert_on_edge_immediate): Tidy.
12631
12632 * gimple.c (gimple_alloc_k): Remove "sequences".
12633 (gimple_seq_cache): Remove.
12634 (gimple_alloc_stat): Make stmt a singleton sequence.
12635 (gimple_seq_alloc, gimple_seq_free): Remove.
12636 (gimple_assign_set_rhs_with_ops_1): Ensure new stmt is a singleton.
12637 (gimple_copy): Ditto.
12638 * gimplify.c (gimplify_cleanup_point_expr): Use gsi_set_stmt,
12639 create iterator from correct sequence.
12640 * tree-phinodes.c (make_phi_node): Make stmt a singleton.
12641
12642 2012-05-02 Michael Matz <matz@suse.de>
12643
12644 * gimple.h (gimple_stmt_iterator <seq>): Make it be pointer to
12645 gimple_seq.
12646 (gimple_seq_set_last, gimple_seq_set_first): Take pointer to
12647 sequence, lazily allocate it.
12648 (bb_seq_addr): New function.
12649 (gsi_start_1): Rename from gsi_start, but take pointer to sequence.
12650 (gsi_start): Macro to wrap gsi_start_1 taking pointer of argument.
12651 (gsi_none): New function.
12652 (gsi_start_bb): Adjust.
12653 (gsi_last_1): Rename from gsi_last, but take pointer to sequence.
12654 (gsi_last): Macro to wrap gsi_last_1 taking pointer of argument.
12655 (gsi_last_bb): Adjust.
12656 (gsi_seq): Adjust.
12657 * tree-flow-inline.h (phi_nodes_ptr): New function.
12658
12659 * gimple-iterator.c (gsi_insert_seq_nodes_before): Adjust to
12660 datastructure and interface change.
12661 (gsi_insert_seq_before_without_update): Ditto.
12662 (gsi_insert_seq_nodes_after): Ditto.
12663 (gsi_insert_seq_after_without_update): Ditto.
12664 (gsi_split_seq_after): Ditto, don't use gimple_seq_alloc.
12665 (gsi_split_seq_before): Ditto.
12666 (gsi_start_phis): Adjust.
12667 * tree-vect-loop.c (vect_determine_vectorization_factor): Use gsi_none.
12668 (vect_transform_loop): Ditto.
12669 * gimple.c (gimple_seq_add_stmt, gimple_seq_add_seq,
12670 gimple_seq_copy): Don't use gimple_seq_alloc.
12671 * gimplify.c (gimple_seq_add_stmt_without_update): Ditto.
12672 (gimplify_seq_add_seq): Ditto.
12673 * lto-streamer-in.c (make_new_block): Ditto.
12674 * tree-cfg.c (create_bb): Ditto.
12675 * tree-sra.c (initialize_parameter_reductions): Ditto.
12676
12677 2012-05-02 Michael Matz <matz@suse.de>
12678
12679 * gimple.h (gimple_seq_first, gimple_seq_first_stmt, gimple_seq_last,
12680 gimple_seq_last_stmt, gimple_seq_set_last, gimple_seq_set_first,
12681 gimple_seq_empty_p, gimple_seq_alloc_with_stmt, bb_seq,
12682 set_bb_seq): Move down to after gimple_statement_d definition.
12683
12684 2012-05-02 Michael Matz <matz@suse.de>
12685
12686 * gimple-fold.c (gimplify_and_update_call_from_tree): Use
12687 gsi_replace_with_seq, instead of inserting itself.
12688 * gimple-iterator.c (gsi_replace_with_seq): New function.
12689 * tree-ssa-forwprop.c (forward_propagate_comparison): Take
12690 iterator instead of statement, advance it.
12691 (ssa_forward_propagate_and_combine): Adjust call to above.
12692
12693 2012-05-02 Michael Matz <matz@suse.de>
12694
12695 * tree-phinodes.c (add_phi_node_to_bb): Tidy, don't use
12696 gimple_seq_alloc.
12697 * omp-low.c (finalize_task_copyfn): Don't use gimple_seq_alloc.
12698 * tree-nested.c (walk_gimple_omp_for): Ditto.
12699 * trans-mem.c (lower_transaction): Ditto.
12700 * tree-eh.c (do_return_redirection): Ditto.
12701 (do_goto_redirection): Ditto.
12702 (lower_try_finally_switch): Ditto.
12703 * gimplify.c (gimplify_stmt): Ditto.
12704 (gimplify_scan_omp_clauses): Ditto.
12705 (gimplify_omp_for): Ditto.
12706 (gimplify_function_tree): Ditto.
12707 * gimple-fold.c (gimplify_and_update_call_from_tree): Ditto.
12708 * tree-mudflap.c (mf_decl_cache_locals): Ditto.
12709 (mf_build_check_statement_for): Ditto.
12710 (mx_register_decls): Ditto.
12711 * graphite-sese-to-poly.c (remove_invariant_phi): Ditto,
12712 and don't use itertors to append.
12713 (insert_stmts): Ditto.
12714 (insert_out_of_ssa_copy): Ditto.
12715 (insert_out_of_ssa_copy_on_edge): Ditto.
12716
12717 2012-05-02 Michael Matz <matz@suse.de>
12718
12719 * gimple.h (gimple_bind_body_ptr): New function.
12720 (gimple_bind_body): Use it.
12721 (gimple_catch_handler): Use gimple_catch_handler_ptr.
12722 (gimple_eh_filter_failure_ptr): New function.
12723 (gimple_eh_filter_failure): Use it.
12724 (gimple_eh_else_n_body_ptr): New function.
12725 (gimple_eh_else_n_body): Use it.
12726 (gimple_eh_else_e_body_ptr): New function.
12727 (gimple_eh_else_e_body): Use it.
12728 (gimple_try_eval_ptr): New function.
12729 (gimple_try_eval): Use it.
12730 (gimple_try_cleanup_ptr): New function.
12731 (gimple_try_cleanup): Use it.
12732 (gimple_wce_cleanup_ptr): New function.
12733 (gimple_wce_cleanup): Use it.
12734 (gimple_omp_body_ptr): New function.
12735 (gimple_omp_body): Use it.
12736 (gimple_omp_for_pre_body_ptr): New function.
12737 (gimple_omp_for_pre_body): Use it.
12738 (gimple_transaction_body_ptr): New function.
12739 (gimple_transaction_body): Use it.
12740 (gsi_split_seq_before): Adjust to return nothing and take pointer
12741 to sequence.
12742 (gsi_set_stmt): Declare.
12743 (gsi_replace_with_seq): Declare.
12744 (walk_gimple_seq_mod): Declare.
12745 * function.h (struct function <gimple_body>): Use typedef gimple_seq.
12746
12747 * gimple-iterator.c (gsi_set_stmt): New function.
12748 (gsi_split_seq_before): Return new sequence via pointer argument.
12749 (gsi_replace): Use gsi_set_stmt.
12750
12751 * tree-ssa-loop-im.c (move_computations_stmt): First remove
12752 then insert stmt.
12753 * tree-complex.c (update_complex_components_on_edge): Don't copy gsi.
12754 * tree-phinodes.c (resize_phi_node): Don't resize stmt in-place,
12755 return new stmt.
12756 (reserve_phi_args_for_new_edge): Change call to above,
12757 use gsi_set_stmt.
12758
12759 * omp-low.c (lower_omp): Change prototype to take pointer to sequence.
12760 (lower_rec_input_clauses): Use gimple_seq_add_seq instead of
12761 iterators. Adjust call to lower_omp.
12762 (lower_lastprivate_clauses): Adjust call to lower_omp.
12763 (lower_reduction_clauses): Ditto.
12764 (expand_omp_taskreg): Nullify non-cfg body of child_fn.
12765 (lower_omp_sections): Don't explicitely count sequence length,
12766 nullify lowered bodies earlier, ensure stmts are part of only
12767 one sequence, adjust call to lower_omp.
12768 (lower_omp_single): Ensure stmts are part of only one sequence,
12769 adjust call to lower_omp.
12770 (lower_omp_master): Ditto.
12771 (lower_omp_ordered): Ditto.
12772 (lower_omp_critical): Ditto.
12773 (lower_omp_for): Ditto.
12774 (lower_omp_taskreg): Ditto, tidy.
12775 (lower_omp_1): Adjust calls to lower_omp.
12776 (execute_lower_omp): Ditto.
12777 (lower_omp): Adjust to take pointer to sequence.
12778 (diagnose_sb_2): Use walk_gimple_seq_mod.
12779 (diagnose_omp_structured_block_errors): Ditto and set possibly
12780 changed function body.
12781 * gimple-low.c (lower_function_body): Set function body after
12782 it stabilizes.
12783 (lower_sequence): Adjust to take pointer to sequence.
12784 (lower_omp_directive): Ensure stmt isn't put twice into the
12785 sequence, adjust call to lower_sequence.
12786 (lower_stmt): Adjust calls to lower_sequence.
12787 (lower_gimple_bind): Ditto.
12788 (gimple_try_catch_may_fallthru): Call gsi_start with lvalue.
12789 * tree-nested.c (walk_body): Take pointer to sequence, use
12790 walk_gimple_seq_mod.
12791 (walk_function): Adjust call to walk_body, set possibly changed body.
12792 (walk_gimple_omp_for): Adjust calls to walk_body.
12793 (convert_nonlocal_omp_clauses): Ditto.
12794 (convert_nonlocal_reference_stmt): Ditto.
12795 (convert_local_omp_clauses): Ditto.
12796 (convert_local_reference_stmt): Ditto.
12797 (convert_tramp_reference_stmt): Ditto.
12798 (convert_gimple_call): Ditto.
12799 (convert_nl_goto_reference): Use local iterator copy.
12800 * gimple.c (walk_gimple_seq_mod): Renamed from walk_gimple_seq,
12801 but taking pointer to sequence, ensure gsi_start is called with
12802 callers lvalue.
12803 (walk_gimple_seq): New wrapper around walk_gimple_seq_mod,
12804 asserting that the sequence head didn't change.
12805 (walk_gimple_stmt): Replace all calls to walk_gimple_seq with
12806 walk_gimple_seq_mod.
12807 * trans-mem.c (lower_transaction): Use walk_gimple_seq_mod.
12808 (execute_lower_tm): Ditto, and set possibly changed body.
12809 * tree-eh.c (lower_eh_constructs_1): Take pointer to sequence,
12810 call gsi_start with that lvalue.
12811 (replace_goto_queue_stmt_list): Ditto.
12812 (replace_goto_queue_1): Adjust calls to replace_goto_queue_stmt_list.
12813 (replace_goto_queue): Ditto.
12814 (lower_try_finally_nofallthru): Adjust calls to lower_eh_constructs_1.
12815 (lower_try_finally_onedest): Ditto.
12816 (lower_try_finally_copy): Ditto.
12817 (lower_try_finally_switch): Ditto.
12818 (lower_try_finally): Ditto.
12819 (lower_eh_filter): Ditto.
12820 (lower_eh_must_not_throw): Ditto.
12821 (lower_cleanup): Ditto.
12822 (lower_eh_constructs_2): Ditto.
12823 (lower_catch): Ditto, and ensure gsi_start is called with lvalue.
12824 (lower_eh_constructs): Adjust calls to lower_eh_constructs_1, and
12825 set possibly changed body.
12826 (optimize_double_finally): Call gsi_start with lvalue.
12827
12828 * tree-cfg.c (make_blocks): Adjust call to gsi_split_seq_before.
12829 (gimple_split_block): Ditto.
12830 (gimple_merge_blocks): Use gsi_start_phis.
12831 (move_stmt_r): Use walk_gimple_seq_mod.
12832 * tree-ssa-dse.c (dse_enter_block): Use gsi_last_bb.
12833 * cgraphbuild.c (build_cgraph_edges): Use gsi_start_phis.
12834 (rebuild_cgraph_edges): Ditto.
12835 (cgraph_rebuild_references): Ditto.
12836 * ipa-prop.c (ipa_analyze_params_uses): Ditto.
12837 * tree-inline.c (copy_phis_for_bb): Ditto.
12838 * tree-ssa-dce.c: Ditto.
12839
12840 * cgraphunit.c (cgraph_analyze_function): Use gimple_has_body_p.
12841
12842 2012-05-02 Kirill Yukhin <kirill.yukhin@intel.com>
12843 Andi Kleen <ak@linux.intel.com>
12844
12845 * coretypes.h (MEMMODEL_MASK): New.
12846 * builtins.c (get_memmodel): Add val. Call target.memmodel_check
12847 and return new variable.
12848 (expand_builtin_atomic_exchange): Mask memmodel values.
12849 (expand_builtin_atomic_compare_exchange): Ditto.
12850 (expand_builtin_atomic_load): Ditto.
12851 (expand_builtin_atomic_store): Ditto.
12852 (expand_builtin_atomic_clear): Ditto.
12853 * doc/extend.texi: Mention port-dependent memory model flags.
12854 * config/i386/cpuid.h (bit_HLE): New.
12855 * config/i386/driver-i386.c (host_detect_local_cpu): Detect
12856 HLE support.
12857 * config/i386/i386-protos.h (ix86_generate_hle_prefix): New.
12858 * config/i386/i386-c.c (ix86_target_macros_internal): Set HLE defines.
12859 (ix86_target_string)<-mhle>: New.
12860 (ix86_valid_target_attribute_inner_p) <OPT_mhle>: Ditto.
12861 * config/i386/i386.c (ix86_target_string) <OPTION_MASK_ISA_HLE>: New.
12862 (ix86_valid_target_attribute_inner_p) <OPT_mhle>: Ditto.
12863 (ix86_option_override_internal) <PTA_HLE>: New switch, set it
12864 enabled for generic, generic64 and core-avx2.
12865 (ix86_print_operand): Generate HLE lock prefixes.
12866 (ix86_memmodel_check): New.
12867 (TARGET_MEMMODEL_CHECK): Ditto.
12868 * config/i386/i386.h (OPTION_ISA_HLE): Ditto.
12869 (IX86_HLE_ACQUIRE): Ditto.
12870 (IX86_HLE_RELEASE): Ditto.
12871 * config/i386/i386.h (ix86_generate_hle_prefix): Ditto.
12872 * config/i386/i386.opt (mhle): Ditto.
12873 * config/i386/sync.md(atomic_compare_and_swap<mode>): Pass
12874 success model to instruction emitter.
12875 (atomic_fetch_add<mode>): Ditto.
12876 (atomic_exchange<mode>): Ditto.
12877 (atomic_add<mode>): Ditto.
12878 (atomic_sub<mode>): Ditto.
12879 (atomic_<code><mode>): Ditto.
12880 (*atomic_compare_and_swap_doubledi_pic): Ditto.
12881 (atomic_compare_and_swap_single<mode>): Define and use argument
12882 for success model.
12883 (atomic_compare_and_swap_double<mode>): Ditto.
12884 * configure.ac: Check if assembler support HLE prefixes.
12885 * configure: Regenerate.
12886 * config.in: Ditto.
12887
12888 2012-05-02 Steven Bosscher <steven@gcc.gnu.org>
12889
12890 PR middle-end/53153
12891 * gimplify.c (preprocess_case_label_vec_for_gimple): New function,
12892 split out from ...
12893 (gimplify_switch_expr): ... here.
12894 * gimple.h (preprocess_case_label_vec_for_gimple): Add prototype.
12895 * tree-ssa-forwprop.c (simplify_gimple_switch_label_vec): New function
12896 to clean up case labels with values outside the index type range.
12897 (simplify_gimple_switch): Call it if something changed.
12898 Remove strange and unnecessary assert.
12899
12900 2012-05-02 Richard Guenther <rguenther@suse.de>
12901
12902 * fold-const.c (div_if_zero_remainder): sizetypes no longer
12903 sign-extend.
12904 (int_const_binop_1): New worker for int_const_binop with
12905 overflowable parameter. Pass it through to force_fit_type_double.
12906 (int_const_binop): Wrap around int_const_binop_1 with overflowable
12907 equal to one.
12908 (size_binop_loc): Call int_const_binop_1 with overflowable equal
12909 to minus one, forcing overflow detection for even unsigned types.
12910 (extract_muldiv_1): Remove bogus TYPE_IS_SIZETYPE special-casing.
12911 (fold_binary_loc): Call try_move_mult_to_index with signed offset.
12912 * stor-layout.c (initialize_sizetypes): sizetypes no longer
12913 sign-extend.
12914 (layout_type): For zero-sized arrays ignore overflow on the
12915 size calculations.
12916 * tree-ssa-ccp.c (bit_value_unop_1): Likewise.
12917 (bit_value_binop_1): Likewise.
12918 * tree.c (double_int_to_tree): Likewise.
12919 (double_int_fits_to_tree_p): Likewise.
12920 (force_fit_type_double): Likewise.
12921 (host_integerp): Likewise.
12922 (int_fits_type_p): Likewise.
12923 * varasm.c (output_constructor_regular_field): Sign-extend the
12924 field-offset to cater for negative offsets produced by the Ada
12925 frontend.
12926 * omp-low.c (extract_omp_for_data): Convert the loop step to
12927 signed for pointer adjustments.
12928
12929 2012-05-02 Richard Guenther <rguenther@suse.de>
12930
12931 * tree.c (valid_constant_size_p): New function.
12932 * tree.h (valid_constant_size_p): Declare.
12933 * cfgexpand.c (expand_one_var): Adjust check for too large
12934 variables by using valid_constant_size_p.
12935 * varasm.c (assemble_variable): Likewise.
12936
12937 * c-decl.c (grokdeclarator): Properly check for sizes that
12938 cover more than half of the address-space.
12939
12940 2012-05-02 Jakub Jelinek <jakub@redhat.com>
12941
12942 PR tree-optimization/53163
12943 * tree-ssa-phiopt.c (cond_if_else_store_replacement): Don't ignore
12944 return value from compute_all_dependences.
12945
12946 PR rtl-optimization/53160
12947 * ree.c (combine_reaching_defs): Handle the case where cand->insn
12948 has been modified by ree pass already.
12949
12950 2012-05-01 Ian Lance Taylor <iant@google.com>
12951
12952 PR c/37303
12953 * c-decl.c (build_compound_literal): Make the decl readonly if it
12954 an array of a readonly type.
12955 * gimplify.c (gimplify_compound_literal_expr): Add fallback
12956 parameter. Change all callers. If the decl is not addressable
12957 and is not an l-value, make it readonly.
12958
12959 2012-05-01 Bernd Schmidt <bernds@codesourcery.com>
12960
12961 * ira.c (allocated_reg_info_size): New static variable.
12962 (expand_reg_info): Manage it. Call
12963 setup_preferred_alternate_classes_for_new_pseudos.
12964 (ira): Don't do it here. Remove local allocated_reg_info_size,
12965 set the global before calling find_moveable_pseudos.
12966 (find_moveable_pseudos): Call expand_reg_info rather than
12967 resize_reg_info.
12968
12969 2012-05-01 Richard Henderson <rth@redhat.com>
12970
12971 * common.opt (fsync-libcalls): New.
12972 * doc/invoke.texi: Document it.
12973 * optabs.c (init_sync_libfuncs): Honor it.
12974
12975 2012-05-01 Kenneth Zadeck <zadeck@naturalbridge.com>
12976 Richard Sandiford <r.sandiford@uk.ibm.com>
12977
12978 PR rtl-optimization/52543
12979 * Makefile.in (lower-subreg.o, target-globals.o): Depend on
12980 lower-subreg.h.
12981 * lower-subreg.h: New file.
12982 * target-globals.h (this_target_lower_subreg): Declare.
12983 (target_globals): Add lower_subreg;
12984 (restore_target_globals): Restore this_target_lower_subreg.
12985 * target-globals.c: Include it.
12986 (default_target_globals): Add default_target_lower_subreg.
12987 (save_target_globals): Initialize target_lower_subreg.
12988 * rtl.h (init_lower_subreg): Added declaration.
12989 * toplev.c (backend_init_target): Call initializer for lower-subreg
12990 pass.
12991 * lower-subreg.c (LOG_COSTS, FORCE_LOWERING): New macros.
12992 (default_target_lower_subreg): New variable.
12993 (this_target_lower_subreg): Likewise.
12994 (twice_word_mode, choices): New macros.
12995 (shift_cost, compute_splitting_shift, compute_costs)
12996 (init_lower_subreg): New functions.
12997 (resolve_simple_move): Add speed_p argument. Check choices.
12998 (find_pseudo_copy): Don't check the mode size here.
12999 (resolve_simple_move): Assert the mode size.
13000 (find_decomposable_shift_zext): Add speed_p argument and return
13001 a bool. Check choices.
13002 (resolve_shift_zext): Add comment.
13003 (dump_shift_choices, dump_choices): New functions.
13004 (decompose_multiword_subregs): Dump list of profitable
13005 transformations. Add code to skip non profitable transformations.
13006 Update calls to simple_move and find_decomposable_shift_zext.
13007
13008 2012-05-01 Ian Bolton <ian.bolton@arm.com>
13009 Sameera Deshpande <sameera.deshpande@arm.com>
13010 Greta Yorsh <greta.yorsh@arm.com>
13011
13012 * config/arm/arm-protos.h (thumb_unexpanded_epilogue): Rename to...
13013 (thumb1_unexpanded_epilogue): ...this.
13014 * config/arm/arm.c (thumb_unexpanded_epilogue): Rename to...
13015 (thumb1_unexpanded_epilogue): ...this.
13016 * config/arm/arm.md (thumb_unexpanded_epilogue): Rename to...
13017 (thumb1_unexpanded_epilogue): ...this.
13018
13019 2012-05-01 Richard Earnshaw <rearnsha@arm.com>
13020
13021 * arm/linux-eabi.h (GLIBC_DYNAMIC_LINKER_DEFAULT): Avoid ifdef
13022 comparing enumeration values. Update comments.
13023
13024 2012-05-01 Alan Modra <amodra@gmail.com>
13025
13026 PR target/53038
13027 * config/rs6000/rs6000.c (load_lr_save, restore_saved_lr,
13028 load_cr_save, add_crlr_cfa_restore): New functions.
13029 (rs6000_restore_saved_cr): Rename to..
13030 (restore_saved_cr): ..this. Add cfa_restore notes for cr.
13031 (rs6000_emit_epilogue): Use new functions. Adjust condition
13032 for emitting lr and cr cfa_restore. Emit cfa_restores for fp
13033 regs when using out-of-line restore only when shrink wrapping.
13034
13035 2012-04-30 Uros Bizjak <ubizjak@gmail.com>
13036
13037 PR middle-end/53136
13038 * ipa-prop.c (ipa_print_node_jump_functions): Wrap multiple
13039 calls to cgraph_node_name in xstrdup.
13040 (ipa_make_edge_direct_to_target): Ditto.
13041 * cgraph.c (dump_cgraph_node): Ditto.
13042 * tree-sra.c (convert_callers_for_node): Ditto.
13043 * lto-symtab.c (lto_cgraph_replace_node): Ditto.
13044 * ipa-cp.c (perhaps_add_new_callers): Ditto.
13045 * cgraphunit.c (cgraph_redirect_edge_call_stmt_to_callee): Ditto.
13046 (cgraph_materialize_all_clones): Ditto.
13047 * ipa-inline.c (report_inline_failed_reason): Ditto.
13048 (want_early_inline_function_p): Ditto.
13049 (edge_badness): Ditto.
13050 (update_edge_key): Ditto.
13051 (flatten_function): Ditto.
13052 (ipa_inline): Ditto.
13053 (inline_always_inline_functions): Ditto.
13054 (early_inline_small_functions): Ditto.
13055
13056 2012-04-30 Uros Bizjak <ubizjak@gmail.com>
13057
13058 PR target/53141
13059 * config/i386/i386.md (*umul<mode><dwi>3_1): Switch places of
13060 constraints 0 and 1.
13061
13062 012-04-30 Jan Hubicka <jh@suse.cz>
13063
13064 * cgraph.c (ld_plugin_symbol_resolution_names): Move to symtab.c
13065 (cgraph_asm_nodes, cgraph_asm_last_node): Move to cgraphunit.c
13066 (cgraph_add_to_same_comdat_group): Remove.
13067 (cgraph_add_asm_node): Move to cgraphunit.c.
13068 (cgraph_make_decl_local): Move to symtab.c
13069 (cgraph_make_node_local_1): Update.
13070 (cgraph_can_remove_if_no_direct_calls_and): Update.
13071 (used_from_object_file_p): Update.
13072 (resolution_used_from_other_file_p): Move to symtab.c
13073 (cgraph_used_from_object_file_p): move to symtab.c
13074 (verify_cgraph_node): Verify same comdat groups.
13075 * cgraph.h (cgraph_asm_node): Rename to ...
13076 (asm_node): ... this one.
13077 (cgraph_asm_nodes): Rename to ...
13078 (asm_nodes): ... this one.
13079 (symtab_add_to_same_comdat_group): New function.
13080 (symtab_dissolve_same_comdat_group_list): New function.
13081 (symtab_used_from_object_file_p): Declare.
13082 (symtab_make_decl_local): Declare.
13083 (cgraph_add_to_same_comdat_group): Remove.
13084 (cgraph_add_asm_node): Remove.
13085 (cgraph_used_from_object_file_p, varpool_used_from_object_file_p):
13086 Remove.
13087 (cgraph_finalize_compilation_unit): Rename to ...
13088 (finalize_compilation_unit): ... this one.
13089 (cgraph_optimize): Rename to ....
13090 (compile): ... this one.
13091 (add_asm_node): Declare.
13092 (fixup_same_cpp_alias_visibility): Declare.
13093 (cgraph_make_decl_local): Remove.
13094 (varpool_assemble_pending_decls): Rename to ...
13095 (varpool_output_variables): ... this one.
13096 (varpool_remove_unreferenced_decls): Remove.
13097 * ipa-inline-transform.c (clone_inlined_nodes): Dissolve comdat groups.
13098 (preserve_function_body_p): Make static.
13099 * toplev.c (compile_file): Update comments; update.
13100 * cgraphunit.c: Update comments.
13101 (cgraph_expand_all_functions): Rename to ...
13102 (expand_all_functions): ... this one; update.
13103 (cgraph_mark_functions_to_output): Rename to ...
13104 (mark_functions_to_output): ... this one; cleanup.
13105 (cgraph_output_pending_asms): Remove prototype.
13106 (asm_nodes, asm_last_node): New static vars.
13107 (cgraph_process_new_functions): Update.
13108 (cgraph_reset_node): Cleanup; add comment.
13109 (cgraph_add_new_function): Update.
13110 (cgraph_output_pending_asms): Rename to ...
13111 (output_asm_statements): ... this one.
13112 (add_asm_node): New function.
13113 (fixup_same_cpp_alias_visibility): New function based on code
13114 in cgraph_analyze_function.
13115 (cgraph_analyze_function): Use it.
13116 (cgraph_order_sort): Update.
13117 (cgraph_output_in_order): Update.
13118 (cgraph_function_versioning): Update.
13119 (cgraph_optimize): Rename to ...
13120 (compile): ... this one; initialize streamer hooks here.
13121 (cgraph_finalize_compilation_unit): Rename to ...
13122 (finalize_compilation_unit): ... this one; do not initialize streamer
13123 hook here.
13124 * lto-streamer-out.c (lto_output_toplevel_asms): Update.
13125 * dwarf2out.c: Update ocmment.
13126 * optimize.c (maybe_clone_body): Use symtab_add_to_same_comdat_group.
13127 * method.c (use_thunk): Likewise.
13128 * semantics.c (maybe_add_lambda_conv_op): Likewise.
13129 * decl2.c (maybe_emit_vtables): Likewise.
13130 (cp_write_global_declarations): Use finalize_compilation_unit.
13131 * parser.c (cp_parser_asm_definition): Use add_asm_node.
13132 * lto-streamer-in.c (lto_input_toplevel_asms): Use add_asm_node
13133 * c-decl.c (c_write_global_declarations): Use
13134 finalize_compilation_unit.
13135 * langhooks.c (write_global_declarations): Update.
13136 * ipa.c (cgraph_externally_visible_p): Update.
13137 (dissolve_same_comdat_group_list): Remove.
13138 (function_and_variable_visibility): Update.
13139 * symtab.c: Inlcude lto-streamer.h and rtl.h
13140 (ld_plugin_symbol_resolution_names): New.
13141 (symtab_add_to_same_comdat_group): New.
13142 (symtab_dissolve_same_comdat_group_list): New.
13143 (resolution_used_from_other_file_p): Move here from cgraph.c
13144 (symtab_used_from_object_file_p): New.
13145 (symtab_make_decl_local): New.
13146 * passes.c (register_pass): Update comments.
13147 * c-parser.c (c_parser_asm_definition): Update.
13148 * varpool.c (varpool_analyze_node): Use
13149 fixup_same_cpp_alias_visibility.
13150 (varpool_remove_unreferenced_decls): Make static.
13151 (varpool_assemble_pending_decls): Rename to ...
13152 (varpool_output_variables): ... this one; call
13153 varpool_remove_unreferenced_decls.
13154 (varpool_used_from_object_file_p): Remove.
13155
13156 2012-04-30 Marc Glisse <marc.glisse@inria.fr>
13157
13158 PR c++/51033
13159 * c-typeck.c (build_array_ref): Call
13160 convert_vector_to_pointer_for_subscript.
13161 * doc/extend.texi (Vector Extensions): Subscripting not just for C.
13162
13163 2012-04-30 Uros Bizjak <ubizjak@gmail.com>
13164
13165 * config/i386/i386.md (and<mode>3): Change runtime operand mode checks
13166 to compile-time "mode == <MODE>mode" checks.
13167 (and splitter): Ditto.
13168
13169 2012-04-30 Richard Henderson <rth@redhat.com>
13170
13171 * config/arm/arm.md (UNSPEC_LL): New.
13172 * config/arm/sync.md (atomic_loaddi, atomic_loaddi_1): New.
13173 (arm_load_exclusivedi): Use %H0.
13174
13175 2012-04-30 Jason Merrill <jason@redhat.com>
13176
13177 * dwarf2out.c (comdat_symbol_id): Add const.
13178 (union die_symbol_or_type_node): Add const to die_symbol.
13179 (output_die_symbol, output_die, output_comp_unit): Adjust.
13180
13181 2012-04-30 Andrew Stubbs <ams@codesourcery.com>
13182
13183 * config/arm/arm.md (negdi2): Use gen_negdi2_neon.
13184 * config/arm/neon.md (negdi2_neon): New insn.
13185 Also add splitters for core and NEON registers.
13186
13187 2012-04-30 Andrew Stubbs <ams@codesourcery.com>
13188
13189 * config/arm/arm.c (neon_valid_immediate): Allow const_int.
13190 (arm_print_operand): Add 'x' format.
13191 * config/arm/constraints.md (Dn): Allow const_int.
13192 * config/arm/neon.md (neon_mov<mode>): Use VDX to allow DImode.
13193 Use 'x' format to print constants.
13194 * config/arm/predicates.md (imm_for_neon_mov_operand): Allow const_int.
13195 * config/arm/vfp.md (movdi_vfp): Disable for const_int when neon
13196 is enabled.
13197 (movdi_vfp_cortexa8): Likewise.
13198
13199 2012-04-30 Ian Bolton <ian.bolton@arm.com>
13200 Sameera Deshpande <sameera.deshpande@arm.com>
13201 Greta Yorsh <greta.yorsh@arm.com>
13202
13203 * config/arm/arm-protos.h (ldm_stm_operation_p): New declaration.
13204 * config/arm/arm.c (ldm_stm_operation_p): New function.
13205 * config/arm/predicates.md (load_multiple_operation): Update predicate.
13206 (store_multiple_operation): Likewise.
13207
13208 * config/arm/arm-protos.h (ldm_stm_operation_p): New parameters.
13209 * config/arm/arm.c (ldm_stm_operation_p): New parameters.
13210 * config/arm/predicates.md (load_multiple_operation): Add arguments.
13211 (store_multiple_operation): Likewise.
13212
13213 2012-04-30 Uros Bizjak <ubizjak@gmail.com>
13214
13215 * config/i386/i386.md (and<mode>3): Expand masking operations with
13216 0xff, 0xffff or 0xffffffff immediates to corresponding zero_extend RTX.
13217 (and splitter): Split to DImode zero_extend RTX for DImode operand[0].
13218
13219 2012-04-30 Dodji Seketeli <dodji@redhat.com>
13220
13221 Add -Wvarargs option
13222 * builtins.c (fold_builtin_next_arg): Use OPT_Wvarargs as an
13223 argument for the various warning_at calls.
13224 * docs/invoke.texi: Update the documentation.
13225
13226 2012-04-30 Dodji Seketeli <dodji@redhat.com>
13227
13228 Switch -ftrack-macro-expansion=2 on by default.
13229 * docs/cppopts.texi: Adjust for enabling -ftrack-macro-expansion=2
13230 by default.
13231
13232 Fix va_start related location
13233 * builtins.c (fold_builtin_next_arg): Unwinds to the first
13234 location in real source code.
13235
13236 Make conversion warnings work on NULL with -ftrack-macro-expansion
13237 * input.h (expansion_point_location_if_in_system_header): Declare
13238 new function.
13239 * input.c (expansion_point_location_if_in_system_header): Define it.
13240
13241 Fix -Wuninitialized for -ftrack-macro-expansion
13242 * tree-ssa.c (warn_uninit): Use the spelling location of the variable
13243 declaration. Use linemap_location_before_p for source locations.
13244
13245 Strip "<built-in>" loc from displayed expansion context
13246 * input.c (expand_location_1): When expanding to spelling location
13247 in a context of a macro expansion, skip reserved system header
13248 locations. Update comments. * tree-diagnostic.c
13249 (maybe_unwind_expanded_macro_loc): Likewise.
13250
13251 Make expand_location resolve to locus in main source file
13252 * input.c (expand_location_1): New. Takes a parameter to choose
13253 whether to resolve the location to spelling or expansion point.
13254 Was factorized from ...
13255 (expand_location): ... here.
13256 (expand_location_to_spelling_point): New. Implemented in terms of
13257 expand_location_1.
13258 * diagnostic.c (diagnostic_build_prefix): Use the new
13259 expand_location_to_spelling_point instead of expand_location.
13260
13261 Fix PCH crash on GTYed pointer-to-scalar field of a struct
13262 * gengtype.c (write_types_process_field): Force second argument of
13263 the call to the PCH object hierarchy walker to be 'x'.
13264
13265 2012-04-30 Eric Botcazou <ebotcazou@adacore.com>
13266
13267 * config/i386/i386.c (ix86_handle_struct_attribute): Use the proper
13268 predicate to discriminate types.
13269
13270 2012-04-30 Manuel López-Ibáñez <manu@gcc.gnu.org>
13271
13272 * doc/invoke.texi (Wmissing-format-attribute): Document as an
13273 alias of Wsuggest-attribute=format.
13274 * c-typeck.c (convert_for_assignment): Replace
13275 Wmissing-format-attribute with Wsuggest-attribute=format.
13276 (digest_init): Likewise.
13277
13278 2012-04-29 Manuel López-Ibáñez <manu@gcc.gnu.org>
13279
13280 * opts.c (finish_options): Do not handle -Wmissing-noreturn here.
13281 * common.opt (Wmissing-noreturn): Alias of
13282 -Wsuggest-attribute=noreturn.
13283
13284 2012-04-29 Hans-Peter Nilsson <hp@axis.com>
13285
13286 PR target/53156
13287 * config/cris/cris.md (andqu): New peephole2.
13288 (andu): Tweak head comment.
13289
13290 2012-04-28 Joern Rennecke <joern.rennecke@embecosm.com>
13291 Steven Bosscher <steven@gcc.gnu.org>
13292 Maxim Kuvyrkov <maxim@codesourcery.com>
13293
13294 PR tree-optimization/38785
13295 * common.opt (ftree-partial-pre): New option.
13296 * doc/invoke.texi: Document it.
13297 * opts.c (default_options_table): Initialize flag_tree_partial_pre.
13298 * tree-ssa-pre.c (do_partial_partial_insertion): Insert only if it will
13299 benefit speed path.
13300 (execute_pre): Use flag_tree_partial_pre.
13301
13302 2012-04-27 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
13303
13304 PR target/52999
13305 * config/pa/pa.c (pa_legitimate_constant_p): Don't put function labels
13306 in constant pool.
13307
13308 2012-04-27 Ollie Wild <aaw@google.com>
13309
13310 * doc/invoke.texi (Wliteral-suffix): Document new option.
13311
13312 2012-04-27 Tom Tromey <tromey@redhat.com>
13313
13314 * dwarf2out.c (dwarf_stack_op_name): Use get_DW_OP_name.
13315 (dwarf_tag_name): Use get_DW_TAG_name.
13316 (dwarf_attr_name): Use get_DW_AT_name.
13317 (dwarf_form_name): Use get_DW_FORM_name.
13318 * dwarf2cfi.c (dwarf_cfi_name): Use get_DW_CFA_name.
13319
13320 2012-04-27 Paolo Bonzini <bonzini@gnu.org>
13321
13322 * tree-ssa-phiopt.c (conditional_replacement): Replace PHIs whose
13323 arguments are -1 and 0, by negating the result of the conditional.
13324
13325 2012-04-27 Paolo Bonzini <bonzini@gnu.org>
13326
13327 PR target/53138
13328 * config/i386/i386.md (x86_mov<mode>cc_0_m1_neg): Add clobber.
13329
13330 2012-04-27 Richard Guenther <rguenther@suse.de>
13331
13332 * tree-flow.h (is_hidden_global_store): Remove.
13333 * tree-ssa-sink.c (is_hidden_global_store): Likewise.
13334 * tree-ssa-alias.h (ref_may_alias_global_p): Declare.
13335 (stmt_may_clobber_global_p): Likewise.
13336 * tree-ssa-alias.c (ref_may_alias_global_p): New function.
13337 (stmt_may_clobber_global_p): Likewise.
13338 * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Call
13339 stmt_may_clobber_global_p.
13340 * tree-ssa-dse.c (dse_possible_dead_store_p): Likewise.
13341
13342 2012-04-27 Steven Bosscher <steven@gcc.gnu.org>
13343
13344 * cfg.c (disconnect_src): Do df_mark_solutions_dirty in the right
13345 place.
13346
13347 * tree-switch-conversion.c (struct switch_conv_info): Add range_max,
13348 reorganize some fields and update comments. Rename bit_test_uniq
13349 and bit_test_count to uniq resp. count. Remove bit_test_bb.
13350 (collect_switch_conv_info): New function, collects info about a
13351 GIMPLE_SWITCH into a struct switch_conv_info.
13352 (check_range): Simplify to use pre-recorded info. Fix think-o in
13353 range-branch ratio check.
13354 (check_process_case): Remove function.
13355 (check_all_empty_except_final): New function, verifies that all
13356 non-final basic blocks are empty.
13357 (process_switch): Simplify to use pre-recorded info. Call
13358 collect_switch_conv_info to do that. Assert that degenerate switch
13359 statements have been cleaned up.
13360
13361 2012-04-27 Marc Glisse <marc.glisse@inria.fr>
13362
13363 PR middle-end/27139
13364 * tree-ssa-forwprop.c (combine_conversions): Handle INT->FP->INT.
13365
13366 2012-04-25 Manuel López-Ibáñez <manu@gcc.gnu.org>
13367
13368 PR c/53130
13369 * c-typeck.c (pop_init_level): Use %qD instead of %qT.
13370
13371 2012-04-27 Tom de Vries <tom@codesourcery.com>
13372
13373 PR tree-optimization/51879
13374 * tree-ssa-sccvn.h (struct vn_reference_s): Add result_vdef field.
13375 * tree-ssa-sccvn.c (mark_use_processed): New function, factored out
13376 of ...
13377 (defs_to_varying): ... here. Don't set use_processed.
13378 (visit_reference_op_call): Handle gimple_vdef.
13379 Handle case that lhs is NULL_TREE.
13380 (visit_use): Use mark_use_processed. Handle calls with side-effect
13381 using visit_reference_op_call.
13382
13383 2012-04-26 Richard Sandiford <richard.sandiford@linaro.org>
13384
13385 * sched-deps.c (fixup_sched_groups): Rename to...
13386 (chain_to_prev_insn): ...this.
13387 (chain_to_prev_insn_p): New function.
13388 (deps_analyze_insn): Use it instead of SCHED_GROUP_P.
13389
13390 2012-04-26 Richard Sandiford <richard.sandiford@linaro.org>
13391
13392 * sched-int.h (_haifa_insn_data): Move priority_status.
13393 Add model_index.
13394 (INSN_MODEL_INDEX): New macro.
13395 * haifa-sched.c (insn_delay): New function.
13396 (sched_regno_pressure_class): Update commentary.
13397 (mark_regno_birth_or_death): Pass the liveness bitmap and
13398 pressure array as arguments, instead of using curr_reg_live and
13399 curr_reg_pressure. Only update the pressure if the bit in the
13400 liveness set has changed.
13401 (initiate_reg_pressure_info): Always trust the live-in set for
13402 SCHED_PRESSURE_MODEL.
13403 (initiate_bb_reg_pressure_info): Update call to
13404 mark_regno_birth_or_death.
13405 (dep_list_size): Take the list as argument.
13406 (calculate_reg_deaths): New function, extracted from...
13407 (setup_insn_reg_pressure_info): ...here.
13408 (MODEL_BAR): New macro.
13409 (model_pressure_data, model_insn_info, model_pressure_limit)
13410 (model_pressure_group): New structures.
13411 (model_schedule, model_worklist, model_insns, model_num_insns)
13412 (model_curr_point, model_before_pressure, model_next_priority):
13413 New variables.
13414 (MODEL_PRESSURE_DATA, MODEL_MAX_PRESSURE, MODEL_REF_PRESSURE)
13415 (MODEL_INSN_INFO, MODEL_INSN): New macros.
13416 (model_index, model_update_limit_points_in_group): New functions.
13417 (model_update_limit_points, model_last_use_except): Likewise.
13418 (model_start_update_pressure, model_update_pressure): Likewise.
13419 (model_recompute, model_spill_cost, model_excess_group_cost): Likewise.
13420 (model_excess_cost, model_dump_pressure_points): Likewise.
13421 (model_set_excess_costs): Likewise.
13422 (rank_for_schedule): Extend SCHED_PRIORITY_WEIGHTED ordering to
13423 SCHED_PRIORITY_MODEL. Use insn_delay. Use the order in the model
13424 schedule as an alternative tie-breaker. Update the call to
13425 dep_list_size.
13426 (ready_sort): Call model_set_excess_costs.
13427 (update_register_pressure): Update call to mark_regno_birth_or_death.
13428 Rely on that function to check liveness rather than doing it here.
13429 (model_classify_pressure, model_order_p, model_add_to_worklist_at)
13430 (model_remove_from_worklist, model_add_to_worklist, model_promote_insn)
13431 (model_add_to_schedule, model_analyze_insns, model_init_pressure_group)
13432 (model_record_pressure, model_record_pressures): New functions.
13433 (model_record_final_pressures, model_add_successors_to_worklist)
13434 (model_promote_predecessors, model_choose_insn): Likewise.
13435 (model_reset_queue_indices, model_dump_pressure_summary): Likewise.
13436 (model_start_schedule, model_finalize_pressure_group): Likewise.
13437 (model_end_schedule): Likewise.
13438 (schedule_insn): Say when we're scheduling the next instruction
13439 in the model schedule.
13440 (schedule_insn): Handle SCHED_PRESSURE_MODEL.
13441 (queue_to_ready): Do not add instructions that are
13442 MAX_SCHED_READY_INSNS beyond the current point of the model schedule.
13443 Always allow the next instruction in the model schedule to be added.
13444 (debug_ready_list): Print the INSN_REG_PRESSURE_EXCESS_COST_CHANGE
13445 and delay for SCHED_PRESSURE_MODEL too.
13446 (prune_ready_list): Extend SCHED_PRIORITY_WEIGHTED handling to
13447 SCHED_PRIORITY_MODEL, but also take the DFA into account.
13448 (schedule_block): Call model_start_schedule and model_end_schedule.
13449 Extend SCHED_PRIORITY_WEIGHTED stall handling to SCHED_PRIORITY_MODEL.
13450 (sched_init): Extend INSN_REG_PRESSURE_EXCESS_COST_CHANGE handling
13451 to SCHED_PRESSURE_MODEL, but don't allocate saved_reg_live or
13452 region_ref_regs.
13453 (sched_finish): Update accordingly.
13454 (fix_tick_ready): Extend INSN_REG_PRESSURE_EXCESS_COST_CHANGE handling
13455 to SCHED_PRESSURE_MODEL.
13456 (add_jump_dependencies): Update call to dep_list_size.
13457 (haifa_finish_h_i_d): Fix leak of max_reg_pressure.
13458 (haifa_init_insn): Extend INSN_REG_PRESSURE_EXCESS_COST_CHANGE handling
13459 to SCHED_PRESSURE_MODEL.
13460 * sched-deps.c (init_insn_reg_pressure_info): Likewise, but don't
13461 allocate INSN_MAX_REG_PRESSURE for SCHED_PRESSURE_MODEL.
13462 (sched_analyze_insn): Extend INSN_REG_PRESSURE_EXCESS_COST_CHANGE
13463 handling to SCHED_PRESSURE_MODEL.
13464
13465 2012-04-26 Richard Sandiford <richard.sandiford@linaro.org>
13466
13467 * common.opt (fsched-pressure-algorithm=): New option.
13468 * flag-types.h (sched_pressure_algorithm): New enum.
13469 * sched-int.h (sched_pressure_p): Replace with...
13470 (sched_pressure): ...this new variable.
13471 * haifa-sched.c (sched_pressure_p): Replace with...
13472 (sched_pressure): ...this new variable.
13473 (sched_regno_pressure_class, rank_for_schedule, ready_sort)
13474 (update_reg_and_insn_max_reg_pressure, schedule_insn)
13475 (debug_ready_list, prune_ready_list, schedule_block, sched_init)
13476 (sched_finish, fix_tick_ready, haifa_init_insn): Update accordingly.
13477 * sched-deps.c (init_insn_reg_pressure_info): Likewise.
13478 (sched_analyze_insn): Likewise.
13479 * sched-rgn.c (schedule_region): Likewise.
13480 * config/m68k/m68k.c (m68k_sched_variable_issue): Likewise.
13481
13482 2012-04-26 Bernd Schmidt <bernds@codesourcery.com>
13483
13484 * PR middle-end/52997
13485 * ira.c (find_moveable_pseudos): Call resize_reg_info.
13486
13487 PR middle-end/52940
13488 * machmode.h (CLASS_HAS_WIDER_MODES_P): True for MODE_PARTIAL_INT.
13489 * expr.c (convert_move): Honor unsignedp when extending partial int
13490 modes.
13491 * genmodes.c (complete_mode): Don't clear component field of partial
13492 int modes.
13493 (emit_mode_inner): Don't emit it however.
13494 (calc_wider_mode): Partial int modes widen to their component.
13495
13496 2012-04-26 David S. Miller <davem@davemloft.net>
13497
13498 * config/sparc/niagara4.md: New file.
13499 * config/sparc/sparc.md: Include it.
13500 * config/sparc/sparc.c (niagara4_costs): New processor costs.
13501 (sparc_option_override): Use it.
13502 (sparc_use_sched_lookahead): Return 2 for niagara4.
13503 (sparc_issue_rate): Likewise.
13504
13505 * config/sparc/sparc.md (attr type): Delete 'fgm_cmp'.
13506 (fpack16_vis, fpackfix_vis, fpack32_vis): Set type to fgm_pack.
13507 (fmul8x16_vis, fmul8x16au_vis, fmul8x16al_vis, fmul8sux16_vis,
13508 fmul8ulx16_vis, fmuld8sux16_vis, fmuld8ulx16_vis): Set type to fgm_mul.
13509 (alignaddrsi_vis, alignaddrdi_vis, alignaddrlsi_vis,
13510 alignaddrldi_vis): Set type to gsr.
13511 (pdist_vis, pdistn<mode>_vis): Set type to fgm_pdsit.
13512 (fcmp<code><GCM:gcm_name><P:mode>_vis, cmask8<P:mode>_vis,
13513 cmask16<P:mode>_vis, cmask32<P:mode>_vis, fchksm16_vis,
13514 v<vis3_shift_patname><mode>3, fmean16_vis,
13515 fp<plusminus_insn>64_vis, <vis3_addsub_ss_patname><mode>3,
13516 fucmp<code>8<P:mode>_vis): Set type to fga.
13517 * config/sparc/ultra1_2.md: Remove refrences to fgm_cmp.
13518 * config/sparc/niagara.md: Likewise.
13519 * config/sparc/niagara2.md: Likewise.
13520 * config/sparc/ultra3.md: Likewise, and fix type matching for
13521 us3_ialuX reservation.
13522
13523 2012-04-26 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
13524
13525 * reload.c (find_reloads): Change the loop nesting when trying an
13526 alternative with swapped operands.
13527
13528 2012-04-26 Manuel López-Ibáñez <manu@gcc.gnu.org>
13529
13530 * tree-diagnostic.c (maybe_unwind_expanded_macro_loc): Fix
13531 comment. Delete unused parameter first_exp_point_map.
13532 (virt_loc_aware_diagnostic_finalizer): Update call.
13533
13534 2012-04-26 Michael Hope <michael.hope@linaro.org>
13535 Richard Earnshaw <rearnsha@arm.com>
13536
13537 * config/arm/linux-eabi.h (GLIBC_DYNAMIC_LINKER_SOFT_FLOAT): Define.
13538 (GLIBC_DYNAMIC_LINKER_HARD_FLOAT): Define.
13539 (GLIBC_DYNAMIC_LINKER_DEFAULT): Define.
13540 (GLIBC_DYNAMIC_LINKER): Redefine to use the hard float path.
13541
13542 2012-04-25 Sriraman Tallam <tmsriram@google.com>
13543
13544 * doc/extend.texi: Document avx2 support.
13545 * config/i386/i386.c (fold_builtin_cpu): Add avx2.
13546
13547 2012-04-26 Hans-Peter Nilsson <hp@axis.com>
13548
13549 PR target/53120
13550 * config/cris/cris.md ("*andhi_lowpart_v32")
13551 ("*andqi_lowpart_v32"): Change first input-only operand from
13552 a (match_operand ...) to (match_dup 0). Drop alternatives with
13553 const_int-matching constraints for redundancy.
13554 ("*andhi_lowpart_non_v32", "*andqi_lowpart_non_v32"): Ditto. Drop
13555 three-operand alternative.
13556
13557 2012-04-25 Jakub Jelinek <jakub@redhat.com>
13558
13559 PR target/53110
13560 * config/i386/i386.md (and<mode>3): For andq $0xffffffff, reg
13561 instead expand it as zero extension.
13562
13563 2012-04-25 H.J. Lu <hongjiu.lu@intel.com>
13564
13565 PR debug/52857
13566 * dwarf2out.c (dbx_reg_number): Assert return value != INVALID_REGNUM.
13567
13568 2012-04-25 Jakub Jelinek <jakub@redhat.com>
13569
13570 * common.opt (flag_debug_types_section): Default to 0.
13571 (dwarf_version): Default to 4.
13572 (dwarf_record_gcc_switches): Default to 1.
13573 (dwarf_strict): Default to 0.
13574 * toplev.c (process_options): Don't handle dwarf_strict
13575 or dwarf_version here.
13576 * config/vxworks.c (vxworks_override_options): Don't
13577 test whether dwarf_strict or dwarf_version are negative,
13578 instead test !global_options_set.x_dwarf_*.
13579 * config/darwin.c (darwin_override_options): Default to
13580 dwarf_version 2.
13581 * doc/invoke.texi: Note that -gdwarf-4, -grecord-gcc-switches
13582 and -fno-debug-types-section are now the default.
13583
13584 2012-04-25 Jan Hubicka <jh@suse.cz>
13585
13586 * cgraphunit.c: Update toplevel comment.
13587 (tree_rest_of_compilation): Merge into cgraph_expand_function.
13588 (cgraph_analyze_function): Make static.
13589 (cgraph_decide_is_function_needed): Make static.
13590 (cgraph_add_new_function): Use expand_function instead of
13591 rest_of_compilation.
13592 (clone_of_p, verify_edge_count_and_frequency, cgraph_debug_gimple_stmt,
13593 verify_edge_corresponds_to_fndecl, verify_cgraph_node, verify_cgraph):
13594 Move to cgraph.c
13595 (cgraph_inline_p): Remove.
13596 (cgraph_preserve_function_body_p): Move to ipa-inline-transform.
13597 (init_cgraph): Add comment.
13598 * cgraphbuild.c (record_reference, mark_address, mark_load,
13599 mark_store): Do not call analyze_expr hook.
13600 * cgraph.c: Update toplevel comment.
13601 (clone_of_p, verify_edge_count_and_frequency, cgraph_debug_gimple_stmt,
13602 verify_edge_corresponds_to_fndecl, verify_cgraph_node, verify_cgraph):
13603 Move fere from cgraphunit.c
13604 (cgraph_mark_force_output_node): Move to cgraph.h
13605 * cgraph.h: Reorder so the comments match the function placement.
13606 (cgraph_analyze_function, cgraph_decide_is_function_needed): Remove.
13607 (cgraph_mark_force_output_node): Move here from cgraph.c
13608 * tree.c (free_lang_data): Do not clear analyze_expr hook.
13609 * ipa-inline-transform.c (preserve_function_body_p): New function.
13610 (inline_transform): Update.
13611 * langhooks.c (lhd_callgraph_analyze_expr): Remove.
13612 * langhooks.h (lang_hooks_for_callgraph): Remove.
13613 (lang_hooks): Remove callgraph.
13614 * tree-inline.c (expand_call_inline): Do not use cgraph_inline_p.
13615 * varpool.c: Remove out of date comment.
13616 * langhooks-def.h (lhd_callgraph_analyze_expr): Remove.
13617 (LANG_HOOKS_CALLGRAPH_ANALYZE_EXPR): Remove.
13618
13619 2012-04-25 Jan Hubicka <jh@suse.cz>
13620
13621 PR middle-end/53089
13622 * cgraphunit.c (referred_to_p): Move ahead in file to avoid
13623 forward declaration.
13624 (cgraph_finalize_function): Finalize them here.
13625 * symtab.c (dump_symtab): Dump ctors and dtors.
13626
13627 2012-04-25 Jakub Jelinek <jakub@redhat.com>
13628
13629 PR middle-end/52979
13630 * stor-layout.c (get_best_mode): Don't return mode with bitsize
13631 larger than maxbits. Don't compute maxbits modulo align.
13632 Also check that unit bytes long store at bitpos / unit * unit
13633 doesn't affect bits beyond bitregion_end.
13634 * expmed.c (store_bit_field_1): Avoid trying insv if OP_MODE MEM
13635 would not fit into bitregion_start ... bitregion_end + 1 bit region.
13636 (store_split_bit_field): Decrease unit close to end of bitregion_end
13637 if access is restricted in order to avoid mutual recursion.
13638
13639 PR tree-optimization/53058
13640 * double-int.h (double_int_max_value, double_int_min_value): New
13641 prototypes.
13642 * double-int.c (double_int_max_value, double_int_min_value): New
13643 functions.
13644 * tree-vrp.c (register_edge_assert_for_2): Compare mask for LE_EXPR
13645 or GT_EXPR with double_int_max_value instead of double_int_mask.
13646
13647 2012-04-25 Richard Guenther <rguenther@suse.de>
13648
13649 * tree-vectorizer.h (vect_loop_versioning): Adjust prototype.
13650 * tree-vect-loop.c (vect_transform_loop): Adjust.
13651 * tree-vect-loop-manip.c (vect_do_peeling_for_loop_bound): Record
13652 the maximum number of iterations for the epilogue loop.
13653 (vect_loop_versioning): Remove case re-using the peeled epilogue loop.
13654
13655 2012-04-25 Jakub Jelinek <jakub@redhat.com>
13656
13657 PR c/52880
13658 * c-typeck.c (set_nonincremental_init,
13659 set_nonincremental_init_from_string): Pass true instead of false
13660 as IMPLICIT to add_pending_init.
13661
13662 2012-04-25 Manuel López-Ibáñez <manu@gcc.gnu.org>
13663
13664 * c-typeck.c (pop_init_level): Improve diagnostics.
13665
13666 2012-04-25 Uros Bizjak <ubizjak@gmail.com>
13667
13668 * compare-elim.c (try_eliminate_compare): Also handle operands with
13669 implicit extensions.
13670
13671 2012-04-25 Alan Modra <amodra@gmail.com>
13672
13673 * config/rs6000/rs6000 (SAVE_INLINE_VRS, REST_INLINE_VRS,
13674 V_SAVE_INLINE, SAVRES_LR, SAVRES_SAVE, SAVRES_REG,
13675 SAVRES_GPR, SAVRES_FPR, SAVRES_VR): Define.
13676 (no_global_regs_above): Delete.
13677 (no_global_regs): New function.
13678 (rs6000_savres_strategy): Handle vector regs. Use proper lr_save_p
13679 value for load multiple test.
13680 (savres_routine_syms): Increase size.
13681 (rs6000_savres_routine_name, rs6000_savres_routine_sym,
13682 ptr_regno_for_savres, rs6000_emit_savres_rtx): Pass in int selector
13683 rather than a number of boolean flags. Update all callers.
13684 (rs6000_savres_routine_name): Generate vector save/restore names.
13685 (rs6000_savres_routine_sym): Handle vector regs. Delete forward decl.
13686 (ptr_regno_for_savres, rs6000_emit_savres_rtx): Likewise.
13687 (rs6000_emit_prologue): Delete saving_FPRs_inline, saving_GPRs_inline
13688 and using_store_multiple. Expand uses. Don't always use r11 as
13689 frame reg when needed for out-of-line saves. Set up initial offset
13690 for out-of-line vector saves when buying stack frame. Handle pointer
13691 reg setup for out-of-line fp save. Emit call to out-of-line vector
13692 save function. Choose r11 or r12 for vrsave reg when available for
13693 better scheduling.
13694 (rs6000_output_function_prologue): Don't emit .extern for ELF.
13695 (rs6000_emit_epilogue): Choose a better frame reg when restoring
13696 from back-chain to suit out-of-line vector restore functions. Emit
13697 call to out-of-line vector restore function. Adjust register used
13698 for cr restore. Tweak pointer register setup for gpr restore.
13699 * config/rs6000/rs6000.h (FIRST_SAVED_GP_REGNO): Take into account
13700 FIXED_R13.
13701 * config/rs6000/sysv4.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Simplify.
13702 (V_SAVE_INLINE): Define.
13703 * config/rs6000/altivec.md (save_vregs_*, restore_vregs_*): New insns.
13704
13705 2012-04-25 Alan Modra <amodra@gmail.com>
13706
13707 * config/rs6000/rs6000.c (rs6000_savres_strategy): Allow
13708 out-of-line save/restore for large frames. Don't disable
13709 out-of-line saves on ABI_AIX when using static chain reg.
13710 (rs6000_emit_prologue): Adjust cr_save_regno on ABI_AIX to not
13711 clobber static chain reg, and tweak for out-of-line gpr saves
13712 that use r1.
13713
13714 2012-04-25 Alan Modra <amodra@gmail.com>
13715
13716 * config/rs6000/rs6000.c (START_USE, END_USE, NOT_INUSE): Define.
13717 (rs6000_emit_prologue): Use the above to catch register overlap.
13718
13719 2012-04-25 Alan Modra <amodra@gmail.com>
13720
13721 * config/rs6000/rs6000.c (rs6000_emit_stack_reset): Delete forward
13722 decl. Move logic selecting update reg to callers. Update all callers.
13723 (rs6000_emit_allocate_stack): Add copy_off param.
13724 (emit_frame_save): Don't handle reg+reg addressing.
13725 (ptr_regno_for_savres): New function, extracted from..
13726 (rs6000_emit_savres_rtx): ..here. Add lr_offset param.
13727 (rs6000_emit_prologue): Generate frame_ptr_rtx as we need it.
13728 Set frame_reg_rtx to r11 whenever r11 is needed, and merge
13729 frame offset adjustment for out-of-line save with copy from sp.
13730 Simplify condition controlling whether cr is saved early or
13731 late. Use ptr_regno_for_savres to verify correct reg is set
13732 up for out-of-line saves. Pass the actual pointer reg used to
13733 rs6000_emit_savres_rtx so rtl matches insns in out-of-line
13734 function. Rearrange spe vars so code is similar to that
13735 elsewhere in this function. Don't update frame_off when spe
13736 save code will restore r11. Use emit_frame_save for spe and
13737 gpr saves. Consolidate darwin out-of-line gpr setup with that
13738 for other abis. Don't assume frame_offset is zero and frame
13739 reg is sp when setting up altivec reg saves, and calculate
13740 exact offset requirement.
13741 (rs6000_emit_epilogue): Use HOST_WIDE_INT for frame_off. Tidy
13742 spe restore code. Consolidate darwin out-of-line gpr setup
13743 with that for other abis.
13744
13745 2012-04-25 Alan Modra <amodra@gmail.com>
13746
13747 * config/rs6000/rs6000.c (rs6000_frame_related): Don't emit a
13748 REG_FRAME_RELATED_EXPR note when the instruction exactly matches
13749 the replacement.
13750 (emit_frame_save): Delete frame_ptr param. Rename total_size to
13751 frame_reg_to_sp.
13752 (rs6000_emit_prologue): Add sp_off. Update rs6000_frame_related
13753 and emit_frame_save calls. Cope with possibly missing note.
13754
13755 2012-04-24 Sriraman Tallam <tmsriram@google.com>
13756
13757 * config/i386/i386.c (build_processor_model_struct): New function.
13758 (make_var_decl): New function.
13759 (fold_builtin_cpu): New function.
13760 (ix86_fold_builtin): New function.
13761 (make_cpu_type_builtin): New function.
13762 (ix86_init_platform_type_builtins): New function.
13763 (ix86_expand_builtin): Expand new builtins by folding them.
13764 (ix86_init_builtins): Make new builtins to detect CPU type.
13765 (TARGET_FOLD_BUILTIN): New macro.
13766 (IX86_BUILTIN_CPU_INIT): New enum value.
13767 (IX86_BUILTIN_CPU_IS): New enum value.
13768 (IX86_BUILTIN_CPU_SUPPORTS): New enum value.
13769 * config/i386/i386-builtin-types.def: New function type.
13770 * testsuite/gcc.target/builtin_target.c: New testcase.
13771 * doc/extend.texi: Document builtins.
13772
13773 2012-04-24 Olivier Hainque <hainque@adacore.com>
13774
13775 * common.opt (gdwarf-): Initialize dwarf_version to -1 instead of 2.
13776 * toplev.c (process_options): Default to dwarf_version 2.
13777 * config/vxworks.c (vxworks_override_options): Default to strict-dwarf
13778 and dwarf_version 2.
13779
13780 2012-04-24 Manuel López-Ibáñez <manu@gcc.gnu.org>
13781
13782 * tree-pretty-print.h (default_tree_printer): Do not declare.
13783 * tree-diagnostic.c: Include tree-pretty-print.h, tree-pass.h and
13784 intl.h.
13785 (default_tree_diagnostic_starter): Make static.
13786 (default_tree_printer): Move to here. Make static.
13787 (tree_diagnostics_defaults): New.
13788 * tree-diagnostic.h (default_tree_diagnostic_starter): Do not declare.
13789 * tree.c (free_lang_data): Use tree_diagnostics_defaults.
13790 * toplev.c: Do not include tree-pass.h.
13791 (default_tree_printer): Move from here.
13792 (general_init): Use tree_diagnostics_defaults.
13793
13794 2012-04-24 Chao-ying Fu <fu@mips.com>
13795
13796 * config.gcc (mips64*-*-linux*): Append mips/linux-common.h to tm_file.
13797 (mips*-*-linux*): Append mips/linux-common.h to tm_file.
13798 * config/mips/gnu-user.h
13799 (SUBTARGET_CC1_SPEC): Use GNU_USER_TARGET_CC1_SPEC directly.
13800 (GNU_USER_TARGET_LINK_SPEC): New define.
13801 (LINK_SPEC): Use GNU_USER_TARGET_LINK_SPEC.
13802 (LIB_SPEC): Use GNU_USER_TARGET_LIB_SPEC directly.
13803 (GNU_USER_TARGET_MATHFILE_SPEC): New define.
13804 (ENDFILE_SPEC): Use GNU_USER_TARGET_MATHFILE_SPEC and
13805 GNU_USER_TARGET_ENDFILE_SPEC.
13806 * config/mips/gnu-user64.h (LIB_SPEC): Remove.
13807 (GNU_USER_TARGET_LINK_SPEC): New define.
13808 (LINK_SPEC): Use GNU_USER_TARGET_LINK_SPEC.
13809 * config/mips/linux-common.h: New file.
13810
13811 2012-04-24 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
13812
13813 PR target/47197
13814 * config/rs6000/rs6000-c.c (fully_fold_convert): New function.
13815 (altivec_build_resolved_builtin): Call fully_fold_convert.
13816
13817 2012-04-24 Georg-Johann Lay <avr@gjlay.de>
13818
13819 PR target/53065
13820 * config/avr/avr.h (HARD_REGNO_CALL_PART_CLOBBERED): New hook define.
13821
13822 2012-04-24 Richard Guenther <rguenther@suse.de>
13823
13824 PR tree-optimization/53085
13825 * tree-ssa-pre.c (eliminate): Do not eliminate volatile redundant
13826 stores.
13827
13828 2012-04-24 Richard Guenther <rguenther@suse.de>
13829
13830 * tree-if-conv.c (main_tree_if_conversion): Move bb under
13831 ENABLE_CHECKING.
13832
13833 2012-04-24 Jim Meyering <meyering@redhat.com>
13834
13835 * genattrtab.c (gen_attr): Avoid NULL-deref after diagnosing
13836 absence of an define_enum call.
13837
13838 2012-04-24 Richard Guenther <rguenther@suse.de>
13839
13840 * tree-vect-loop-manip.c (vect_do_peeling_for_loop_bound): If
13841 the epilogue loop is not re-used as unvectorized version
13842 record the its maximum number of iterations.
13843
13844 2012-04-24 Andrew Pinski <apinski@cavium.com>
13845
13846 * tree-ssa-forwprop.c (simplify_bitwise_binary):
13847 Don't directly use def1/def2.
13848
13849 2012-04-24 Richard Guenther <rguenther@suse.de>
13850
13851 PR tree-optimization/53098
13852 * tree-vect-loop.c (vect_analyze_loop_operations): Fixup
13853 comparison sign.
13854
13855 2012-04-24 Andrew Pinski <apinski@cavium.com>
13856
13857 PR tree-opt/33512
13858 * tree-ssa-forwprop.c (defcodefor_name): New function.
13859 (simplify_bitwise_binary): Use defcodefor_name instead of manually
13860 Simplify "( X | Y) & X" to X and "( X & Y) | X" to X.
13861 Simplify "(~X | Y) & X" to "X & Y" and
13862 "(~X & Y) | X" to "X | Y".
13863
13864 2012-04-24 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
13865
13866 * recog.c (insn_invalid_p): Add IN_GROUP parameter and use
13867 validate_change to add clobbers if IN_GROUP is nonzero.
13868 (verify_changes): Call insn_invalid_p with IN_GROUP set to true.
13869 * recog.h (insn_invalid_p): Add IN_GROUP parameter to function
13870 prototype.
13871 * gcse.c (process_insert_insn): Call insn_invalid_p with IN_GROUP
13872 set to false.
13873 * config/s390/s390.c (insn_invalid_p): Likewise.
13874
13875 2012-04-24 Jakub Jelinek <jakub@redhat.com>
13876
13877 PR middle-end/53084
13878 * varasm.c (compute_reloc_for_constant): Handle ADDR_EXPR of MEM_REF.
13879 (output_addressed_constants): Likewise.
13880
13881 PR middle-end/52999
13882 * varasm.c (get_section): Don't ICE for section conflicts with
13883 built-in section kinds.
13884
13885 2012-04-23 DJ Delorie <dj@redhat.com>
13886
13887 * config/s390/s390.h (LINK_SPEC): Remove, no longer needed.
13888 (LIBSTDCXX): Change to CPP2.
13889
13890 2012-04-23 H.J. Lu <hongjiu.lu@intel.com>
13891
13892 PR bootstrap/52878
13893 * opth-gen.awk: Check if MASK_ and TARGET_ macros are defined for
13894 extra_masks.
13895
13896 2012-04-23 Uros Bizjak <ubizjak@gmail.com>
13897
13898 * config/i386/i386.md (*add<mode>_2): Add r/r/0 alternative.
13899 (*addsi_2_zext): Ditto.
13900 (*add<mode>_3): Ditto.
13901 (*addsi_3_zext): Ditto.
13902 (*add<mode>_5): Ditto.
13903
13904 2012-04-23 Andrew Pinski <apinski@cavium.com>
13905
13906 * tree-ssa-forwprop.c (simplify_bitwise_binary): Simplify (A & B) OP0
13907 (C & B) to (A OP0) & B.
13908
13909 2012-04-23 Martin Jambor <mjambor@suse.cz>
13910
13911 * expr.c (expand_expr_real_1): Remove setting parent's alias set for
13912 temporaries created for a bitfield (reverting revision 122014).
13913
13914 2012-04-23 Richard Guenther <rguenther@suse.de>
13915
13916 * tree-vect-loop-manip.c (slpeel_add_loop_guard): Gimplify
13917 the condition using is_gimple_condexpr and avoid the not necessary
13918 boolification.
13919 (set_prologue_iterations): Likewise.
13920 (vect_loop_versioning): Likewise.
13921
13922 2012-04-23 Richard Guenther <rguenther@suse.de>
13923
13924 PR tree-optimization/53070
13925 * tree-if-conv.c (combine_blocks): Free predicates in all blocks.
13926 (main_tree_if_conversion): Verify we succeeded in that.
13927
13928 2012-04-23 Jan Hubicka <jh@suse.cz>
13929
13930 * lto-symtab.c (lto_cgraph_replace_node): Do not call
13931 mark_reahcable_node.
13932 * cgraph.c (cgraph_remove_node): Do not clear reachable.
13933 (cgraph_mark_reachable_node): Remove.
13934 (cgraph_mark_force_output_node): Do not set reachable.
13935 (dump_cgraph_node): Do not dump reachable.
13936 (cgraph_create_virtual_clone): Do not set reachable.
13937 * cgraph.h (cgraph_node): Remove reachable flag.
13938 (varpool_node): Remove reachable flag.
13939 (cgraph_mark_if_needed): Remove.
13940 (cgraph_mark_reachable_node): Remove.
13941 * tree-emutls.c (ipa_lower_emutls): Do not check reachable.
13942 * cgraphunit.c (cgraph_finalize_function): Do not mark node as
13943 reachable.
13944 (cgraph_add_new_function): Likewise.
13945 (cgraph_mark_if_needed): Remove.
13946 (cgraph_analyze_function): Do not set target as reachable.
13947 (process_function_and_variable_attributes): Do not care about
13948 dllexport.
13949 (cgraph_analyze_functions): Do not set reachable flags.
13950 (cgraph_mark_functions_to_output): Do not check reachability.
13951 (cgraph_copy_node_for_versioning): Do not set reachable flag.
13952 (dbxout_expand_expr): Update.
13953 * c-decl.c (merge_decls): Do not track changed externs.
13954 * ipa.c: Include pointer-set.h
13955 (enqueue_cgraph_node): Use reachable pointer set.
13956 (process_references): Likewise.
13957 (cgraph_remove_unreachable_nodes): Likewise.
13958 (whole_program_function_and_variable_visibility): Do not recompute
13959 reachable.
13960 * trans-mem.c (ipa_tm_execute): Do not check reachable flag.
13961
13962 2012-04-23 Georg-Johann Lay <avr@gjlay.de>
13963
13964 * doc/extend.texi (AVR Named Address Spaces): Fix typos.
13965
13966 2012-04-23 Richard Guenther <rguenther@suse.de>
13967
13968 PR c/53060
13969 * c-typeck.c (build_binary_op): Fix typo.
13970
13971 2012-04-23 Jakub Jelinek <jakub@redhat.com>
13972
13973 PR tree-optimizations/52891
13974 * tree-vect-patterns.c (adjust_bool_pattern): Use
13975 build_nonstandard_type even if rhs1 has unsigned INTEGER_TYPE,
13976 but with non-standard precision.
13977
13978 2012-04-22 Jan Hubicka <jh@suse.cz>
13979
13980 * tree-ssa-loop-ivopts.c (expr_invariant_in_loop_p): Bail out at NULL
13981 tree refs.
13982
13983 2012-04-22 Jan Hubicka <jh@suse.cz>
13984
13985 * lto-symtab.c (lto_varpool_replace_node): Do not merge needed flags.
13986 * cgraphbuild.c (record_reference, record_type_list, mark_address,
13987 mark_load, mark_store): Do not mark varpool nodes as needed.
13988 * cgraph.c (cgraph_new_nodes): Remove.
13989 (cgraph_create_function_alias): Do not mark nodes as reachable.
13990 (cgraph_add_thunk): Likewise.
13991 (cgraph_mark_reachable_node): Do not manage the queue.
13992 * cgraph.h (cgraph_node): Remove next_needed.
13993 (varpool_nodes_queue): Remove next_needed and prev_needed.
13994 (x_cgraph_nodes_queue, x_cgraph_nodes_queue, cgraph_new_nodes): Remove.
13995 (cgraph_new_nodes): Declare.
13996 (x_varpool_nodes_queue, varpool_nodes_queue); Remove.
13997 (varpool_analyze_pending_decls): Remove.
13998 (varpool_analyze_node): New.
13999 (varpool_mark_needed_node): Remove.
14000 (varpool_first_variable, varpool_next_variable): New inlines.
14001 (varpool_first_static_initializer, varpool_next_static_initializer):
14002 Update.
14003 (FOR_EACH_STATIC_VARIABLE): Remove unused walker.
14004 (varpool_first_defined_variable): New inline.
14005 (varpool_next_defined_variable): New inline
14006 (FOR_EACH_VARIABLE): Reimplement.
14007 (FOR_EACH_DEFINED_VARIABLE): Reimplement.
14008 * toplev.c (wrapup_global_declaration_2): Use analyzed instead of
14009 needed flag.
14010 * cgraphunit.c (cgraph_new_nodes): Declare here.
14011 (enqueue_node): New function.
14012 (cgraph_process_new_functions): update for new
14013 node set; when constructing cgraph enqueue node for processing.
14014 (cgraph_add_new_function): Use new node set.
14015 (process_function_and_variable_attributes): Do not set varpool needed
14016 flags.
14017 (referred_to_p): New function.
14018 (varpool_finalize_decl): Move here from varpool.c; enqueue needed node
14019 when varpool is in construction.
14020 (cgraph_analyze_functions): Rewrite.
14021 (cgraph_expand_all_functions): Update.
14022 (cgraph_output_in_order): Do not analyze pending decls; do not set
14023 needed flags.
14024 (cgraph_optimize): Do not analyze pending decls.
14025 * lto-cgraph.c (input_varpool_node): Clear analyzed flag for objects
14026 in other partition; do not mark node as needed.
14027 * dwarf2out.c (reference_to_unused): Use analyzed flag.
14028 (premark_types_used_by_global_vars_helper): Likewise.
14029 * ipa.c (process_references): Do not call varpool_mark_needed_node.
14030 (cgraph_remove_unreachable_nodes): Do not rely on varpool and
14031 cgrpah queues.
14032 (function_and_variable_visibility): Do not mark node as needed.
14033 (whole_program_function_and_variable_visibility): Likewise.
14034 * Makefile.in (gt-varpool.h): No longer needed.
14035 * passes.c (execute_one_pass, execute_ipa_pass_list): Update.
14036 (ipa_write_summaries): Do not use needed flag.
14037 * varpool.c: Do not include gt-varpool.h
14038 (x_varpool_nodes_queue, x_varpool_last_needed_node,
14039 x_varpool_last_needed_node, x_varpool_first_unanalyzed_node,
14040 x_varpool_first_unanalyzed_node, varpool_assembled_nodes_queue):
14041 Remove.
14042 (varpool_remove_node): Do not update the lists.
14043 (dump_varpool_node): Do not dump needed flag.
14044 (varpool_enqueue_needed_node): Remove.
14045 (varpool_mark_needed_node): Remove.
14046 (varpool_reset_queue): Remove.
14047 (varpool_finalize_decl): Move to cgraphunit.c
14048 (varpool_analyze_node): New functions based on former
14049 varpool_analyze_pending_decls.
14050 (varpool_analyze_pending_decls): Remove.
14051 (varpool_assemble_decl): Do not update the lists.
14052 (enqueue_node): New function.
14053 (varpool_remove_unreferenced_decls): Rewrite.
14054 (varpool_empty_needed_queue): Remove.
14055 (add_new_static_var): Do not mark node as needed.
14056 (varpool_create_variable_alias): Handle expansion state
14057 creation.
14058 * except.c (output_ttype): Do not mark node as needed.
14059 * varasm.c (mark_decl_referenced): Do not use mark_needed_node.
14060 * tree-profile.c (init_ic_make_global_vars, init_ic_make_global_vars):
14061 Likewise.
14062 * tree-switch-conversion.c (build_one_array): Likewise.
14063
14064 2012-04-22 Manuel López-Ibáñez <manu@gcc.gnu.org>
14065
14066 PR c/44774
14067 * doc/invoke.texi (pedantic): Rename to Wpedantic.
14068 * common.opt (Wpedantic): New.
14069 (pedantic): Alias Wpedantic.
14070 * diagnostic.c (warning_at): Likewise.
14071 * c-decl.c (diagnose_mismatched_decls): Likewise.
14072 (build_array_declarator): Likewise.
14073 (mark_forward_parm_decls):
14074 (check_bitfield_type_and_width): Likewise.
14075 (grokdeclarator): Likewise.
14076 (grokfield): Likewise.
14077 (finish_struct): Likewise.
14078 (build_enumerator): Likewise.
14079 (store_parm_decls_oldstyle): Likewise.
14080 (declspecs_add_qual): Likewise.
14081 (declspecs_add_type): Likewise.
14082 (finish_declspecs): Likewise.
14083 * c-typeck.c (composite_type): Likewise.
14084 (comp_target_types): Likewise.
14085 (build_array_ref): Likewise.
14086 (pointer_diff): Likewise.
14087 (build_unary_op): Likewise.
14088 (build_conditional_expr): Likewise.
14089 (build_c_cast): Likewise.
14090 (convert_for_assignment): Likewise.
14091 (maybe_warn_string_init): Likewise.
14092 (digest_init): Likewise.
14093 (pop_init_level): Likewise.
14094 (set_init_index): Likewise.
14095 (c_finish_goto_label): Likewise.
14096 (c_finish_return): Likewise.
14097 (do_case): Likewise.
14098 (build_binary_op): Likewise.
14099 * c-parser.c (static): Likewise.
14100 (c_parser_external_declaration): Likewise.
14101 (c_parser_declaration_or_fndef): Likewise.
14102 (c_parser_static_assert_declaration_no_se): Likewise.
14103 (c_parser_enum_specifier): Likewise.
14104 (c_parser_struct_or_union_specifier): Likewise.
14105 (c_parser_struct_declaration): Likewise.
14106 (c_parser_alignas_specifier): Likewise.
14107 (c_parser_braced_init): Likewise.
14108 (c_parser_initelt): Likewise.
14109 (c_parser_compound_statement_nostart): Likewise.
14110 (c_parser_conditional_expression): Likewise.
14111 (c_parser_alignof_expression): Likewise.
14112 (c_parser_postfix_expression): Likewise.
14113 (c_parser_postfix_expression_after_paren_): Likewise.
14114 (c_parser_objc_class_instance_variables): Likewise.
14115 (c_parser_objc_method_definition): Likewise.
14116 (c_parser_objc_methodprotolist): Likewise.
14117
14118 2012-04-22 Ian Lance Taylor <iant@google.com>
14119
14120 * godump.c (go_output_typedef): Dump size of structs.
14121
14122 2012-04-22 Razya Ladelsky <razya@il.ibm.com>
14123
14124 Correcting transform_to_exit_first_loop + fix to PR46886
14125 * tree-parloops.c (transform_to_exit_first_loop): Remove
14126 setting of number of iterations according to the loop pattern.
14127 Duplicate from entry to exit->src instead of loop->latch.
14128 (pallelize_loops): Remove the condition preventing do-while loops.
14129 * tree-cfg.c (bool bb_in_region_p): New.
14130 (gimple_duplicate_sese_tail): Adjust duplication of the the subloops.
14131 Adjust redirection of the duplicated iteration.
14132
14133 2012-04-21 Richard Sandiford <rdsandiford@googlemail.com>
14134
14135 PR bootstrap/53021
14136 * rtl.def (ADDRESS): Use "i" rather than "w".
14137 * rtl.h (find_base_term): Delete.
14138 (may_be_sp_based_p): Declare.
14139 * rtl.c (rtx_code_size): Remove ADDRESS special case.
14140 * alias.h (UNIQUE_BASE_VALUE_SP, UNIQUE_BASE_VALUE_ARGP)
14141 (UNIQUE_BASE_VALUE_FP, UNIQUE_BASE_VALUE_HFP): Move to...
14142 * alias.c: ...here.
14143 (find_base_term): Make static.
14144 (may_be_sp_based_p): New function.
14145 * dse.c (record_store): Use it.
14146 * store-motion.c (store_killed_in_insn): Likewise.
14147
14148 2012-04-21 Richard Sandiford <rdsandiford@googlemail.com>
14149
14150 * fold-const.c (fold_checksum_tree): Fix VECTOR_CST case.
14151
14152 2012-04-21 Manuel López-Ibáñez <manu@gcc.gnu.org>
14153
14154 PR 35441
14155 * c-typeck.c (inform_declaration): New.
14156 (build_function_call_vec): Do not pretty-print
14157 expressions when caret is enabled.
14158 (convert_arguments): Use inform_declaration.
14159
14160 2012-04-20 Jim Meyering <meyering@redhat.com>
14161
14162 * genmodes.c (make_complex_modes): Don't truncate a mode name of
14163 length 7 or more when prepending a "C". Suggested by Richard Guenther.
14164
14165 2012-04-20 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
14166
14167 PR rtl-optimization/44214
14168 * fold-const.c (exact_inverse): New function.
14169 (fold_binary_loc): Fold vector and complex division by constant into
14170 multiply by recripocal with flag_reciprocal_math; fold vector division
14171 by constant into multiply by reciprocal with exact inverse.
14172
14173 2012-04-20 Jan Hubicka <jh@suse.cz>
14174
14175 * lto-symtab.c (lto_cgraph_replace_node): Merge needed instead of
14176 force flags.
14177 * cgraph.c (cgraph_add_thunk): Use mark_reachable_node.
14178 (cgraph_remove_node): Update.
14179 (cgraph_mark_needed_node): Remove.
14180 (cgraph_mark_force_output_node): New.
14181 (dump_cgraph_node): Do not dump needed flag.
14182 (cgraph_node_cannot_be_local_p_1): Update.
14183 (cgraph_can_remove_if_no_direct_calls_and_refs): Update.
14184 * cgraph.h (symtab_node_base): Add force_output flag.
14185 (cgraph_node): Remove needed flag.
14186 (varpool_node): Remove force_output flag.
14187 (cgraph_mark_needed_node): Remove.
14188 (cgraph_mark_force_output_node): New.
14189 (cgraph_only_called_directly_or_aliased_p,
14190 varpool_can_remove_if_no_refs, varpool_all_refs_explicit_p): Update.
14191 * ipa-cp.c (ipcp_generate_summary): Remove out of date assert.
14192 * cgraphunit.c (cgraph_decide_is_function_needed): rewrite.
14193 (cgraph_add_new_function): Update.
14194 (cgraph_mark_if_needed): Update.
14195 (verify_cgraph_node): Update.
14196 (cgraph_analyze_function): Alias target is reachable.
14197 (process_function_and_variable_attributes): Update: externally_visible
14198 flag makes function reachable.
14199 (cgraph_analyze_functions): Update dumping.
14200 * lto-cgraph.c (lto_output_node, lto_output_varpool_node,
14201 input_overwrite_node, input_varpool_node): Update streaming.
14202 * lto-streamer-out.c (produce_symtab): Use force_output.
14203 * ipa.c (process_references): Weakrefs must be processed.
14204 (cgraph_remove_unreachable_nodes): Likewise; update for new
14205 force_output flag.
14206 (varpool_externally_visible_p): Weakrefs are externally visible
14207 even if they are not.
14208 (function_and_variable_visibility): Update; when processing alias
14209 pair force the targets to be output.
14210 (whole_program_function_and_variable_visility): Use
14211 mark_reachable_node.
14212 * trans-mem.c (ipa_tm_mark_needed_node): Remove
14213 (ipa_tm_mark_force_output_node): New function.
14214 (ipa_tm_create_version_alias, ipa_tm_create_version): Update.
14215 * gimple-fold.c (can_refer_decl_in_current_unit_p): Be lax about
14216 aliases.
14217 * varasm.c (mark_decl_referenced): Update.
14218 (find_decl_and_mark_needed): Remove.
14219 (find_decl): New function.
14220 (weak_finish, finish_aliases_1, assemble_alias): Update; do not mark
14221 alias targets as needed.
14222 (dump_tm_clone_pairs): Update.
14223 * tree-inline.c (copy_bb): Update check.
14224 * symtab.c (dump_symtab_base): Dump force_output.
14225 * tree-ssa-structalias.c (ipa_pta_execute): Use force_output.
14226 * passes.c (execute_todo): Fix dumping.
14227 * varpool.c (decide_is_variable_needed, varpool_finalize_decl): Update.
14228 (varpool_analyze_pending_decls): Alias target is reachable.
14229 (varpool_create_variable_alias): Finalize weakrefs.
14230
14231 2012-04-20 Jakub Jelinek <jakub@redhat.com>
14232
14233 PR bootstrap/53021
14234 * alias.h (UNIQUE_BASE_VALUE_SP, UNIQUE_BASE_VALUE_ARGP,
14235 UNIQUE_BASE_VALUE_FP, UNIQUE_BASE_VALUE_HFP): Define.
14236 * alias.c (init_alias_targets): Use UNIQUE_BASE_VALUE_*
14237 macros instead of constants.
14238 * dse.c (record_store): Check for SP ADDRESS by comparing
14239 XWINT to UNIQUE_BASE_VALUE_SP instead of expecting
14240 XEXP to be stack_pointer_rtx.
14241
14242 2012-04-20 Richard Guenther <rguenther@suse.de>
14243
14244 * tree-ssa-copy.c (propagate_tree_value_into_stmt): Use
14245 update_call_from_tree when propagating into a call.
14246
14247 2012-04-20 Alan Modra <amodra@gmail.com>
14248
14249 * config/rs6000/rs6000.c (rs6000_emit_savres_rtx): Formatting.
14250 (rs6000_emit_prologue, rs6000_emit_epilogue): Likewise. Rename
14251 sp_offset to frame_off. Move world save code earlier.
14252
14253 2012-04-20 Richard Guenther <rguenther@suse.de>
14254
14255 PR tree-optimization/53050
14256 * tree-ssa-forwprop.c (ssa_forward_propagate_and_combine):
14257 Do only one transform on COND_EXPRs at the same time.
14258
14259 2012-04-19 Jan Hubicka <jh@suse.cz>
14260
14261 * symtab.c (dump_symtab_base): Revert accidental checkin.
14262
14263 2012-04-20 Alan Modra <amodra@gmail.com>
14264
14265 PR target/53040
14266 * config/rs6000/rs6000.c (rs6000_savres_strategy): When using
14267 static chain, set REST_INLINE_FPRS too.
14268
14269 2012-04-20 Thomas Schwinge <thomas@codesourcery.com>
14270
14271 * tree-dump.c (dequeue_and_dump) <BIT_FIELD_REF>: Dump the three child
14272 nodes.
14273
14274 2012-04-20 Richard Guenther <rguenther@suse.de>
14275
14276 * tree-vect-loop.c (vect_analyze_loop_operations): Do not vectorize
14277 loops that can never run more often than the vectorization factor.
14278
14279 2012-04-19 Jan Hubicka <jh@suse.cz>
14280
14281 * symtab.c (dump_symtab_base): Fix dumping of asm lists.
14282
14283 2012-04-19 David Edelsohn <dje.gcc@gmail.com>
14284
14285 * config/rs6000/sync.md (fetchop_name): Change ior attribute to "or".
14286
14287 2012-04-19 Jim Meyering <meyering@redhat.com>
14288
14289 * genmodes.c (make_complex_modes): Avoid unnecessary use of strncpy.
14290 We verified above that the string(including trailing NUL) fits in buf,
14291 so just use memcpy.
14292
14293 2012-04-19 Richard Guenther <rguenther@suse.de>
14294
14295 * symtab.c (dump_symtab_base): Use TREE_STRING_POINTER
14296 for dumping DECL_SECTION_NAME.
14297
14298 2012-04-19 Michael Matz <matz@suse.de>
14299
14300 PR middle-end/52977
14301 * tree.h (VECTOR_CST_NELTS): Use part number of types again.
14302 (struct tree_vector): Adjust GTY length.
14303 * tree.c (make_vector_stat): Don't set VECTOR_CST_NELTS.
14304
14305 * gengtype.c (struct walk_type_data): Add in_record_p and loopcounter
14306 members.
14307 (walk_type, <TYPE_POINTER, TYPE_ARRAY>): Handle case where our
14308 caller emitted the length calulation already.
14309 (walk_type, <TYPE_UNION, TYPE_STRUCT>): Emit length calculations
14310 before handling any of the fields for structs.
14311
14312 2012-04-19 Richard Guenther <rguenther@suse.de>
14313
14314 PR tree-optimization/53031
14315 * tree-vrp.c (adjust_range_with_scev): Revert back to
14316 using max_loop_iterations.
14317
14318 2012-04-19 Michael Matz <matz@suse.de>
14319
14320 * diagnostic.c (emit_diagnostic): Move va_end call after user
14321 of the va_list.
14322 (warning, warning_at, pedwarn, permerror): Ditto.
14323
14324 2012-04-19 Richard Guenther <rguenther@suse.de>
14325
14326 * ira-int.h (ira_allocno_object_iter_cond): Avoid out-of-bound
14327 array access.
14328
14329 2012-04-19 Georg-Johann Lay <avr@gjlay.de>
14330
14331 PR target/53033
14332 * config/avr/avr.c (avr_out_load_psi): Fix assembler template for
14333 the case *(X+const).
14334
14335 2012-04-19 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
14336
14337 * config/arm/sync.md (sync_optab): Change ior attribute to "or".
14338
14339 2012-04-19 Manuel López-Ibáñez <manu@gcc.gnu.org>
14340
14341 PR c/52283/37985
14342 * stmt.c (warn_if_unused_value): Skip NOP_EXPR.
14343 * convert.c (convert_to_integer): Don't set TREE_NO_WARNING.
14344
14345 2012-04-19 Richard Guenther <rguenther@suse.de>
14346
14347 PR rtl-optimization/44688
14348 * loop-iv.c (determine_max_iter): Only return max_iter.
14349 (iv_number_of_iterations): Also use the recorded loop bound
14350 on the maximum number of iterations.
14351 * loop-unroll.c (decide_unroll_runtime_iterations): Use
14352 max_iter to avoid unrolling loops that do not roll.
14353 (decide_unroll_stupid): Likewise.
14354
14355 2012-04-18 Steven Bosscher <steven@gcc.gnu.org>
14356
14357 * targhooks.c (default_case_values_threshold): Fix code style nit.
14358
14359 * stmt.c (add_case_node, expand_case): Move logic to remove/reduce
14360 case range and type folding from here...
14361 * gimplify.c (gimplify_switch_expr): ... to here. Expect NULL_TREE
14362 type, as documented in tree.def.
14363
14364 2012-04-18 Jan Hubicka <jh@suse.cz>
14365
14366 * cgraph.h (verify_symtab, verify_symtab_node, verify_symtab_base):
14367 Declare.
14368 * cgraphunit.c (verify_cgraph_node): Verify symtab base; do not verify
14369 cgraph hash and same comdat groups.
14370 (cgraph_optimize): Verify symbol table.
14371 * ipa.c (cgraph_remove_unreachable_nodes): Verify symbol table.
14372 (dissolve_same_comdat_group_list): Work on symtab nodes.
14373 (function_and_variable_visibility): Dissolve variable same comdat group
14374 lists, too.
14375 * symtab.c: Include timevar.h
14376 (verify_symtab_base, verify_symtab_node, verify_symtab): New functions.
14377
14378 2012-04-18 Steven Bosscher <steven@gcc.gnu.org>
14379
14380 * tree-switch-conversion.c (info): Remove global pass info.
14381 (check_range, check_process_case, check_final_bb, create_temp_arrays,
14382 free_temp_arrays, gather_default_values, build_constructors,
14383 array_value_type, build_one_array, build_arrays, gen_def_assigns,
14384 fix_phi_nodes, gen_inbound_check): Pass info around from ...
14385 (process_switch): ... here. Unify message format. Return a const
14386 char pointer to the failure reason message.
14387 (do_switchconv): Unify message format. Update process_switch usage.
14388
14389 * tree.def (CASE_LABEL_EXPR): Fix documentation, mention all operands.
14390 * tree-cfg.c (edge_to_cases): Fix documentation.
14391
14392 2012-04-18 Uros Bizjak <ubizjak@gmail.com>
14393
14394 * config/alpha/sync.md (fetchop_name): Change ior attribute to "or".
14395
14396 2012-04-18 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
14397
14398 PR tree-optimization/52976
14399 * tree-ssa-reassoc.c (add_to_ops_vec_max_rank): Delete.
14400 (possibly_move_powi): New function.
14401 (rewrite_expr_tree): Call possibly_move_powi.
14402 (rewrite_expr_tree_parallel): Likewise.
14403 (attempt_builtin_powi): Change call of add_to_ops_vec_max_rank to
14404 call add_to_ops_vec instead.
14405
14406 2012-04-18 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
14407
14408 PR tree-optimization/52976
14409 * tree-ssa-reassoc.c (stmt_is_power_of_op): New function.
14410 (decrement_power): Likewise.
14411 (propagate_op_to_single_use): Likewise.
14412 (zero_one_operation): Handle __builtin_pow* calls in linearized
14413 expression trees; factor logic into propagate_op_to_single_use.
14414 (undistribute_ops_list): Allow operands with repeat counts > 1.
14415
14416 2012-04-18 Richard Guenther <rguenther@suse.de>
14417
14418 PR tree-optimization/44688
14419 * cfgloop.h (record_niter_bound): Declare.
14420 * tree-ssa-loop-niter.c (record_niter_bound): Export.
14421 Update the estimation with the upper bound here...
14422 (estimate_numbers_of_iterations_loop): ... instead of here.
14423 Do not forcefully reset a recorded upper bound.
14424 * tree-vect-loop-manip.c (vect_do_peeling_for_alignment):
14425 Record the maximum number of loop iterations of the prologue loop.
14426
14427 2012-04-18 Jan Hubicka <jh@suse.cz>
14428
14429 * lto-symtab.c (lto_cgraph_replace_node): Update.
14430 * cgraphbuild.c (record_reference, record_type_list,
14431 record_eh_tables, mark_address, mark_load, mark_store): Update.
14432 * cgraph.c (cgraph_same_body_alias, dump_cgraph_node,
14433 cgraph_create_virtual_clone, cgraph_for_node_thunks_and_aliases):
14434 Update.
14435 * cgraph.h (symtab_node_def, symtab_node, const_symtab_node): Remove.
14436 (cgraph_alias_aliased_node, varpool_alias_aliased_node): Update.
14437 * reload.c: Fix typo in comment.
14438 * rtlanal.c: Likewise.
14439 * tree-emultls.c (gen_emutls_addr): Update.
14440 * ipa-reference.c (analyze_function): Update.
14441 * cgraphunit.c (cgraph_analyze_function,
14442 cgraph_process_same_body_aliases, assemble_thunks_and_aliases):
14443 Update.
14444 * ipa-ref.c (ipa_record_reference): Reorg to avoid reference types.
14445 (ipa_remove_reference): Likewise.
14446 (ipa_remove_all_refering): Rename to ...
14447 (ipa_remove_all_referring): ... this one; update.
14448 (ipa_dump_references): Update.
14449 (ipa_dump_referring): Update.
14450 (ipa_clone_references): Update.
14451 (ipa_clone_refering): Rename to ...
14452 (ipa_clone_referring): ... this one; update.
14453 (ipa_ref_cannot_lead_to_return): Update.
14454 (ipa_ref_has_aliases_p): Update.
14455 * ipa-ref.h (symtab_node_def, symtab_node, const_symtab_node): New
14456 forward typedefs.
14457 (ipa_ref_type): Remove.
14458 (ipa_ref_ptr_u): Remove.
14459 (ipa_ref): Remove referencing, refered, refered_index, refering_type
14460 and refered_type; add referring, referred and referred_index.
14461 (ipa_ref_list): Rename refering to referring.
14462 (ipa_record_reference, ipa_remove_all_referring, ipa_dump_referring,
14463 ipa_clone_references, ipa_clone_referring): Update prototypes.
14464 * lto-cgraph.c (referenced_from_other_partition_p): Update.
14465 (lto_output_ref): Update.
14466 (add_references): Update.
14467 (input_varpool_node): Update.
14468 (input_refs): Update.
14469 * ipa-ref-inline.h (ipa_ref_node): Update.
14470 (ipa_ref_varpool_node): Update.
14471 (ipa_ref_referring_node): Update.
14472 (ipa_ref_referring_varpool_node): Update.
14473 (ipa_ref_referring_ref_list): Update.
14474 (ipa_ref_referred_ref_list): Update.
14475 (ipa_ref_list_first_referring): Update.
14476 (ipa_empty_ref_list): Update.
14477 (ipa_ref_list_refering_iterate): Rename to ...
14478 (ipa_ref_list_referring_iterate): ... this one.
14479 * cse.c: Update comment.
14480 * ipa-utils.c (ipa_reverse_postorder): Update.
14481 * tree-ssa-alias.c: Update.
14482 * ipa-inline.c (reset_edge_caches): Update.
14483 (update_caller_keys): Update.
14484 * ipa-inline.h: Update comments.
14485 * jump.c: Update comment.
14486 * alias.c: Likewise.
14487 * ipa.c (process_references): Update.
14488 (cgraph_remove_unreachable_nodes): Likewise.
14489 (ipa_discover_readonly_nonaddressable_var): Likewise.
14490 (cgraph_address_taken_from_non_vtable_p): Likewise.
14491 * trans-mem.c (ipa_tm_execute): Update.
14492 * simplify-rtx.c: Fix comment.
14493 * rtl.c: Fix comment.
14494 * symtab.c (symtab_unregister_node): Update.
14495 * varpool.c (dump_varpool_node): Update.
14496 (varpool_analyze_pending_decls): Update.
14497 (assemble_aliases): Update.
14498 (varpool_for_node_and_aliases): Update.
14499
14500 2012-04-18 Richard Guenther <rguenther@suse.de>
14501
14502 * cfgloop.h (estimate_numbers_of_iterations_loop): Remove
14503 use_undefined_p parameter.
14504 * tree-flow.h (estimate_numbers_of_iterations): Likewise.
14505 * tree-ssa-loop-niter.c (estimate_numbers_of_iterations_loop):
14506 Likewise.
14507 (estimate_numbers_of_iterations): Likewise.
14508 (estimated_loop_iterations): Adjust.
14509 (max_loop_iterations): Likewise.
14510 (scev_probably_wraps_p): Likewise.
14511 * tree-ssa-loop.c (tree_ssa_loop_bounds): Likewise.
14512 * tree-vrp.c (adjust_range_with_scev): Use max_stmt_executions,
14513 not max_loop_iterations.
14514 (execute_vrp): Remove explicit number of iterations estimation.
14515
14516 2012-04-18 Enkovich Ilya <ilya.enkovich@intel.com>
14517
14518 * config/i386/linux-common.h: New.
14519
14520 * config.gcc: Add i386/linux-common.h before
14521 all i386/linux.h and i386/linux64.h usages.
14522
14523 * config/i386/gnu-user.h (GNU_USER_TARGET_LINK_SPEC): New.
14524 (LINK_SPEC): Use GNU_USER_TARGET_LINK_SPEC.
14525 * config/i386/gnu-user64.h: Likewise.
14526
14527 * config/i386/gnu-user.common.h (GNU_USER_TARGET_CC1_SPEC): New.
14528 (CC1_SPEC): Use GNU_USER_TARGET_CC1_SPEC.
14529 (GNU_USER_TARGET_MATHFILE_SPEC): New.
14530 (ENDFILE_SPEC): Use GNU_USER_TARGET_MATHFILE_SPEC.
14531
14532 2012-04-18 Jan Hubicka <jh@suse.cz>
14533
14534 * cgraph.c (cgraph_node_name): Remove.
14535 (dump_cgraph_node): Use dump_symtab_base; reformat.
14536 * cgraph.h (symtab_node_asm_name, symtab_node_name, dump_symtab,
14537 debug_symtab, dump_symtab_node, debug_symtab_node, dump_symtab_base):
14538 Declare.
14539 (cgraph_node_name, varpool_node_name): Remove.
14540 (cgraph_node_asm_name, varpool_node_asm_name,
14541 cgraph_node_name, varpool_node_name): New.
14542 * tree-pass.h (TODO_dump_cgraph): Rename to ...
14543 (TODO_dump_symtab): ... this one.
14544 * ipa-cp (pass_ipa_cp): Update.
14545 * ia-reference.c (generate_summary, read_write_all_from_decl,
14546 propagate, ipa_reference_read_optimization_summary): Update.
14547 * cgraphunit.c (cgraph_analyze_functions): Update.
14548 (cgraph_optimize): Update.
14549 * ipa-ref.c (ipa_dump_references): Update.
14550 (ipa_dump_refering): Update.
14551 * ipa-inline.c (pass_ipa_inline): Update.
14552 * matrix-reorg.c (pass_ipa_matrix_reorg): Update.
14553 * ipa.c (pass_ipa_function_visibility,
14554 pass_ipa_whole_program_visibility): Update.
14555 * tree-sra.c (pass_early_ipa_sra): Update.
14556 * symtab.c: Include langhooks.h
14557 (symtab_node_asm_name): New.
14558 (symtab_node_name): New.
14559 (symtab_type_names): New static var.
14560 (dump_symtab_base): New.
14561 (dump_symtab_node, dump_symtab): New.
14562 (debug_symtab_node, debug_symtab): New.
14563 * tree-ssa-structalias.c: Dump symbol table.
14564 * pases.c (execute_todo): Handle TODO_dump_symtab instead
14565 of TODO_dump_cgraph.
14566 * varpoo.c (varpool_node_name): Remove.
14567 (dump_varpool_node): Use dump_symtab_base; reformat.
14568
14569 2012-04-18 Manuel López-Ibáñez <manu@gcc.gnu.org>
14570
14571 * doc/invoke.texi (Language Independent Options): @item should be
14572 before @opindex.
14573
14574 2012-04-17 Richard Sandiford <rdsandiford@googlemail.com>
14575
14576 PR bootstrap/53021
14577 * rtl.c (rtx_code_size): Handle ADDRESS.
14578
14579 2012-04-17 Tom de Vries <tom@codesourcery.com>
14580
14581 * tree-iterator.c (append_to_statement_list_1): Handle case that *list_p
14582 is not a STMT_LIST.
14583
14584 2012-04-17 Uros Bizjak <ubizjak@gmail.com>
14585
14586 PR target/53020
14587 * config/i386/sync.md (atomic_<code><mode>): Rename to
14588 atomic_<logic><mode>.
14589
14590 2012-04-17 Richard Sandiford <rdsandiford@googlemail.com>
14591
14592 * rtl.def (ADDRESS): Turn operand into a HOST_WIDE_INT.
14593 * alias.c (reg_base_value): Expand and update comment.
14594 (arg_base_value): New variable.
14595 (unique_id): Move up file.
14596 (unique_base_value, unique_base_value_p, known_base_value_p): New.
14597 (find_base_value): Use arg_base_value and known_base_value_p.
14598 (record_set): Document REG_NOALIAS handling. Use unique_base_value.
14599 (find_base_term): Use known_base_value_p.
14600 (base_alias_check): Use unique_base_value_p.
14601 (init_alias_target): Initialize arg_base_value. Use unique_base_value.
14602 (init_alias_analysis): Use 1 as the first id for REG_NOALIAS bases.
14603
14604 2012-04-17 Pat Haugen <pthaugen@us.ibm.com>
14605
14606 * config/rs6000/rs6000.h (SLOW_UNALIGNED_ACCESS): Remove DImode.
14607
14608 2012-04-17 Michael Matz <matz@suse.de>
14609
14610 PR tree-optimization/18437
14611 * tree-vectorizer.h (_stmt_vec_info.stride_load_p): New member.
14612 (STMT_VINFO_STRIDE_LOAD_P): New accessor.
14613 (vect_check_strided_load): Declare.
14614 * tree-vect-data-refs.c (vect_check_strided_load): New function.
14615 (vect_analyze_data_refs): Use it to accept strided loads.
14616 * tree-vect-stmts.c (vectorizable_load): Ditto and handle them.
14617
14618 2012-04-17 Richard Guenther <rguenther@suse.de>
14619
14620 PR middle-end/53011
14621 * tree-eh.c (cleanup_empty_eh_merge_phis): Properly discard
14622 loops when redirecting an entry or latch edge.
14623
14624 2012-04-17 Bernd Schmidt <bernds@codesourcery.com>
14625
14626 * sel-sched.c (sel_global_init): Revert previous change.
14627
14628 2012-04-17 Richard Guenther <rguenther@suse.de>
14629
14630 * tree-flow.h (array_at_struct_end_p): Move declaration ...
14631 * tree.h (array_at_struct_end_p): ... here.
14632 * tree-ssa-loop-niter.c (array_at_struct_end_p): Move ...
14633 * expr.c (array_at_struct_end_p): ... here. Rewrite.
14634
14635 2012-04-17 Steven Bosscher <steven@gcc.gnu.org>
14636
14637 * stmt.c (cost_table_, use_cost_table, cost_table_initialize,
14638 COST_TABLE): Remove.
14639 (estimate_case_costs): Remove.
14640 (expand_case): Do not call estimate_case_costs
14641 to set use_cost_table.
14642 (balance_case_nodes): Do not use use_cost_table.
14643
14644 2012-04-16 Jan Hubicka <jh@suse.cz>
14645
14646 * cgraph.c (cgraph_hash, assembler_name_hash): Remove.
14647 (hash_node, eq_node): Remove.
14648 (cgraph_create_node): Do not handle hashtable.
14649 (cgraph_get_node): Remove.
14650 (cgraph_insert_node_to_hashtable): Remove.
14651 (hash_node_by_assembler_name): Remove.
14652 (eq_assembler_name): Remove.
14653 (cgraph_node_for_asm): Rewrite.
14654 (cgraph_find_replacement_node): Break out from ...
14655 (cgraph_remove_node): ... here; do not maintain hashtables.
14656 (change_decl_assembler_name): Remove.
14657 (cgraph_clone_node): Do not maintain hashtables.
14658 * cgraph.h (const_symtab_node): New typedef.
14659 (cgraph_insert_node_to_hashtable): Remove.
14660 (symtab_get_node, symtab_node_for_asm,
14661 symtab_insert_node_to_hashtable): Declare.
14662 (cgraph_find_replacement_node): Declare.
14663 (cgraph_get_node, varpool_get_node): Turn into inlines.
14664 (cgraph, varpool): Work sanely on NULL pointers.
14665 (FOR_EACH_SYMBOL): New walker.
14666 * ipa-inline-transform.c (save_inline_function_body): Use
14667 symtab_insert_node_to_hashtable.
14668 * symtab.c: Include ggc.h and diagnostics.h
14669 (symtab_hash, assembler_name_hash): New static vars;
14670 (hash_node, eq_node, hash_node_by_assembler_name,
14671 eq_assembler_name, insert_to_assembler_name_hash,
14672 unlink_from_assembler_name_hash): New.
14673 (symtab_register_node): Update hashtables.
14674 (symtab_insert_node_to_hashtable): New.
14675 (symtab_unregister_node): Update hashtables.
14676 (symtab_get_node): New.
14677 (symtab_node_for_asm): New.
14678 (change_decl_assembler_name): New.
14679 * Makefile.in (symtab.o): Needs GTY.
14680 * varpool.c (varpool_hash): Remove.
14681 (hash_varpool_node, eq_varpool_node, varpool_get_node): Remove.
14682 (varpool_node): Rewrite using varpool_get_node.
14683 (varpool_remove_node): DO not maintain hashtables.
14684 (varpool_node_for_asm): Rewrite.
14685
14686 2012-04-16 Sandra Loosemore <sandra@codesourcery.com>
14687
14688 * doc/invoke.texi: Copy-edit to put verbs in the present tense
14689 when describing the current behavior of GCC.
14690
14691 2012-04-16 Richard Sandiford <rdsandiford@googlemail.com>
14692
14693 * genemit.c (gen_exp): Remove ADDRESS handling.
14694 * genoutput.c (scan_operands): Likewise.
14695 * genpeep.c (match_rtx): Likewise.
14696 * genrecog.c (add_to_sequence): Likewise.
14697
14698 2012-04-16 David Edelsohn <dje.gcc@gmail.com>
14699
14700 * doc/install.texi (Specific, *-ibm-aix*): Update assembler bug status.
14701
14702 2012-04-16 Martin Jambor <mjambor@suse.cz>
14703
14704 * tree-sra.c (build_ref_for_model): Create COMPONENT_REFs only for
14705 bit-fields.
14706
14707 2012-04-16 Ulrich Weigand <ulrich.weigand@linaro.org>
14708
14709 PR target/51819
14710 * config/arm/arm.c (arm_print_operand): Fix invalid alignment
14711 hints for 'A' operand types.
14712
14713 2012-04-16 Jan Hubicka <jh@suse.cz>
14714
14715 * cgraph.h (symtab_node_base): Add next and previous pointers.
14716 (cgraph_node): Remove next and preivous pointers.
14717 (varpool_node): Likewise; remove next/previous GTY marker;
14718 it is not type safe.
14719 (symtab_node_def): Update GTY marker
14720 (x_cgraph_nodes, cgraph_nodes): Remove.
14721 (symtab_nodes): New function.
14722 (cgraph_order): Rename to ...
14723 (symtab_order): ... this one.
14724 (symtab_register_node, symtab_unregister_node, symtab_remove_node):
14725 Declare.
14726 (x_varpool_nodes, varpool_nodes): Remove.
14727 (FOR_EACH_STATIC_VARIABLE): Update.
14728 (symtab_function_p, symtab_variable_p): New function.
14729 (FOR_EACH_VARIABLE): Update.
14730 (varpool_first_variable, varpool_next_variable): New functions.
14731 (FOR_EACH_VARIABLE): Update.
14732 (cgraph_first_defined_function): Update.
14733 (cgraph_next_defined_function, cgraph_next_defined_function): Update.
14734 (FOR_EACH_DEFINED_FUNCTION, FOR_EACH_FUNCTION): Update.
14735 (cgraph_first_function, cgraph_next_function): New.
14736 (FOR_EACH_FUNCTION): Update.
14737 (cgraph_first_function_with_gimple_body,
14738 cgraph_next_function_with_gimple_body): Update.
14739 * symtab.c: New file.
14740 * cgraph.c: Update copyright dates.
14741 (x_cgraph_nodes, cgraph_order): Remove.
14742 (NEXT_FREE_NODE): Update.
14743 (SET_NEXT_FREE_NODE): New.
14744 (cgraph_create_node_1): Remove common code.
14745 (cgraph_create_node): Remove common code; call symtab_register_node.
14746 (cgraph_remove_node): Remove common code; call symtab_unregister-node.
14747 (cgraph_add_asm_node): Update.
14748 (cgraph_clone_node): Register new node.
14749 * cgraphunit.c (process_function_and_variable_attributes): Update.
14750 (cgraph_analyze_functions): Update.
14751 (cgraph_analyze_functions): Update.
14752 (cgraph_output_in_order): Update.
14753 * lto-cgraph.c (input_node, input_varpool_node, input_cgraph_1):
14754 Update.
14755 * ipa-inline.c (recursive_inlining): Update.
14756 * lto-streamer-in.c (lto_input_toplevel_asms): Update.
14757 * ipa.c (cgraph_remove_unreachable_nodes): Update.
14758 * Makefile.in: Add symtab.o
14759 * varpool.c (x_varpool_nodes): Remove
14760 (varpool_node): Remove common code; call symtab_register_node.
14761 (varpool_remove_node): Remove common code; call symtab_unregister_node.
14762
14763 2012-04-16 Richard Guenther <rguenther@suse.de>
14764
14765 PR middle-end/52977
14766 * tree.h (VECTOR_CST_NELTS): Adjust.
14767 (struct tree_vector): Add explicit length field.
14768 (make_vector_stat): Declare.
14769 (make_vector): Define.
14770 * tree.c (make_vector_stat): New function.
14771 (build_vector_stat): Use it.
14772 * tree-streamer-in.c (streamer_alloc_tree): Likewise.
14773
14774 2012-04-16 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
14775
14776 PR tree-optimization/52976
14777 * tree-ssa-reassoc.c (add_to_ops_vec_max_rank): New function.
14778 (undistribute_ops_list): Ops with repeat counts aren't eligible for
14779 undistribution.
14780 (attempt_builtin_powi): Call add_to_ops_vec_max_rank.
14781
14782 2012-04-16 Jan Hubicka <jh@suse.cz>
14783
14784 * cgraph.h (FOR_EACH_VARIABLE, FOR_EACH_VARIABLE, FOR_EACH_FUNCTION):
14785 New macros.
14786 * lto-symtab.c (lto_symtab_merge_cgraph_nodes): Use FOR_EACH
14787 walkers to walk cgraph and varpool.
14788 * cgraph.c (cgraph_node_for_asm): Likewise.
14789 (dump_cgraph): Likewise.
14790 * value-prof.c (init_node_map): Likewise.
14791 * tree.c (free_lang_data_in_cgraph): Likewise.
14792 * tree-emutls.c: (ipa_lower_emutls): Likewise.
14793 * ipa-reference.c (generate_summary, propagate): Likewise.
14794 * cgraphunit.c (verify_cgraph, cgraph_process_same_body_aliases,
14795 cgraph_mark_functions_to_output, cgraph_output_in_order,
14796 output_weakrefs, cgraph_materialize_all_clones,
14797 cgraph_optimize): Likewise.
14798 * lto-cgraph.c (merge_profile_summaries): Likewise.
14799 (input_cgraph): Likewise.
14800 * ipa-pure-const.c (generate_summary): Likewise.
14801 (propagate): Likwise.
14802 * ipa-utils.c (ipa_reduced_postorder): Likewise.
14803 (ipa_free_postorder_info): Likewise.
14804 (ipa_reverse_postorder): Likewise.
14805 * ipa-inline.c (ipa_inline): Likewise.
14806 * matrix-reorg.c (find_matrices_decl): Likewise.
14807 (matrix_reorg): Likewise.
14808 * tree-vectorizer.c (increase_alignment): Likewise.
14809 * ipa.c (cgraph_remove_unreachable_nodes): Likewise.
14810 (function_and_variable_visibility): Likewise.
14811 (whole_program_function_and_variable_visibility): Likewise.
14812 (ipa_cdtor_merge): Likewise.
14813 * trans-mem.c (ipa_tm_execute): Likewise.
14814 * ipa-inline-analysis.c (dump_inline_summaries): Likewise.
14815 * ipa-prop.c (ipa_print_all_jump_functions): Likewise.
14816 (ipa_print_all_params): Likewise.
14817 (ipa_update_after_lto_read): Likewise.
14818 * tree-profie.c (tree_profiling): Likewise.
14819 * tree-ssa-structalias.c (ipa_pta_execute): Likewise.
14820 * passes.c (dump_passes): Likewise.
14821 (do_per_function): Likewise.
14822 (ipa_write_summaries): Likewise.
14823 * varpool.c (dump_varpool): Likewise.
14824 (varpool_node_for_asm): Likewise.
14825 (varpool_assemble_pending_decls): Likewise.
14826
14827 2012-04-16 Richard Guenther <rguenther@suse.de>
14828
14829 PR tree-optimization/52975
14830 * tree-if-conv.c (predicate_bbs): Do not simplify inverted
14831 condition but always mark it with TRUTH_NOT_EXPR.
14832
14833 2012-04-16 Richard Guenther <rguenther@suse.de>
14834
14835 PR tree-optimization/52975
14836 * tree-ssa-forwprop.c (combine_cond_exprs): New function.
14837 (ssa_forward_propagate_and_combine): Call it for COND_EXPRs
14838 and VEC_COND_EXPRs. Also combine into VEC_COND_EXPRs condition.
14839 * fold-const.c (operand_equal_p): Handle TARGET_MEM_REF.
14840
14841 2012-04-14 Uros Bizjak <ubizjak@gmail.com>
14842
14843 * config/i386/sse.md (ssse3_plusminus): New code iterator.
14844 (avx2_ph<plusminus_mnemonic>wv16hi3): Macroize insn from
14845 avx2_ph{add,adds,sub,subs}wv16hi3 using ssse3_plusminus code iterator.
14846 (ssse3_ph<plusminus_mnemonic>wv8hi3): Macroize insn from
14847 ssse3_ph{add,adds,sub,subs}wv8hi3 using ssse3_plusminus code iterator.
14848 (ssse3_ph<plusminus_mnemonic>wv4hi3): Macroize insn from
14849 ssse3_ph{add,adds,sub,subs}wv4hi3 using ssse3_plusminus code iterator.
14850
14851 (avx2_ph<plusminus_mnemonic>dv8si3): Macroize insn from
14852 avx2_ph{add,adds,sub,subs}dv8si3 using plusminus code iterator.
14853 (ssse3_ph<plusminus_mnemonic>dv4si3): Macroize insn from
14854 ssse3_ph{add,adds,sub,subs}dv4si3 using plusminus code iterator.
14855 (ssse3_ph<plusminus_mnemonic>dv2si3): Macroize insn from
14856 ssse3_ph{add,adds,sub,subs}dv2si3 using plusminus code iterator.
14857
14858 (xop_plus): New code iterator.
14859 (macs): New code attribute.
14860 (macds): Ditto.
14861 (xop_p<macs><ssemodesuffix><ssemodesuffix>): Macroize insn from
14862 xop_pmacs{,s}{ww,dd} using xop_plus code iterator and VI24_128 mode
14863 iterator.
14864 (xop_p<macs>dql): Macroize insn from xop_pmacs{,s}dql using
14865 xop_plus code iterator.
14866 (xop_p<macs>dqh): Macroize insn from xop_pmacs{,s}dqh using
14867 xop_plus code iterator.
14868 (xop_p<macs>wd): Macroize insn from xop_pmacs{,s}wd using
14869 xop_plus code iterator.
14870 (xop_p<madcs>wd): Macroize insn from xop_pmadcs{,s}wd using
14871 xop_plus code iterator.
14872
14873 (xop_phadd<u>bw): Macroize insn from xop_phadd{,u}bw usign
14874 any_extend code iterator.
14875 (xop_phadd<u>bd): Macroize insn from xop_phadd{,u}bd usign
14876 any_extend code iterator.
14877 (xop_phadd<u>bq): Macroize insn from xop_phadd{,u}bq usign
14878 any_extend code iterator.
14879 (xop_phadd<u>wd): Macroize insn from xop_phadd{,u}wd usign
14880 any_extend code iterator.
14881 (xop_phadd<u>wq): Macroize insn from xop_phadd{,u}wq usign
14882 any_extend code iterator.
14883 (xop_phadd<u>dq): Macroize insn from xop_phadd{,u}dq usign
14884 any_extend code iterator.
14885
14886 2012-04-14 Tom de Vries <tom@codesourcery.com>
14887
14888 * cfgcleanup.c (try_optimize_cfg): Replace call to delete_insn_chain by
14889 call to delete_insn. Remove code to reorder BASIC_BLOCK note and
14890 DELETED_LABEL note, and move it to ...
14891 * cfgrtl.c (delete_insn): ... here. Change return type to void.
14892 (delete_insn_and_edges): Likewise.
14893 (delete_insn_chain): Handle new return type of delete_insn. Delete
14894 chain backwards rather than forwards.
14895 * rtl.h (delete_insn, delete_insn_and_edges): Change return type to
14896 void.
14897 * cfglayout.c (fixup_reorder_chain): Delete unused label.
14898
14899 2012-04-14 Jan Hubicka <jh@suse.cz>
14900
14901 * cgraph.h: Update copyrights;
14902 (symtab_node): Turn to union typedef.
14903 (symtab_node_base): New structure.
14904 (symtab_type): Add SYMTAB_SYMBOL tag.
14905 (cgraph_node): Annotate some pinters with nested_ptr.
14906 (varpool_node): Likewise.
14907 (cgraph_local_info): Remove lto_file_data
14908 and externally_visible.
14909 (cgraph_node): Remove decl; same_comdat_group list;
14910 aux; ref_list; order; address_taken; reachable_from_other_parittion,
14911 in_other_partition; resolution.
14912 (varpool_node): Remove decl; same_comdat_group;
14913 ref_list; lto_file_data; aux; order; resolution; externally_visible;
14914 used_from_other_partition; in_other_partition.
14915 (symtab_node_def): New union.
14916 (cgraph, varpool): Update.
14917 (varpool_first_static_initializer, varpool_next_static_initializer,
14918 cgraph_only_called_directly_or_aliased_p,
14919 varpool_can_remove_if_no_refs, varpool_can_remove_if_no_refs,
14920 varpool_all_refs_explicit_p, cgraph_alias_aliased_node,
14921 varpool_alias_aliased_node, cgraph_edge_recursive_p): Update
14922 field references.
14923 * cgraph.c: Likewise.
14924 (cgraph_hash, assembler_name_hash): Turn into symtab_node.
14925 * cgraphbuild.c: Likewise.
14926 * lto-symtab.c: Likewise.
14927 * c-gimplify.c: Likewise.
14928 * value-prof.c: Likewise.
14929 * tree.c: Likewise.
14930 * ipa-cp.c: Likewise.
14931 * tree-emutls.c: Likewise.
14932 * ipa-inline-transform.c: Likwise.
14933 * ipa-reference.c: Likewise.
14934 * cgraphunit.c: Likewise.
14935 * ipa-ref.c: Likewise.
14936 * lto-cgraph.c: Likewise.
14937 * ipa-ref-inline.h: Likewise.
14938 * ipa-pure-const.c: Likewise.
14939 * lto-streamer-out.c: Likewise.
14940 * ipa-utils.c: Likewise.
14941 * ipa-inline.c: Likewise.
14942 * matrix-reorg.c: Likewise.
14943 * tree-eh.c: Likewise.
14944 * tree-vectorizer.c: Likewise.
14945 * ipa-split.c: Likewise.
14946 * ipa.c: Likewise.
14947 * trans-mem.c: Likewise.
14948 * ipa-inline-analysis.c: Likewise.
14949 * gimplify.c: Likewise.
14950 * cfgexpand.c: Likewise.
14951 * tree-sra.c: Likewise.
14952 * ipa-prop.c: Likewise.
14953 * varasm.c: Likewise.
14954 * tree-nested.c: Likewise.
14955 * tree-inline.c: Likewise.
14956 * tree-profile.c: Likewise.
14957 * tree-ssa-structalias.c: Likewise.
14958 * passes.c: Likewise.
14959 * varpool.c: Likewise.
14960
14961 2012-04-14 Tom de Vries <tom@codesourcery.com>
14962
14963 * tree-ssa-tail-merge.c (stmt_local_def): New function, factored out of
14964 same_succ_hash, with local_def inlined. Use SINGLE_SSA_DEF_OPERAND.
14965 Use FOR_EACH_IMM_USE_FAST instead of FOR_EACH_IMM_USE_STMT. Remove use
14966 of find_edge.
14967 (gsi_advance_fw_nondebug_nonlocal): New function.
14968 (local_def): Removed function.
14969 (same_succ_hash): Use stmt_local_def.
14970 (same_succ_equal): Use gsi_advance_fw_nondebug_nonlocal.
14971 (gsi_advance_bw_nondebug_nonlocal): Use stmt_local_def.
14972
14973 2012-04-13 H.J. Lu <hongjiu.lu@intel.com>
14974
14975 * config/i386/i386-c.c (ix86_target_macros): Define _ILP32
14976 and __ILP32__ for x32.
14977
14978 2012-04-13 Martin Jambor <mjambor@suse.cz>
14979
14980 PR middle-end/52939
14981 * gimple-fold.c (gimple_get_virt_method_for_binfo): Bail out if
14982 fold_ctor_reference returns a zero constant.
14983
14984 2012-04-13 Enkovich Ilya <ilya.enkovich@intel.com>
14985
14986 * config.gcc: Add i386/gnu-user-common.h before all
14987 i386/gnu-user.h and i386/gnu-user64.h usages.
14988
14989 * config/i386/gnu-user-common.h: New.
14990
14991 * config/i386/gnu-user.h (CPP_SPEC): Moved to gnu-user-common.h.
14992 (CC1_SPEC): Likewise.
14993 (ENDFILE_SPEC): Likewise.
14994 (DEFAULT_PCC_STRUCT_RETURN): Likewise.
14995 (TARGET_TLS_DIRECT_SEG_REFS_DEFAULT): Likewise.
14996 (TARGET_OS_CPP_BUILTINS): Likewise.
14997 (LIBGCC2_HAS_TF_MODE): Likewise.
14998 (LIBGCC2_TF_CEXT): Likewise.
14999 (TF_SIZE): Likewise.
15000 (TARGET_ASM_FILE_END): Likewise.
15001 (STACK_CHECK_MOVING_SP): Likewise.
15002 (STACK_CHECK_STATIC_BUILTIN): Likewise.
15003 * config/i386/gnu-user64.h: Likewise.
15004
15005 2012-04-13 Martin Jambor <mjambor@suse.cz>
15006
15007 * expr.c (expand_expr_real_1): Pass type, not the expression, to
15008 set_mem_attributes for a memory temporary. Do not call the function
15009 for the memory temporary created for a bitfield.
15010
15011 2012-04-13 Alexandre Oliva <aoliva@redhat.com>
15012
15013 PR debug/48866
15014 * df.h (enum debug_temp_where): New.
15015 (dead_debug_init, dead_debug_finish) Declare.
15016 (dead_debug_add, dead_debug_insert_temp): Declare.
15017 (struct dead_debug_use, struct dead_debug): Moved from...
15018 * df-problems.c: ... here.
15019 (df_set_unused_notes_for_mw): Bind debug uses of unused regno
15020 to a debug temp.
15021 (df_create_unused_note): Likewise.
15022 (df_set_dead_notes_for_mw): Move comment where it belongs.
15023 (dead_debug_init): Export.
15024 (dead_debug_reset_uses): New, factored out of...
15025 (dead_debug_finish): ...this. Export.
15026 (dead_debug_reset): Remove.
15027 (dead_debug_add): Export.
15028 (dead_debug_insert_before): Rename to...
15029 (dead_debug_insert_temp): ... this. Add where argument. Export.
15030 Locate stored value for BEFORE_WITH_VALUE. Avoid repeat inserts.
15031 Return insertion count.
15032 (df_note_bb_compute): Adjust.
15033 * dce.c (word_dce_process_block): Adjust dead debug uses.
15034 (dce_process_block): Likewise.
15035
15036 2012-04-13 Alexandre Oliva <aoliva@redhat.com>
15037
15038 * df-problems.c (df_note_bb_compute): Do not take note of
15039 debug uses for whose REGs we won't emit DEAD or UNUSED notes.
15040
15041 2012-04-13 Alexandre Oliva <aoliva@redhat.com>
15042
15043 PR debug/51570
15044 * var-tracking.c (expand_depth): New type.
15045 (onepart_aux, expand_loc_callback_data): Change depth type to it.
15046 (loc_exp_dep_alloc): Adjust initializer.
15047 (update_depth): Use new type. Add entryvals.
15048 (vt_expand_var_loc_chain): Take note of expansions with
15049 ENTRY_VALUEs, but don't accept them right away. Run an optional
15050 second pass accepting the minimum ENTRY_VALUE count found in the
15051 first pass.
15052 (vt_expand_loc_callback, INIT_ELCD): Adjust.
15053
15054 2012-04-13 Tom de Vries <tom@codesourcery.com>
15055
15056 * tree-ssa-tail-merge.c (gsi_advance_bw_nondebug_nonlocal): Add
15057 parameters vuse and vuse_escaped.
15058 (find_duplicate): Init vuse1, vuse2 and vuse_escaped. Pass to
15059 gsi_advance_bw_nondebug_nonlocal. Return if vuse_escaped and
15060 vuse1 != vuse2.
15061
15062 2012-04-13 Richard Guenther <rguenther@suse.de>
15063
15064 PR tree-optimization/52969
15065 * tree-if-conv.c (predicate_mem_writes): Properly gimplify
15066 the condition for the COND_EXPR and handle predicate negation
15067 by swapping the COND_EXPR arms.
15068
15069 2012-04-13 Nick Clifton <nickc@redhat.com>
15070
15071 * config/rl78/rl78.c (rl78_devirt_pass): Remove use of
15072 TODO_dump_func flag.
15073
15074 2012-04-13 Andrey Belevantsev <abel@ispras.ru>
15075
15076 PR rtl-optimization/52203
15077 PR rtl-optimization/52715
15078
15079 Revert the 2012-03-07 fix for PR 52203.
15080 * sel-sched.c (reset_sched_cycles_in_current_ebb): Check that
15081 the insn does not modify DFA right before issuing, adjust
15082 issue_rate accordingly.
15083
15084 2012-04-13 Richard Guenther <rguenther@suse.de>
15085
15086 PR c/52549
15087 * c-typeck.c (pointer_diff): Remove bogus assert.
15088
15089 2012-04-13 Richard Guenther <rguenther@suse.de>
15090
15091 PR c/52862
15092 * convert.c (convert_to_pointer): Remove special-casing of zero.
15093
15094 2012-04-13 Joey Ye <joey.ye@arm.com>
15095
15096 * config/arm/constraints.md (Pe): New constraint.
15097 * config/arm/arm.md: New split for imm 256-510.
15098
15099 2012-04-13 Terry Guo <terry.guo@arm.com>
15100
15101 * config/arm/arm-cores.def: Added core cortex-m0plus.
15102 * config/arm/arm-tune.md: Regenerated.
15103 * config/arm/arm-tables.opt: Regenerated.
15104 * doc/invoke.texi: Added entry for cpu ARM cortex-m0plus.
15105
15106 2012-04-13 Alan Modra <amodra@gmail.com>
15107
15108 PR target/52828
15109 * config/rs6000/rs6000.c (rs6000_emit_stack_tie): Rewrite with
15110 tie regs on destination of sets. Delete forward declaration.
15111 (rs6000_emit_stack_reset): Update rs6000_emit_stack_tie calls.
15112 (rs6000_emit_prologue): Likewise.
15113 (rs6000_emit_epilogue): Likewise. Use in place of gen_frame_tie
15114 and gen_stack_tie.
15115 (is_mem_ref): Use tie_operand to recognise stack ties.
15116 * config/rs6000/predicates.md (tie_operand): New.
15117 * config/rs6000/rs6000.md (restore_stack_block): Generate new
15118 stack tie rtl.
15119 (restore_stack_nonlocal): Likewise.
15120 (stack_tie): Update.
15121 (frame_tie): Delete.
15122
15123 2012-04-12 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
15124
15125 * tree-ssa-reassoc.c (attempt_builtin_powi_stats): Change %ld to
15126 HOST_WIDE_INT_PRINT_DEC in format strings.
15127
15128 2012-04-12 Uros Bizjak <ubizjak@gmail.com>
15129
15130 PR target/52932
15131 * config/i386/avx2intrin.h (_mm256_permutevar8x32_ps): Change second
15132 argument type to __m256i. Update call to __builtin_ia32_permvarsf256.
15133 * config/i386/sse.md (UNSPEC_VPERMVAR): New.
15134 (UNSPEC_VPERMSI, UNSPEC_VPERMSF): Remove.
15135 (avx2_permvarv8sf, avx2_permvarv8si): Switch operands 1 and 2.
15136 (avx2_permvar<mode>): Macroize insn from avx2_permvarv8sf and
15137 avx2_permvarv8si using VI4F_256 mode iterator.
15138 * config/i386/i386.c (bdesc_args) <__builtin_ia32_permvarsf256>:
15139 Update builtin type to V8SF_FTYPE_V8SF_V8SI.
15140 (ix86_expand_vec_perm): Update calls to gen_avx2_permvarv8si and
15141 gen_avx2_permvarv8sf.
15142 (expand_vec_perm_pshufb): Ditto.
15143
15144 2012-04-12 Michael Meissner <meissner@linux.vnet.ibm.com>
15145
15146 PR target/52775
15147 * config/rs6000/rs6000.h (TARGET_FCFID): Add TARGET_PPC_GPOPT to
15148 the list of options to enable the FCFID instruction.
15149 (TARGET_EXTRA_BUILTINS): Adjust comment.
15150
15151 2012-04-12 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
15152
15153 PR tree-optimization/18589
15154 * tree-ssa-reassoc.c (reassociate_stats): Add two fields.
15155 (operand_entry): Add count field.
15156 (add_repeat_to_ops_vec): New function.
15157 (completely_remove_stmt): Likewise.
15158 (remove_def_if_absorbed_call): Likewise.
15159 (remove_visited_stmt_chain): Remove feeding builtin pow/powi calls.
15160 (acceptable_pow_call): New function.
15161 (linearize_expr_tree): Look for builtin pow/powi calls and add operand
15162 entries with repeat counts when found.
15163 (repeat_factor_d): New struct and associated typedefs.
15164 (repeat_factor_vec): New static vector variable.
15165 (compare_repeat_factors): New function.
15166 (get_reassoc_pow_ssa_name): Likewise.
15167 (attempt_builtin_powi): Likewise.
15168 (reassociate_bb): Call attempt_builtin_powi.
15169 (fini_reassoc): Two new calls to statistics_counter_event.
15170
15171 2012-04-12 Richard Guenther <rguenther@suse.de>
15172
15173 * Makefile.in (cgraphunit.o): Add $(EXCEPT_H) dependency.
15174 * cgraph.h (tree_rest_of_compilation): Remove.
15175 * cgraph.c (cgraph_add_new_function): Move ...
15176 * cgraphunit.c (cgraph_add_new_function): ... here.
15177 (tree_rest_of_compilation): Make static.
15178 (cgraph_expand_function): Do not set cgraph_function_flags_ready.
15179 * tree-optimize.c (gate_all_optimizations, pass_all_optimizations,
15180 gate_all_early_local_passes, execute_all_early_local_passes,
15181 pass_early_local_passes, gate_all_early_optimizations,
15182 pass_all_early_optimizations): Move ...
15183 * passes.c (gate_all_optimizations, pass_all_optimizations,
15184 gate_all_early_local_passes, execute_all_early_local_passes,
15185 pass_early_local_passes, gate_all_early_optimizations,
15186 pass_all_early_optimizations): ... here.
15187 * tree-optimize.c (execute_free_datastructures): Remove.
15188 * tree-flow.h (execute_free_datastructures): Remove.
15189 * tree-optimize.c (execute_init_datastructures,
15190 pass_init_datastructures): Move ...
15191 * tree-ssa.c (execute_init_datastructures,
15192 pass_init_datastructures): ... here.
15193 * cfgexpand.c (gimple_expand_cfg): Inline-expand call to
15194 execute_free_datastructures.
15195
15196 2012-04-12 Bernd Schmidt <bernds@codesourcery.com>
15197
15198 * dbgcnt.def (ira_move): New counter.
15199 * ira-int.h (ira_create_new_reg): Declare function.
15200 (first_moveable_pseudo, last_moveable_pseudo): Declare variables.
15201 * ira-emit.c (ira_create_new_reg): Renamed from craete_new_reg and
15202 no longer static. All callers changed.
15203 * ira.c: Include "dbgcnt.h".
15204 (rtx_moveable_p, insn_dominated_by_p, find_moveable_pseudos,
15205 move_unallocated_pseudos): New static functions.
15206 (first_moveable_pseudo, last_moveable_pseudo): New global variables.
15207 (pseudo_replaced_reg, pseudo_move_insn): New static variables.
15208 (ira): Call find_moveable_pseudos and move_unallocated_pseudos.
15209 * ira-costs.c (find_costs_and_classes): Assign a memory cost of zero
15210 to the pseudos generated in find_moveable_pseudos.
15211 * Makefile.in (ira.o): Add $(DBGCNT_H).
15212
15213 2012-04-12 Richard Guenther <rguenther@suse.de>
15214
15215 PR tree-optimization/52943
15216 * tree-chrec.h (chrec_is_positive): Remove.
15217 * tree-scalar-evolution.c (chrec_is_positive): Move ...
15218 * tree-data-ref.c (chrec_is_positive): ... here. Make static.
15219 Return false for a constant zero instead of negative.
15220 (analyze_siv_subscript_cst_affine): Handle zero difference
15221 in the initial condition explicitely.
15222
15223 2012-04-12 Richard Guenther <rguenther@suse.de>
15224
15225 * tree-parloops.c (parallelize_loops): Also consult the upper
15226 bound for the number of iterations.
15227 * tree-ssa-loop-prefetch.c (determine_loop_nest_reuse): Likewise.
15228 (loop_prefetch_arrays): Likewise.
15229
15230 2012-04-12 Richard Guenther <rguenther@suse.de>
15231
15232 * cfgloop.h (estimated_loop_iterations_int): Ditch
15233 'conservative' parameter.
15234 (max_stmt_executions_int): Likewise.
15235 (estimated_loop_iterations): Likewise.
15236 (max_stmt_executions): Likewise.
15237 (max_loop_iterations): Declare.
15238 (max_loop_iterations_int): Likewise.
15239 (estimated_stmt_executions): Likewise.
15240 (estimated_stmt_executions_int): Likewise.
15241 * tree-ssa-loop-niter.c (estimated_loop_iterations):
15242 Split parts to ...
15243 (max_loop_iterations): ... this.
15244 (estimated_loop_iterations_int): Split parts to ...
15245 (max_loop_iterations_int): ... this.
15246 (max_stmt_executions_int): Split parts to ...
15247 (estimated_stmt_executions_int): ... this.
15248 (max_stmt_executions): Split parts to ...
15249 (estimated_stmt_executions): ... this.
15250 * graphite-sese-to-poly.c (build_loop_iteration_domains): Adjust.
15251 * predict.c (predict_loops): Likewise.
15252 * tree-data-ref.c (max_stmt_executions_tree): Likewise.
15253 (analyze_siv_subscript_cst_affine): Likewise.
15254 (compute_overlap_steps_for_affine_1_2): Likewise.
15255 (analyze_subscript_affine_affine): Likewise.
15256 (init_omega_for_ddr_1): Likewise.
15257 * tree-parloops.c (parallelize_loops): Likewise.
15258 * tree-ssa-loop-ivopts.c (avg_loop_niter): Likewise.
15259 (may_eliminate_iv): Likewise.
15260 * tree-ssa-loop-prefetch.c (determine_loop_nest_reuse): Likewise.
15261 (loop_prefetch_arrays): Likewise.
15262 * tree-vrp.c (adjust_range_with_scev): Likewise.
15263
15264 2012-04-12 Oleg Endo <olegendo@gcc.gnu.org>
15265
15266 * config/sh/sh.h (RETURN_ADDR_RTX): Use NULL_RTX instead of 0.
15267 * config/sh/sh.c (INSN_REGMODE_WEIGHT, CURR_REGMODE_PRESSURE):
15268 Fix line width.
15269 (dump_table): Use bool type for need_align and have_df variables.
15270 (find_barrier, sfunc_uses_reg): Use NULL_RTX instead of 0.
15271 (regs_used): Remove register modifier.
15272 (barrier_align): Move variables slot, credit, jump_to_next
15273 into if block above for loop. Use bool type for jump_to_next.
15274 (sh_function_arg): Use NULL_RTX instead of 0.
15275
15276 2012-04-11 Andreas Schwab <schwab@linux-m68k.org>
15277
15278 * config/m68k/m68k.md (rotrhi3+1): Name it rotrhi_lowpart.
15279 (bswapsi2): New expander.
15280
15281 2012-04-11 H.J. Lu <hongjiu.lu@intel.com>
15282
15283 * config/host-linux.c (TRY_EMPTY_VM_SPACE): Defined to
15284 0x60000000 if __x86_64 is defined and __LP64__ isn't defined.
15285
15286 2012-04-11 H.J. Lu <hongjiu.lu@intel.com>
15287
15288 PR rtl-optimization/52876
15289 * emit-rtl.c (set_reg_attrs_from_value): Handle arbitrary value.
15290 Don't call mark_reg_pointer for incompatible pointer sign extension.
15291
15292 * reginfo.c (reg_scan_mark_refs): Call set_reg_attrs_from_value
15293 directly.
15294
15295 2012-04-11 Bernd Schmidt <bernds@codesourcery.com>
15296
15297 * fold-const.c (fold_unary_loc): Use GET_MODE_PRECISION for
15298 comparisons against TYPE_PRECISION.
15299 * tree-ssa-forwprop.c (combine_conversions): Likewise.
15300
15301 2012-04-11 Xinliang David Li <davidxl@google.com>
15302
15303 * tree-passes.h: Remove TODO_dump_func.
15304 * tree-ssa-tail-merge.c (tail_merge_optimize): Remove TODO_dump_func.
15305 * trans-mem.c: Remove TODO_dump_func.
15306 * ira.c: Remove TODO_dump_func.
15307
15308 2012-04-11 H.J. Lu <hongjiu.lu@intel.com>
15309
15310 * config/i386/i386.c (ix86_option_override_internal): Check
15311 SUBTARGET_OVERRIDE_OPTIONS and SUBSUBTARGET_OVERRIDE_OPTIONS
15312 after TARGET_64BIT is updated.
15313
15314 2012-04-11 Oleg Endo <olegendo@gcc.gnu.org>
15315
15316 * config/sh/sh.h: Remove old secondary reload code.
15317
15318 2012-04-11 Oleg Endo <olegendo@gcc.gnu.org>
15319
15320 * config/sh/sh.c (SCHED_REORDER): Merge macro into ...
15321 (ready_reorder): ... this function.
15322
15323 2012-04-11 Bernd Schmidt <bernds@codesourcery.com>
15324
15325 * sel-sched.c (sel_global_init): Swap order of sched_rgn_init and
15326 sched_init calls.
15327
15328 * haifa-sched.c (prune_ready_list): Rework handling of SCHED_GROUP_P
15329 insns so that no other insn is queued for a time before them.
15330
15331 * config/c6x/c6x.md (load_got_gotoff): Set op_pattern attribute to
15332 unknown.
15333
15334 2012-04-11 Richard Guenther <rguenther@suse.de>
15335
15336 PR middle-end/52621
15337 * tree-chrec.c (evolution_function_is_invariant_rec_p): Properly
15338 consider loop nesting.
15339 (evolution_function_is_univariate_p): Properly check the remainder
15340 for chrecs.
15341
15342 2012-04-11 Richard Guenther <rguenther@suse.de>
15343
15344 PR middle-end/52918
15345 * except.c (sjlj_emit_dispatch_table): Properly update loop structure.
15346
15347 2012-04-11 Nick Clifton <nickc@redhat.com>
15348
15349 * config/rl78/rl78.c (rl78_expand_prologue): Set stack use
15350 information, if requested.
15351
15352 * config/rx/rx.c (rx_expand_prologue): Likewise.
15353
15354 2012-04-11 Peter Bergner <bergner@vnet.ibm.com>
15355 Michael Matz <matz@suse.de>
15356
15357 PR target/16458
15358 * rtlanal.c (unsigned_reg_p): New function.
15359 Update copyright notice dates.
15360 * rtl.h (unsigned_reg_p): Prototype it.
15361 Update copyright notice dates.
15362 * config/rs6000/rs6000.c (rs6000_generate_compare): Use it.
15363 Update comment.
15364 * expr.c (expand_expr_real_1): Set register attributes.
15365 * stmt.c (expand_case): Likewise.
15366
15367 2012-04-11 Oleg Endo <olegendo@gcc.gnu.org>
15368
15369 PR target/50751
15370 * config/sh/sh-protos.h (sh_legitimate_index_p): Add new arguments
15371 consider_sh2a and allow_zero.
15372 * config/sh/sh.c (sh_legitimate_index_p): Likewise.
15373 (disp_addr_displacement): New function.
15374 (sh_address_cost): Use disp_addr_displacement function instead
15375 of DISP_ADDR_OFFSET.
15376 (sh_legitimate_address_p): Adapt to changed
15377 sh_legitimate_index_p declaration.
15378 (sh_find_mov_disp_adjust): Remove HImode check.
15379 (sh_secondary_reload): Add HImode case. Use satisfies_constraint_Sdd,
15380 disp_addr_displacement and max_mov_insn_displacement.
15381 (max_mov_insn_displacement): Remove HImode check.
15382 * config/sh/sh.h (CONST_OK_FOR_K04, CONST_OK_FOR_K12,
15383 DISP_ADDR_P, DISP_ADDR_OFFSET): Remove.
15384 * config/sh/constraints.md (K05, K13): New constraints.
15385 (K12): Correct comment.
15386 (Sdd): Do not use DISP_ADDR_P macro.
15387 (Snd, Sbw): Use satisfies_constraint_Sdd.
15388 * config/sh/sh.md (extendhisi2): Remove constraints from expander.
15389 (*extendhisi2_compact, movhi_i): Remove.
15390 (*extendhisi2_compact_reg, *extendhisi2_compact_mem_disp,
15391 *extendhisi2_compact_mem_disp, *extendhisi2_compact_snd,
15392 *movhi_reg_reg, *movhi_store_mem_disp05, *movhi_store_mem_disp13,
15393 *movhi_load_mem_disp, *movhi_load_mem_disp, *movhi): New insns.
15394 (*extendqisi2_compact_mem_disp, *extendqisi2_compact_mem_disp,
15395 *movqi_store_mem_disp04, *movqi_store_mem_disp12, *movqi_load_mem_disp,
15396 *movqi_load_mem_disp): Use sh_legitimate_index_p instead of
15397 CONST_OK_FOR_Kxx.
15398 Add new peepholes for HImode displacement addressing.
15399
15400 2012-04-11 Oleg Endo <olegendo@gcc.gnu.org>
15401
15402 * config/sh/sh.h (SIDI_OFF): Remove.
15403 * config/sh/sh.md: Use gen_highpart and gen_lowpart to access
15404 DImode subregs instead of gen_rtx_REG or simplifly_gen_subreg
15405 or operand_subword.
15406
15407 2012-04-11 Eric Botcazou <ebotcazou@adacore.com>
15408
15409 PR target/52624
15410 * doc/extend.texi (Other Builtins): Document __builtin_bswap16.
15411 (PowerPC AltiVec/VSX Built-in Functions): Remove it.
15412 * doc/md.texi (Standard Names): Add bswap.
15413 * builtin-types.def (BT_UINT16): New primitive type.
15414 (BT_FN_UINT16_UINT16): New function type.
15415 * builtins.def (BUILT_IN_BSWAP16): New.
15416 * builtins.c (expand_builtin_bswap): Add TARGET_MODE argument.
15417 (expand_builtin) <BUILT_IN_BSWAP16>: New case. Pass TARGET_MODE to
15418 expand_builtin_bswap.
15419 (fold_builtin_bswap): Add BUILT_IN_BSWAP16 case.
15420 (fold_builtin_1): Likewise.
15421 (is_inexpensive_builtin): Likewise.
15422 * optabs.c (expand_unop): Deal with bswap in HImode specially. Add
15423 missing bits for bswap to libcall code.
15424 * tree.c (build_common_tree_nodes): Build uint16_type_node.
15425 * tree.h (enum tree_index): Add TI_UINT16_TYPE.
15426 (uint16_type_node): New define.
15427 * config/rs6000/rs6000-builtin.def (RS6000_BUILTIN_BSWAP_HI): Delete.
15428 * config/rs6000/rs6000.c (rs6000_expand_builtin): Remove handling of
15429 above builtin.
15430 (rs6000_init_builtins): Likewise.
15431 * config/rs6000/rs6000.md (bswaphi2): Add TARGET_POWERPC predicate.
15432
15433 2012-04-11 Tristan Gingold <gingold@adacore.com>
15434
15435 * doc/extend.texi (Type Attributes): Move paragraph.
15436
15437 2012-04-11 Manuel López-Ibáñez <manu@gcc.gnu.org>
15438
15439 PR 24985
15440 * diagnostic.h (show_caret): Declare.
15441 (caret_max_width): Declare.
15442 (diagnostic_show_locus): Declare.
15443 * diagnostic.c (diagnostic_initialize): Initialize to false.
15444 (diagnostic_show_locus): New.
15445 (diagnostic_report_diagnostic): Call it.
15446 (getenv_columns): New.
15447 (adjust_line): New.
15448 (diagnostic_set_caret_max_width): New.
15449 * input.c (read_line): New.
15450 (location_get_source_line): New.
15451 * input.h (location_get_source_line): Declare.
15452 * toplev.c (general_init): Initialize show_caret from options.
15453 * dwarf2out.c (gen_producer_string): Handle fdiagnostics-show-caret.
15454 * opts.c (common_handle_option): Likewise.
15455 * pretty-print.h (pp_get_prefix): New.
15456 (pp_base_get_prefix): New.
15457 * common.opt (fdiagnostics-show-caret): New option.
15458 * doc/invoke.texi (fdiagnostics-show-caret): Document it.
15459
15460 2012-04-11 Richard Guenther <rguenther@suse.de>
15461
15462 PR rtl-optimization/52881
15463 * ifcvt.c (find_if_case_2): Avoid speculating loop latches.
15464
15465 2012-04-11 Richard Guenther <rguenther@suse.de>
15466
15467 PR tree-optimization/52912
15468 * tree-ssa-threadupdate.c (thread_block): Tell the cfg
15469 manipulation code we are threading through a loop header
15470 to an exit destination.
15471
15472 2012-04-10 Manuel López-Ibáñez <manu@gcc.gnu.org>
15473
15474 * tree.h (warn_if_unused_value): Move declaration from here.
15475 * stmt.c (warn_if_unused_value): Move definition from here.
15476
15477 2012-04-10 Michael Matz <matz@suse.de>
15478
15479 * tree-vectorizer.h (_loop_vec_info.strided_stores): Rename to
15480 grouped_stores.
15481 (LOOP_VINFO_STRIDED_STORES): Rename to LOOP_VINFO_GROUPED_STORES.
15482 (struce _bb_vec_info.strided_stores): Rename to grouped_stores.
15483 (BB_VINFO_STRIDED_STORES): Rename to BB_VINFO_GROUPED_STORES.
15484 (STMT_VINFO_STRIDED_ACCESS): Rename to STMT_VINFO_GROUPED_ACCESS.
15485 (vect_strided_store_supported): Rename to vect_grouped_store_supported.
15486 (vect_strided_load_supported): Rename to vect_grouped_load_supported.
15487 (vect_transform_strided_load): Rename to vect_transform_grouped_load.
15488 (vect_record_strided_load_vectors): Rename to
15489 vect_record_grouped_load_vectors.
15490 * tree-vect-data-refs.c (vect_update_misalignment_for_peel):
15491 Rename use of above macros.
15492 (vect_verify_datarefs_alignment): Ditto.
15493 (vector_alignment_reachable_p): Ditto.
15494 (vect_peeling_hash_get_lowest_cost): Ditto.
15495 (vect_enhance_data_refs_alignment): Ditto.
15496 (vect_analyze_group_access): Ditto and rename stride to groupsize.
15497 (vect_analyze_data_ref_access): Rename "strided" to "grouped".
15498 (vect_strided_store_supported): Rename to vect_grouped_store_supported.
15499 (vect_strided_load_supported): Rename to vect_grouped_load_supported.
15500 (vect_transform_strided_load): Rename to vect_transform_grouped_load.
15501 (vect_record_strided_load_vectors): Rename to
15502 vect_record_grouped_load_vectors.
15503 * tree-vect-loop.c (new_loop_vec_info): Rename use of above macros.
15504 (destroy_loop_vec_info): Ditto.
15505 (vect_transform_loop): Ditto and rename strided_store to grouped_store.
15506 * tree-vect-slp.c (vect_build_slp_tree): Rename use of above macros.
15507 (vect_analyze_slp): Ditto.
15508 (new_bb_vec_info): Ditto.
15509 (destroy_bb_vec_info): Ditto.
15510 (vect_schedule_slp_instance): Ditto and rename strided_store to
15511 grouped_store.
15512 * tree-vect-stmts.c (vect_cost_strided_group_size): Rename to
15513 vect_cost_group_size.
15514 (vect_model_store_cost): Rename use of above macros and call
15515 to vect_cost_strided_group_size.
15516 (vect_model_load_cost): Ditto.
15517 (vectorizable_store): Ditto, rename strided_store to grouped_store
15518 and calls to renamed tree-vectorizer.h functions.
15519 (vectorizable_load): Ditto.
15520 (vect_transform_stmt): Rename use of above macros and strided_store
15521 to grouped_store.
15522
15523 2012-04-10 Jan Hubicka <jh@suse.cz>
15524
15525 * cgraph.h: Remove misledaing comment on ipa-ref.h.
15526 (symtab_type): New enum.
15527 (symtab_node): New structure.
15528 (cgraph_node, varpool_node): Add symbol base type.
15529 (cgraph, varpool): New accestor functions.
15530 * cgraph.c (cgraph_create_node_1): Set symbol type.
15531 * varpool.c (varpool_node): Set symbol type.
15532
15533 2012-04-10 Ulrich Weigand <ulrich.weigand@linaro.org>
15534 Richard Sandiford <rdsandiford@googlemail.com>
15535
15536 * fwprop.c (propagate_rtx): Also set PR_CAN_APPEAR for subregs.
15537
15538 2012-04-10 Richard Guenther <rguenther@suse.de>
15539
15540 PR middle-end/52888
15541 * gimple-low.c (gimple_check_call_args): Properly account for
15542 compatible aggregate types.
15543
15544 2012-04-10 Richard Guenther <rguenther@suse.de>
15545
15546 * toplev.h (tree_rest_of_compilation): Remove.
15547 * tree-optimize.c (tree_rest_of_compilation): Likewise.
15548 * cgraph.h (tree_rest_of_compilation): Declare.
15549 * tree-optimize.c (tree_rest_of_compilation): Move ...
15550 * cgraphunit.c (tree_rest_of_compilation): ... here.
15551 * cgraph.c (cgraph_add_new_function): Adjust.
15552 * Makefile.in (tree-optimize.o): Adjust.
15553 (cgraphunit.o): Likewise.
15554
15555 2012-04-10 Ulrich Weigand <ulrich.weigand@linaro.org>
15556
15557 PR tree-optimization/52870
15558 * tree-vect-patterns.c (vect_recog_widen_mult_pattern): Verify that
15559 presumed pattern statement is within the same loop or basic block.
15560
15561 2012-04-10 Tristan Gingold <gingold@adacore.com>
15562
15563 * gengtype.c (main): Make uintptr_t a known type.
15564
15565 2012-04-10 Richard Guenther <rguenther@suse.de>
15566
15567 * tree-pass.h (tree_lowering_passes): Remove.
15568 * tree-optimize.c (tree_lowering_passes): Remove.
15569 * cgraph.c (cgraph_add_new_function): Inline relevant parts
15570 of tree_lowering_passes, avoid redundant call of early local passes.
15571 * cgraphunit.c (cgraph_lower_function): Fold into ...
15572 (cgraph_analyze_function): ... its single caller. Inline
15573 relevant parts of tree_lowering_passes.
15574
15575 2012-04-09 H.J. Lu <hongjiu.lu@intel.com>
15576
15577 PR other/52777
15578 * config/pa/pa.opt: Remove SIO and GNU_LD.
15579
15580 2012-04-09 Jan Hubicka <jh@suse.cz>
15581
15582 PR lto/52722
15583 PR lto/51765
15584 PR lto/52634
15585 * lto-cgraph.c (compute_ltrans_boundary): When alias is in the
15586 boundary, add its target too.
15587 * lto.c (add_references_to_partition): Add also aliased nodes.
15588 (add_cgraph_node_to_partition,
15589 add_varpool_node_to_partition): Work on nodes, not functions/variables;
15590 when adding alias, add also the aliased object.
15591
15592 2012-04-09 Uros Bizjak <ubizjak@gmail.com>
15593
15594 PR target/52883
15595 * config/i386/predicates.md (x86_64_zext_general_operand): Prevent
15596 VOIDmode immediate operands.
15597 * config/i386/constraints.md (Wz): New constraint.
15598 * config/i386/i386.md (*zero_extendsidi2_rex64): Use Wz instead of Z.
15599
15600 2012-04-09 Eric Botcazou <ebotcazou@adacore.com>
15601
15602 PR target/52717
15603 * config/sparc/sparc.c (sparc_file_end): Set TREE_PUBLIC explicitly on
15604 the DECL generated for the special GOT helper.
15605
15606 2012-04-09 Oleg Endo <olegendo@gcc.gnu.org>
15607
15608 * config/sh/constraints.md: Update list of constraints in
15609 comment block.
15610 (Sr0): Remove unused memory constraint.
15611
15612 2012-04-08 Manuel López-Ibáñez <manu@gcc.gnu.org>
15613
15614 * tree-pretty-print.h: Update comment.
15615
15616 2012-04-08 Oleg Endo <olegendo@gcc.gnu.org>
15617
15618 * config/sh/sh.md: Use braced string notation where applicable.
15619 (*prefetch_i4, prefetch_m2a): Merge into ...
15620 (*prefetch): ... this new insn.
15621
15622 2012-04-07 Oleg Endo <olegendo@gcc.gnu.org>
15623
15624 * config/sh/sh.h (high_life_started): Remove
15625 * config/sh/predicates.md (general_movdst_operand): Use
15626 'reload_in_progress' instead of 'high_life_started'.
15627 * config/sh/sh.md (divsi_inv_call, *divsi_inv_call_combine,
15628 divsi_inv_fp): Likewise.
15629
15630 2012-04-07 Oleg Endo <olegendo@gcc.gnu.org>
15631
15632 * config/sh/sh-protos.h (prepare_move_operands): Return void
15633 instead of int.
15634 * config/sh/sh.c (prepare_move_operands): Likewise.
15635 * config/sh/sh.md: Remove return value checks of prepare_move_operands.
15636
15637 2012-04-07 Oleg Endo <olegendo@gcc.gnu.org>
15638
15639 * config/sh/sh-protos.h (fp_int_operand, symbol_ref_operand,
15640 general_movsrc_operand, general_movdst_operand, arith_reg_operand,
15641 fp_arith_reg_operand, arith_operand, arith_reg_or_0_operand,
15642 logical_operand, fpscr_operand, fpul_operand, expand_fp_branch,
15643 commutative_float_operator, noncommutative_float_operator,
15644 sh_handle_pragma): Remove.
15645
15646 2012-04-06 Sandra Loosemore <sandra@codesourcery.com>
15647
15648 * doc/invoke.texi: Clean up Texinfo markup throughout the file.
15649 Use @option markup on command-line options. Use @samp markup on
15650 literal keywords to options. Use @code markup on code fragments.
15651 Use other markup in preference to quotation marks in the text.
15652 Add markup to some passages without any.
15653
15654 2012-04-06 Mike Stump <mikestump@comcast.net>
15655
15656 * gimple-fold.c (gimple_fold_stmt_to_constant_1): Avoid warning.
15657
15658 2012-04-06 Oleg Endo <olegendo@gcc.gnu.org>
15659
15660 * config/sh/sh.c (hi_const): Remove.
15661 (find_barrier, sh_reorg): Use satisfies_constraint_I16 instead
15662 of hi_const.
15663
15664 2012-04-06 Oleg Endo <olegendo@gcc.gnu.org>
15665
15666 * config/sh/sh-protos.h (sh_expand_t_scc): Change return type from int
15667 to bool.
15668 * config/sh/sh.c (sh_expand_t_scc): Likewise.
15669 * config/sh/sh.md (cstoresi4, cstoredi4): Remove GET_CODE checks before
15670 calling sh_expand_t_scc.
15671
15672 2012-04-06 Oleg Endo <olegendo@gcc.gnu.org>
15673
15674 * config/sh/sh-protos.h (fp_zero_operand, fp_one_operand,
15675 nonpic_symbol_mentioned_p, expand_block_move, expand_ashiftrt,
15676 sh_dynamicalize_shift_p, gen_shl_and, gen_shl_sext, system_reg_operand,
15677 reg_unused_after, sh_can_redirect_branch, sh_need_epilogue, fldi_ok,
15678 sh_hard_regno_rename_ok, sh_cfun_interrupt_handler_p,
15679 sh_cfun_resbank_handler_p, sh_attr_renesas_p, sh_cfun_attr_renesas_p,
15680 check_use_sfunc_addr, sh_contains_memref_p, sh_loads_bankedreg_p,
15681 sh2a_is_function_vector_call): Use bool as return type.
15682 (sh_pass_in_reg_p): Remove.
15683 * config/sh/sh.c (broken_move, mova_p, noncall_uses_reg, high_pressure,
15684 flow_dependent_p, sh2a_function_vector_p, expand_block_move,
15685 expand_ashiftrt, sh_dynamicalize_shift_p, gen_shl_and, gen_shl_sext,
15686 sh_need_epilogue, sh2a_is_function_vector_call, sh_attr_renesas_p,
15687 sh_cfun_attr_renesas_p, sh_cfun_interrupt_handler_p,
15688 sh_cfun_resbank_handler_p, system_reg_operand, fp_zero_operand,
15689 fp_one_operand, fldi_ok, reg_unused_after, sh_can_redirect_branch,
15690 sh_hard_regno_rename_ok, check_use_sfunc_addr, sh_contains_memref_p,
15691 sh_loads_bankedreg_p): Use bool as return type.
15692 (nonpic_symbol_mentioned_p): Use bool as return type. Remove
15693 'register' modifier.
15694
15695 2012-04-06 Matt Turner <mattst88@gmail.com>
15696
15697 * doc/install.texi: Correct typo "-mno-lsc" -> "-mno-llsc".
15698
15699 2012-04-06 Eric Botcazou <ebotcazou@adacore.com>
15700
15701 * config/ia64/ia64.c (ia64_load_pair_ok): Return 0 if the second member
15702 of the destination isn't also a FP_REGS register.
15703
15704 2012-04-05 Teresa Johnson <tejohnson@google.com>
15705 H.J. Lu <hongjiu.lu@intel.com>
15706
15707 * config/i386/i386.h (ix86_tune_indices): Add X86_TUNE_LCP_STALL.
15708 * config/i386/i386.md (move immediate to memory peephole2):
15709 Add cases for HImode move when LCP stall avoidance is needed.
15710 * config/i386/i386.c (initial_ix86_tune_features): Initialize
15711 X86_TUNE_LCP_STALL entry.
15712
15713 2012-04-05 Uros Bizjak <ubizjak@gmail.com>
15714
15715 PR target/52882
15716 * config/i386/i386.c (ix86_decompose_address): Allow VOIDmode
15717 CONST_INT operands, zero-extended with AND.
15718
15719 2012-04-05 Oleg Endo <olegendo@gcc.gnu.org>
15720
15721 PR target/50751
15722 * config/sh/sh.c (sh_find_mov_disp_adjust): Take machine_mode as the
15723 first argument instead of mode size. Move displacement calculations
15724 to ...
15725 (mov_insn_size, max_mov_insn_displacement, mov_insn_alignment_mask):
15726 ... these new functions.
15727 (disp_adjust): Remove max_mov_disp field.
15728 (sh_legitimate_index_p): Use max_mov_insn_displacement and
15729 mov_insn_alignment_mask.
15730 (sh_address_cost): Use max_mov_insn_displacement.
15731
15732 2012-04-05 Andrew Stubbs <ams@codesourcery.com>
15733
15734 * config/arm/arm.md (arch): Add neon_onlya8 and neon_nota8.
15735 (arch_enabled): Handle new arch types.
15736 (one_cmpldi2): Add NEON support.
15737
15738 2012-04-05 Richard Guenther <rguenther@suse.de>
15739
15740 * gimple.c (walk_gimple_op): Compute val_only for the LHS
15741 of an assigment in the canonical way, avoiding is_gimple_mem_rhs.
15742 (is_gimple_mem_rhs, is_gimple_reg_rhs, is_gimple_stmt): Move ...
15743 * gimplify.c (is_gimple_mem_rhs, is_gimple_reg_rhs, is_gimple_stmt):
15744 ... here and make static.
15745 * gimple.h (is_gimple_mem_rhs, is_gimple_reg_rhs, is_gimple_stmt):
15746 Remove.
15747
15748 2012-04-05 Richard Guenther <rguenther@suse.de>
15749
15750 * tree-ssa-dse.c (dse_optimize_stmt): Remember the stmt
15751 basic-block before removing it.
15752
15753 2012-04-05 Richard Guenther <rguenther@suse.de>
15754
15755 * tree-ssanames.c (release_dead_ssa_names): Compact the SSA
15756 version namespace as we release the freelist.
15757
15758 2012-04-05 Richard Guenther <rguenther@suse.de>
15759
15760 * tree-nrv.c (tree_nrv): Release VDEFs.
15761 * tree-sra.c (sra_modify_constructor_assign): Likewise.
15762 (sra_modify_assign): Likewise.
15763 * tree-vect-stmts.c (vect_remove_stores): Likewise.
15764 * tree-vect-loop.c (vect_transform_loop): Likewise.
15765 * tree-ssa-dom.c (optimize_stmt): Likewise.
15766 * tree-vect-slp.c (vect_schedule_slp): Likewise.
15767 * tree-ssa-math-opts.c (execute_cse_sincos): Likewise.
15768
15769 2012-04-05 Richard Guenther <rguenther@suse.de>
15770
15771 * gimple-iterator.c (gsi_remove): Return whether EH edges need to be
15772 cleanup.
15773 * gimple.h (gsi_remove): Adjust.
15774 * tree-ssa-operands.c (unlink_stmt_vdef): Optimize.
15775 * tree-ssa-dom.c (optimize_stmt): Use gsi_remove result.
15776 * tree-ssa-dse.c (dse_optimize_stmt): Likewise.
15777 * tree-ssa-forwprop.c (remove_prop_source_from_use): Likewise.
15778 * tree-ssa-math-opts.c (execute_optimize_widening_mul): Likewise.
15779 * tree-ssa-pre.c (eliminate): Likewise.
15780
15781 2012-04-04 Mike Stump <mikestump@comcast.net>
15782
15783 * doc/rtl.texi (const_double): Document as sign-extending.
15784 * expmed.c (expand_mult): Ensure we don't use shift incorrectly.
15785 * emit-rtl.c (immed_double_int_const): Refine to state the
15786 value is signed.
15787 * simplify-rtx.c (mode_signbit_p): Add a fixme for wider than
15788 CONST_DOUBLE integers.
15789 (simplify_const_unary_operation, UNSIGNED_FLOAT): Ensure no
15790 negative values are converted. Fix conversions bigger than
15791 HOST_BITS_PER_WIDE_INT.
15792 (simplify_binary_operation_1): Ensure we don't use shift incorrectly.
15793 (simplify_immed_subreg): Sign-extend CONST_DOUBLEs.
15794 * explow.c (plus_constant_mode): Add.
15795 (plus_constant): Implement with plus_constant_mode.
15796 * rtl.h (plus_constant_mode): Add.
15797
15798 2012-04-04 Richard Guenther <rguenther@suse.de>
15799
15800 PR tree-optimization/52808
15801 * tracer.c (tail_duplicate): Do not tail-duplicate loop header blocks.
15802 * Makefile.in (tracer.o): Depend on $(CFGLOOP_H).
15803
15804 2012-04-04 Tristan Gingold <gingold@adacore.com>
15805
15806 * expr.c (expand_expr_real_2): Handle larger sizetype in
15807 POINTER_PLUS_EXPR.
15808
15809 2012-04-03 Kaz Kojima <kkojima@gcc.gnu.org>
15810
15811 * config/sh/t-sh (MULTILIB_MATCHES): Match m2a-single-only
15812 to m2a-single instead of m2e.
15813
15814 2012-04-03 Eric Botcazou <ebotcazou@adacore.com>
15815
15816 * expr.c (get_bit_range): Add OFFSET parameter and adjust BITPOS.
15817 Change type of BITOFFSET to signed. Make sure the lower bound of
15818 the computed range is non-negative by adjusting OFFSET and BITPOS.
15819 (expand_assignment): Adjust call to get_bit_range.
15820
15821 2012-04-03 Sandeep Kumar Singh <Sandeep.Singh2@kpitcummins.com>
15822
15823 * h8300/h8300.c (h8300_current_function_monitor_function_p):
15824 New function. Added to check monitor functions.
15825 (h8300_option_override): Modified to generate error/warning
15826 messages for invalid combinations of different command line
15827 options.
15828 * h8300/h8300.md: Generate 'rte' for monitor functions. Do not
15829 save EXR on stack for monitor function in case of H8S target
15830 when "-mno-exr" is passed.
15831 * h8300/h8300-protos.h (h8300_current_function_monitor_function_p):
15832 Add prototype.
15833 * doc/invoke.texi: Document H8S options.
15834
15835 2012-04-03 Tristan Gingold <gingold@adacore.com>
15836
15837 * configure.ac: Use GCC_AC_FUNC_MMAP_BLACKLIST instead
15838 of gcc_AC_FUNC_MMAP_BLACKLIST.
15839 * acinclude.m4 (gcc_AC_FUNC_MMAP_BLACKLIST): Remove.
15840 * Makefile.in (aclocal_deps): Add mmap.m4.
15841 * configure: Regenerate.
15842 * aclocal.m4: Regenerate.
15843
15844 2012-04-03 Richard Guenther <rguenther@suse.de>
15845
15846 PR tree-optimization/52808
15847 * tracer.c (tail_duplicate): Return whether we have duplicated
15848 any block.
15849 (tracer): If we have duplicated any block, cleanup the CFG.
15850 * cfghooks.c (duplicate_block): If we duplicated a loop
15851 header but not its loop, destroy the loop because it now has
15852 multiple entries.
15853 * tree-ssa-threadupdate.c (thread_through_loop_header): Tell
15854 the cfg manipulation routines we are not creating a multiple
15855 entry loop.
15856
15857 2012-04-03 Tristan Gingold <gingold@adacore.com>
15858
15859 * config/vms/vms-c.c (vms_pragma_nomember_alignment): Handle
15860 'byte' alignment.
15861 (vms_c_common_override_options): Allow parameterless variadic
15862 functions.
15863
15864 2012-04-03 Jakub Jelinek <jakub@redhat.com>
15865
15866 PR tree-optimization/52835
15867 * tree-data-ref.c (build_rdg): Return NULL if
15868 compute_data_dependences_for_loop failed.
15869
15870 2012-04-03 Eric Botcazou <ebotcazou@adacore.com>
15871
15872 * varasm.c (initializer_constant_valid_for_bitfield_p): Return true
15873 for REAL_CST as well.
15874 (output_constructor): Use RECORD_OR_UNION_TYPE_P predicate.
15875 In the bitfield case, if the value is a REAL_CST, convert it first to
15876 an INTEGER_CST.
15877
15878 2012-04-02 H.J. Lu <hongjiu.lu@intel.com>
15879
15880 * config.gcc: Use i386/biarchx32.h instead of i386/biarch64.h
15881 for --with-abi={x32|mx32} or --with-multilib-list=mx32.
15882 (supported_defaults): Add abi for i[34567]86-*-* and x86_64-*-*.
15883
15884 * config/i386/biarchx32.h: New.
15885
15886 2012-04-02 Anatoly Sokolov <aesok@post.ru>
15887
15888 * config/arm/arm.h (PREFERRED_RELOAD_CLASS): Remove.
15889 * config/arm/arm.c (TARGET_PREFERRED_RELOAD_CLASS): Define.
15890 (arm_preferred_reload_class): New function.
15891
15892 2012-04-02 Richard Guenther <rguenther@suse.de>
15893
15894 PR tree-optimization/52756
15895 * tree-ssa-threadupdate.c (def_split_header_continue_p): New function.
15896 (thread_through_loop_header): After threading through the loop latch
15897 remove the split part from the loop and clear further threading
15898 opportunities that would create a multiple entry loop.
15899
15900 2012-04-02 Richard Guenther <rguenther@suse.de>
15901
15902 PR rtl-optimization/52800
15903 * cprop.c (execute_rtl_cprop): Call cleanup_cfg with
15904 CLEANUP_CFG_CHANGED.
15905
15906 2012-04-02 Richard Guenther <rguenther@suse.de>
15907
15908 PR middle-end/52803
15909 * loop-init.c (gate_handle_loop2): Destroy loops here if
15910 we don't enter RTL loop optimizers.
15911
15912 2012-04-02 Uros Bizjak <ubizjak@gmail.com>
15913
15914 Partially revert:
15915 2012-03-29 Richard Guenther <rguenther@suse.de>
15916
15917 * rtl.h (extended_count): Remove.
15918 * combine.c (extended_count): Remove.
15919
15920 2012-04-02 Dodji Seketeli <dodji@redhat.com>
15921
15922 PR c++/40942
15923 * pt.c (more_specialized_fn): Don't apply decay conversion to
15924 types of function parameters.
15925
15926 2012-04-02 Tristan Gingold <gingold@adacore.com>
15927
15928 * ggc-page.c (PAGE_L1_SIZE, PAGE_L2_SIZE, LOOKUP_L1, LOOKUP_L2)
15929 (ggc_allocated_p, lookup_page_table_entry, set_page_table_entry)
15930 (alloc_page, init_ggc, clear_marks, struct ggc_pch_data)
15931 (ggc_pch_this_base): Use uintptr_t instead of size_t.
15932
15933 2012-03-31 H.J. Lu <hongjiu.lu@intel.com>
15934
15935 PR bootstrap/52784
15936 * config/i386/i386.c (ix86_option_override_internal): Don't
15937 check TARGET_64BIT if TARGET_64BIT_DEFAULT is false.
15938
15939 2012-03-31 Eric Botcazou <ebotcazou@adacore.com>
15940
15941 * tree-cfg.c (call_can_make_abnormal_goto): New predicate.
15942 (stmt_can_make_abnormal_goto): Use it.
15943 (is_ctrl_altering_stmt): Likewise.
15944
15945 2012-03-30 Naveen H.S <naveen.S@kpitcummins.com>
15946 Kaz Kojima <kkojima@gcc.gnu.org>
15947
15948 * config/sh/sh.c (push_regs): Skip banked registers when
15949 resbank attribute is specified.
15950 (sh_expand_epilogue): Likewise.
15951
15952 2012-03-30 Richard Henderson <rth@redhat.com>
15953
15954 PR debug/52727
15955 * combine-stack-adj.c (prev_active_insn_bb): New.
15956 (next_active_insn_bb): New.
15957 (force_move_args_size_note): New.
15958 (combine_stack_adjustments_for_block): Use it.
15959
15960 2012-03-30 Richard Henderson <rth@redhat.com>
15961
15962 * config/i386/i386.c (struct expand_vec_perm_d): Add one_operand_p.
15963 (ix86_expand_vector_init_duplicate): Initialize it.
15964 (expand_vec_perm_palignr): Likewise.
15965 (ix86_expand_vec_perm_const): Likewise.
15966 (ix86_vectorize_vec_perm_const_ok): Likewise.
15967 (expand_vec_perm_blend): Use it.
15968 (expand_vec_perm_vpermil): Likewise.
15969 (expand_vec_perm_pshufb): Likewise.
15970 (expand_vec_perm_1): Likewise.
15971 (expand_vec_perm_pshuflw_pshufhw): Likewise.
15972 (expand_vec_perm_interleave2): Likewise.
15973 (expand_vec_perm_vpermq_perm_1): Likewise.
15974 (expand_vec_perm_vperm2f128): Likewise.
15975 (expand_vec_perm_interleave3): Likewise.
15976 (expand_vec_perm_vperm2f128_vblend): Likewise.
15977 (expand_vec_perm_vpshufb2_vpermq): Likewise.
15978 (expand_vec_perm_vpshufb2_vpermq_even_odd): Likewise,.
15979 (expand_vec_perm_broadcast): Likewise.
15980 (expand_vec_perm_vpshufb4_vpermq2): Likewise.
15981
15982 2012-03-30 Richard Henderson <rth@redhat.com>
15983
15984 * dwarf2out.c (gen_variable_die): Initialize off.
15985
15986 2012-03-30 Tristan Gingold <gingold@adacore.com>
15987
15988 * config/vms/vms-f.c: New file.
15989 * config/vms/t-vms (vms-f.o): New rule.
15990 * config.gcc (*-*-*vms*): Define fortran_target_objs.
15991
15992 2012-03-30 Richard Guenther <rguenther@suse.de>
15993
15994 PR tree-optimization/52754
15995 * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Only
15996 propagate arbitrary addresses into really plain dereferences.
15997
15998 2012-03-30 Richard Guenther <rguenther@suse.de>
15999
16000 PR middle-end/52772
16001 * except.c (emit_to_new_bb_before): Move loop updating ...
16002 (dw2_build_landing_pads): ... here. Use a proper block for
16003 querying the loop father.
16004
16005 2012-03-30 Tristan Gingold <gingold@adacore.com>
16006
16007 * config/ia64/ia64.c (ia64_section_type_flags): Remove
16008 common_object attribute handling.
16009 (SECTION_VMS_OVERLAY): Remove
16010 (ia64_vms_common_object_attribute): Replace abort with an assert.
16011 Do not set DECL_SECTION_NAME.
16012 (ia64_vms_output_aligned_decl_common): Handle common_object
16013 attribute.
16014 (ia64_vms_elf_asm_named_section): Remove.
16015 * config/ia64/vms.h (TARGET_ASM_NAMED_SECTION): Remove.
16016
16017 2012-03-30 Richard Guenther <rguenther@suse.de>
16018
16019 PR middle-end/52786
16020 * double-int.c (rshift_double): Remove not needed cast.
16021
16022 2012-03-30 Richard Guenther <rguenther@suse.de>
16023
16024 * tree-affine.h (print_aff): Remove.
16025 * tree-affine.c (print_aff): Make static.
16026 * tree-data-ref.h (access_matrix_get_index_for_parameter): Remove.
16027 (get_references_in_stmt): Likewise.
16028 (print_direction_vector): Likewise.
16029 (print_dir_vectors): Likewise.
16030 (print_dist_vectors): Likewise.
16031 (dump_subscript): Likewise.
16032 (dump_ddrs): Likewise.
16033 (dump_dist_dir_vectors): Likewise.
16034 (dump_data_references): Likewise.
16035 (dump_data_dependence_relation): Likewise.
16036 (dump_data_dependence_direction): Likewise.
16037 (dump_rdg_vertex): Likewise.
16038 (dump_rdg_component): Likewise.
16039 (debug_ddrs): Declare.
16040 (struct data_ref_loc_d): Move ...
16041 * tree-data-ref.c (struct data_ref_loc_d): ... here.
16042 (get_references_in_stmt): Make static.
16043 (dump_data_references): Likewise.
16044 (dump_subscript): Likewise.
16045 (print_direction_vector): Likewise.
16046 (print_dir_vectors): Likewise.
16047 (print_dist_vectors): Likewise.
16048 (dump_data_dependence_relation): Likewise.
16049 (dump_dist_dir_vectors): Likewise.
16050 (dump_ddrs): Likewise.
16051 (dump_rdg_vertex): Likewise.
16052 (dump_rdg_component): Likewise.
16053 (debug_ddrs): New function.
16054 (access_matrix_get_index_for_parameter): Remove.
16055
16056 2012-03-30 Tristan Gingold <gingold@adacore.com>
16057
16058 * config/vms/vms.c (VMS_CRTL_FLOAT32): Rename.
16059 (VMS_CRTL_FLOAT64, VMS_CRTL_FLOAT64_VAXD): New.
16060 (VMS_CRTL_FLOAT128, VMS_CRTL_DPML, VMS_CRTL_NODMPL)
16061 (VMS_CRTL_32ONLY, VMS_CRTL_G_MASK, VMS_CRTL_G_NONE)
16062 (VMS_CRTL_GA, VMS_CRTL_GL, VMS_CRTL_FLOATV2): New.
16063 (vms_patch_builtins): Handle new flags
16064 * config/vms/vms-crtlmap.map: Completed using nm on
16065 c and math system libraries.
16066 * config/vms/make-crtlmap.awk: Handle any number of flags.
16067
16068 2012-03-30 Martin Jambor <mjambor@suse.cz>
16069
16070 * tree-ssa-ccp.c (insert_clobbers_for_var): Do not assert that there
16071 is a builtin_stack_save in a dominating BB.
16072
16073 2012-03-29 Uros Bizjak <ubizjak@gmail.com>
16074
16075 * config/i386/sse.md (avx_h<plusminus_insn>v4df3): Fix results
16076 crossing 128bit lane boundary.
16077
16078 2012-03-29 Vladimir Makarov <vmakarov@redhat.com>
16079
16080 * ira-color.c (setup_left_conflict_sizes_p): Process all
16081 conflicting objects.
16082
16083 2012-03-29 Jakub Jelinek <jakub@redhat.com>
16084
16085 PR tree-optimization/52760
16086 * tree-vect-slp.c (vect_get_constant_vectors): Convert constant_p
16087 shift count for {L,R}{SHIFT,ROTATE}_EXPR to TREE_TYPE (vector_type).
16088
16089 2012-03-29 Richard Guenther <rguenther@suse.de>
16090
16091 * cgraph.h (cgraph_materialize_all_clones): Remove.
16092 (reset_inline_failed): Likewise.
16093 * cgraphunit.c (cgraph_materialize_all_clones): Make static.
16094 * cgraphbuild.c (reset_inline_failed): Remove.
16095 * rtl.h (cse_main): Remove.
16096 (extended_count): Likewise.
16097 * cse.c (dump_class): Mark as DEBUG_FUNCTION.
16098 (cse_main): Make static.
16099 * combine.c (extended_count): Remove.
16100 (dump_combine_stats): Mark as DEBUG_FUNCTION.
16101 * basic-block.h (reorder_basic_blocks): Remove.
16102 * bb-reorder.c (reorder_basic_blocks): Make static.
16103 * Makefile.in (dse.o): Remove dse.h dependency.
16104 * dse.h: Remove.
16105 * dse.c (gate_dse): Remove.
16106 (clear_alias_mode_eq): Likewise.
16107 (clear_alias_mode_hash): Likewise.
16108 (dse_record_singleton_alias_set): Likewise.
16109 (dse_invalidate_singleton_alias_set): Likewise.
16110
16111 2012-03-29 H.J. Lu <hongjiu.lu@intel.com>
16112
16113 * config/linux-android.h (ANDROID_STARTFILE_SPEC): Use
16114 crtbegin_so%O%s for -shared.
16115 (ANDROID_ENDFILE_SPEC): Use crtend_so%O%s for -shared.
16116
16117 2012-03-29 Richard Guenther <rguenther@suse.de>
16118
16119 * tree-flow.h (struct pre_expr_d): Remove forward declaration.
16120 (add_to_value): Remove.
16121 (print_value_expressions): Likewise.
16122 * tree-ssa-pre.c (add_to_value): Make static.
16123 (print_value_expressions): Likewise.
16124 * gimple.h (gimple_adjust_this_by_delta): Remove.
16125 * gimple-fold.c (gimple_adjust_this_by_delta): Likewise.
16126
16127 2012-03-29 Richard Guenther <rguenther@suse.de>
16128
16129 PR middle-end/50708
16130 * double-int.h (rshift_double): Remove.
16131 * double-int.c (lshift_double): Use absu_hwi to make count positive.
16132 (rshift_double): Make static, take unsigned count argument,
16133 remove handling of negative count argument.
16134 (double_int_rshift): Dispatch to lshift_double.
16135
16136 2012-03-28 H.J. Lu <hongjiu.lu@intel.com>
16137
16138 * config/i386/biarch64.h (TARGET_64BIT_DEFAULT): Add
16139 OPTION_MASK_ABI_64.
16140
16141 * config/i386/gnu-user64.h (SPEC_64): Support TARGET_BI_ARCH == 2.
16142 (SPEC_X32): Likewise.
16143 (MULTILIB_DEFAULTS): Likewise.
16144
16145 * config/i386/i386.c (isa_opts): Remove -m64.
16146 (ix86_target_string): Properly handle -m32/-m64/-mx32.
16147 (ix86_option_override_internal): Properly
16148 set OPTION_MASK_ISA_64BIT and OPTION_MASK_ISA_X32 as well as
16149 handle -m32, -m64 and -mx32.
16150
16151 * config/i386/i386.h (TARGET_X32): Replace OPTION_ISA_X32
16152 with OPTION_ABI_X32. Moved after TARGET_LP64.
16153 (TARGET_LP64): Changed to OPTION_ABI_64.
16154
16155 * config/i386/i386.opt (m64): Replace ISA_64BIT with ABI_64.
16156 (mx32): Replace ISA_X32 with ABI_X32.
16157
16158 2012-03-28 Eric Botcazou <ebotcazou@adacore.com>
16159
16160 * tree.c (tree_size) <VECTOR_CST>: New case.
16161
16162 2012-03-28 Uros Bizjak <ubizjak@gmail.com>
16163
16164 * config/i386/i386.c (ix86_modes_tieable_p): Handle 32bit AVX modes.
16165 (ix86_expand_vector_move_misalign): Remove un-needed gen_lowpart calls.
16166
16167 2012-03-28 Jakub Jelinek <jakub@redhat.com>
16168
16169 PR middle-end/52691
16170 * tree-ssa-ccp.c (optimize_stdarg_builtin): Optimize
16171 __builtin_va_start to __builtin_next_arg if the latter is
16172 builtin_decl_explicit_p rather than when it is not.
16173
16174 PR middle-end/52750
16175 * tree-vect-generic.c (vector_element): Perform multiplication
16176 for pos in bitsizetype type instead of idx type.
16177
16178 2012-03-28 Richard Guenther <rguenther@suse.de>
16179
16180 * loop-init.c (loop_optimizer_init): If loops are preserved
16181 perform incremental initialization of required loop features.
16182 (loop_optimizer_finalize): If loops are to be preserved only
16183 clean up optional loop features.
16184 (rtl_loop_done): Forcefully free loops here.
16185 * cgraph.c (cgraph_release_function_body): Forcefully free loops.
16186 * cfgexpand.c (expand_gimple_cond): Properly add new basic-blocks
16187 to existing loops.
16188 (construct_init_block): Likewise.
16189 (construct_exit_block): Likewise.
16190 (gimple_expand_cfg): Clear LOOP_CLOSED_SSA loop state. Cleanup
16191 the CFG after expanding.
16192 * cfgloop.c (verify_loop_structure): Calculate or verify dominators.
16193 If we needed to calculate them, free them afterwards.
16194 * tree-pass.h (PROP_loops): New define.
16195 * tree-ssa-loop.c (pass_tree_loop_init): Provide PROP_loops.
16196 * basic-block.h (CLEANUP_CFG_CHANGED): New.
16197 * cfgcleanup.c (merge_blocks_move): Protect loop latches.
16198 (cleanup_cfg): If we did something and have loops around, fix them up.
16199 * cse.c (rest_of_handle_cse_after_global_opts): Call cleanup_cfg
16200 with CLEANUP_CFG_CHANGED.
16201 * cfghooks.c (merge_blocks): If we merge a loop header into
16202 its predecessor, update the loop structure.
16203 (duplicate_block): If we copy a loop latch, adjust loop state
16204 to note we may have multiple latches.
16205 (delete_basic_block): Mark loops for fixup if we remove a loop.
16206 * cfganal.c (forwarder_block_p): Protect loop latches, headers
16207 and preheaders.
16208 * cfgrtl.c (rtl_can_merge_blocks): Protect loop latches.
16209 (cfg_layout_can_merge_blocks_p): Likewise.
16210 * cprop.c (bypass_block): If we create a loop with multiple
16211 entries, mark it for removal.
16212 * except.c (emit_to_new_bb_before): Add the new basic-block
16213 to existing loops.
16214 * tree-eh.c (lower_resx): Likewise.
16215 * omp-low.c (finalize_task_copyfn): Do not copy PROP_loops.
16216 (expand_omp_taskreg): Likewise.
16217 * tree-inline.c (initialize_cfun): Likewise.
16218 * tree-mudflap.c (add_bb_to_loop): Prototype.
16219 (mf_build_check_statement_for): Properly add new basic-blocks
16220 to existing loops.
16221 * tree-ssa-threadupdate.c (thread_block): Mark loops for fixup
16222 if we remove a loop.
16223 (thread_through_loop_header): Likewise.
16224 * trans-mem.c (tm_log_emit_save_or_restores): Properly add
16225 new basic-blocks to existing loops.
16226 (expand_transaction): Likewise.
16227 * Makefile.in (except.o): Add $(CFGLOOP_H).
16228 (expr.o): Likewise.
16229 (cgraph.o): Likewise.
16230 (cprop.o): Likewise.
16231 (cfgexpand.o): Likewise.
16232 (cfganal.o): Likewise.
16233 (trans-mem.o): Likewise.
16234 (tree-eh.o): Likewise.
16235
16236 2012-03-28 Georg-Johann Lay <avr@gjlay.de>
16237
16238 PR target/52692
16239 * config/avr/avr.c (TARGET_BUILTIN_DECL): New define.
16240 (avr_builtin_decl): New static function.
16241 (struct avr_builtin_description, avr_bdesc): Move up.
16242 Add GTY marker. Add field fndecl. Remove redundant field id.
16243 (avr_init_builtins): Initialize avr_bdesc[ID].fndecl.
16244 (avr_expand_builtin): Code cleanup because .id is removed.
16245
16246 2012-03-28 Georg-Johann Lay <avr@gjlay.de>
16247
16248 PR target/52737
16249 * config.gcc (tm_file): Remove avr/multilib.h.
16250
16251 * doc/invoke.texi (AVR Options): Adjust documentation of -mtiny-stack.
16252
16253 * config/avr/genmultilib.awk: Remove code to generate multilib.h.
16254 (BEGIN): Use -msp8 as multilib option instead of -mtiny-stack.
16255 * config/avr/t-avr: Remove generation of multilib.h.
16256 * config/avr/t-multilib: Regenerate.
16257 * config/avr/multilib.h: Remove.
16258 * config/avr/avr.opt (-msp8): New option.
16259 (avr_sp8): New variable.
16260 * config/avr/driver-avr.c (avr_device_to_sp8): New function.
16261 * config/avr/avr.h (AVR_HAVE_SPH): New define.
16262 (AVR_HAVE_8BIT_SP): Also set by avr_sp8 i.e. -msp8.
16263 (avr_device_to_sp8): New prototype.
16264 (EXTRA_SPEC_FUNCTIONS): Add { "device_to_sp8", avr_device_to_sp8 }
16265 (DRIVER_SELF_SPECS): New define.
16266 * config/avr/avr-c.c (avr_cpu_cpp_builtins): New built-in defines:
16267 __AVR_SP8__, __AVR_HAVE_SPH__.
16268 * config/avr/avr.c (output_movhi): Use AVR_HAVE_SPH instead of
16269 AVR_HAVE_8BIT_SP to decide if SP_H is present.
16270 (avr_file_start): Ditto.
16271
16272 2012-03-28 Jakub Jelinek <jakub@redhat.com>
16273
16274 PR target/52736
16275 * config/i386/sse.md (sse2_loadlpd splitter): Use offset 0
16276 instead of 8 in adjust_address.
16277
16278 2012-03-27 Aurelien Buhrig <aurelien.buhrig.gcc@gmail.com>
16279
16280 PR middle-end/51893
16281 * expmed.c (store_bit_field_1): Fix wordnum value for big-endian
16282 targets.
16283
16284 2012-03-27 Oleg Endo <olegendo@gcc.gnu.org>
16285
16286 PR target/50751
16287 * config/sh/sh.c (sh_legitimize_address, sh_legitimize_reload_address):
16288 Rearrange conditional logic. Move displacement address calculations
16289 to ...
16290 (sh_find_mov_disp_adjust): ... this new function.
16291
16292 2012-03-27 H.J. Lu <hongjiu.lu@intel.com>
16293
16294 * config/arm/arm.opt (mapcs): Remove MaskExists.
16295 * config/cris/linux.opt (mno-gotplt): Likewise.
16296 * config/i386/i386.opt (mhard-float): Likewise.
16297 (msse4): Likewise.
16298 (mno-sse4): Likewise.
16299 * config/m68k/m68k.opt (mhard-float): Likewise.
16300 * config/mep/mep.op (mcop32): Likewise.
16301 * config/pa/pa-hpux.opt (msio): Likewise.
16302 * config/pa/pa64-hpux.opt (mgnu-ld): Likewise.
16303 * config/picochip/picochip.opt (mlittle): Likewise.
16304 * config/sh/sh.opt (mrenesas): Likewise.
16305 * config/sparc/long-double-switch.opt (mlong-double-128): Likewise.
16306 * config/sparc/sparc.opt (mhard-float): Likewise.
16307 * config/v850/v850.opt (mv850es): Likewise.
16308 * config/vax/vax.opt (mg-float): Likewise.
16309
16310 2012-03-27 Martin Jambor <mjambor@suse.cz>
16311
16312 PR middle-end/52693
16313 * tree-sra.c (sra_modify_assign): Do not call
16314 load_assign_lhs_subreplacements when working with an unscalarizable
16315 region.
16316
16317 2012-03-27 Uros Bizjak <ubizjak@gmail.com>
16318
16319 PR target/52698
16320 * config/i386/i386-protos.h (ix86_legitimize_reload_address):
16321 New prototype.
16322 * config/i386/i386.h (LEGITIMIZE_RELOAD_ADDRESS): New define.
16323 * config/i386/i386.c: Include reload.h.
16324 (ix86_legitimize_reload_address): New function.
16325
16326 2012-03-27 H.J. Lu <hongjiu.lu@intel.com>
16327
16328 * opth-gen.awk: Allocated a bit for Mask and InverseMask if it
16329 hasn't been allocated. Define a target macro for Mask and
16330 InverseMask if it hasn't been defined. Remove MaskExists handling.
16331
16332 * doc/options.texi: Remove MaskExists.
16333
16334 2012-03-27 Chung-Lin Tang <cltang@codesourcery.com>
16335
16336 PR target/52667
16337 * config/sh/sh.c (find_barrier): Add equality check of last_got
16338 to avoid going above orig insn. Update comments.
16339
16340 2012-03-27 Richard Guenther <rguenther@suse.de>
16341
16342 PR middle-end/52720
16343 * fold-const.c (try_move_mult_to_index): Handle &x.array more
16344 explicitely.
16345
16346 2012-03-27 Eric Botcazou <ebotcazou@adacore.com>
16347
16348 * expmed.c (store_bit_field): Assert that BITREGION_START is a multiple
16349 of a unit before computing the offset in units.
16350 * expr.c (get_bit_range): Return the null range if the enclosing record
16351 is part of a larger bit field.
16352
16353 2012-03-27 Tristan Gingold <gingold@adacore.com>
16354
16355 * config/ia64/vms.h (CASE_VECTOR_MODE): Define.
16356 * config/ia64/ia64.md: Remove mode in template.
16357 Sign extend operand in expand_simple_binop.
16358 * config/ia64/ia64.h (ASM_OUTPUT_ADDR_DIFF_ELT): Use
16359 CASE_VECTOR_MODE instead of TARGET_ILP32.
16360 (ADDR_VEC_ALIGN): Make it depends on CASE_VECTOR_MODE.
16361
16362 2012-03-26 Steven Bosscher <steven@gcc.gnu.org>
16363
16364 * varasm.c (assemble_external): #if 0 out the new assert from the
16365 previous commit, it breaks the Java and Go front ends.
16366
16367 2012-03-26 Steven Bosscher <steven@gcc.gnu.org>
16368
16369 * toplev.c (check_global_declaration_1): Do not call assemble_external.
16370 * expr.c (emit_block_move_libcall_fn): Likewise.
16371 (clear_storage_libcall_fn): Likewise.
16372 (expand_expr_addr_expr_1): Likewise.
16373 (expand_expr_real_1): Likewise.
16374 * calls.c (rtx_for_function_call): Likewise.
16375
16376 * varasm.c (assemble_external): Assert this function is only called
16377 during or after expanding to RTL.
16378
16379 2012-03-26 Martin Jambor <mjambor@suse.cz>
16380
16381 PR tree-optimization/50052
16382 * tree-sra.c (tree_non_aligned_mem_p): Removed.
16383 (tree_non_aligned_mem_for_access_p): Likewise.
16384 (build_accesses_from_assign): Removed strict alignment requirements
16385 checks.
16386 (access_precludes_ipa_sra_p): Likewise.
16387
16388 2012-03-26 Richard Guenther <rguenther@suse.de>
16389
16390 PR tree-optimization/52701
16391 * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Always
16392 compute and set the evolution part of PHI nodes.
16393
16394 2012-03-26 Richard Guenther <rguenther@suse.de>
16395
16396 PR tree-optimization/52721
16397 * tree-vect-stmts.c (vect_init_vector): Handle scalars.
16398
16399 2012-03-26 Ulrich Weigand <ulrich.weigand@linaro.org>
16400
16401 PR tree-optimization/52686
16402 * tree-vect-data-refs.c (vect_get_smallest_scalar_type): Handle
16403 WIDEN_LSHIFT_EXPR.
16404
16405 2012-03-26 Tristan Gingold <gingold@adacore.com>
16406
16407 * config/alpha/vms.h (LINK_SPEC): Simplify.
16408 (STARTFILE_SPEC): Remove -mvms-return-codes handling.
16409 (NAME__MAIN, SYMBOL__MAIN): Remove.
16410 (VMS_DEBUG_MAIN_POINTER): Remove.
16411 * config/ia64/vms.h: Likewise.
16412 * config/alpha/alpha.c (alpha_start_function): Move vms_debug_main
16413 code to vms.c. Call vms_start_function.
16414 * config/ia64/ia64.c (ia64_start_function): Likewise.
16415 * config/vms/vms-protos.h (vms_start_function): Declare.
16416 * config/vms/vms.c (vms_start_function): New function.
16417 * config/vms/vms.h (MATH_LIBRARY): Define.
16418 (VMS_DEBUG_MAIN_POINTER): Define.
16419
16420 2012-03-26 Eric Botcazou <ebotcazou@adacore.com>
16421
16422 PR rtl-optimization/52629
16423 * reload1.c (count_pseudo): Short-circuit common case.
16424 (count_spilled_pseudo): Return early for pseudos without hard regs.
16425 Assert that the pseudo has got a hard reg before manipulating it.
16426
16427 2012-03-24 Jan Hubicka <jh@suse.cz>
16428
16429 PR lto/51663
16430 * varpool.c (varpool_finalize_decl): Handle toplevel_reorder here.
16431 (decide_is_variable_needed): Do not handle toplevel reorder here.
16432 * cgraph.h (varpool_can_remove_if_no_refs): Likewise.
16433 * ipa.c (cgraph_remove_unreachable_nodes): Remove unreachable vars
16434 even at -O0.
16435
16436 2012-03-24 Eric Botcazou <ebotcazou@adacore.com>
16437
16438 * expr.c (optimize_bitfield_assignment_op) <BIT_IOR_EXPR>: Use str_mode
16439 and str_bitsize instead of more convoluted expressions.
16440
16441 2012-03-24 Eric Botcazou <ebotcazou@adacore.com>
16442
16443 PR target/52610
16444 * config/sparc/sparc.h (ASM_CPU_SPEC): Pass -Av8 if -mcpu=leon.
16445
16446 2012-03-24 Eric Botcazou <ebotcazou@adacore.com>
16447
16448 PR target/52656
16449 * config/sparc/sparc.c (sparc_handle_vis_mul8x16): Fix pasto.
16450
16451 2012-03-23 Martin Jambor <mjambor@suse.cz>
16452
16453 * tree-sra.c (build_accesses_from_assign): Remove FIXME comment.
16454
16455 2012-03-23 Richard Guenther <rguenther@suse.de>
16456
16457 PR tree-optimization/52678
16458 * tree-vectorizer.h (struct _stmt_vec_info): Add
16459 loop_phi_evolution_part member.
16460 (STMT_VINFO_LOOP_PHI_EVOLUTION_PART): New define.
16461 * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Initialize
16462 STMT_VINFO_LOOP_PHI_EVOLUTION_PART.
16463 * tree-vect-loop-manip.c (vect_update_ivs_after_vectorizer):
16464 Use the cached evolution part and the PHI nodes value from
16465 the loop preheader edge instead of re-analyzing the evolution.
16466
16467 2012-03-22 Maxim Kuvyrkov <maxim@codesourcery.com>
16468
16469 * config/mips/mips-tables.opt: Update.
16470 * config/mips/mips.md (processor): Add xlp.
16471 * config/mips/mips-cpus.def: Add xlp.
16472 * config/mips/mips.c (mips_rtx_cost_data): Add costs for XLP, copy from
16473 5KF for now.
16474 * config/mips/mips.h (MIPS_ISA_LEVEL_SPEC): Handle xlp.
16475 * doc/invoke.texi: Mention XLP.
16476
16477 2012-03-22 Jakub Jelinek <jakub@redhat.com>
16478
16479 PR middle-end/52547
16480 * tree-nested.c (convert_tramp_reference_stmt): Call declare_vars
16481 on any new_local_var_chain vars declared during recursing on
16482 GIMPLE_OMP_PARALLEL or GIMPLE_OMP_TASK body.
16483
16484 2012-03-22 Uros Bizjak <ubizjak@gmail.com>
16485
16486 * config/alpha/alpha.h (ASM_OUTPUT_ALIGN): Move to config/alpha/elf.h
16487 (ASM_OUTPUT_SKIP): Move to config/alpha/vms.h
16488 (ASM_OUTPUT_LOCAL): Ditto.
16489 (ASM_OUTPUT_COMMON): Remove.
16490 * config/alpha/elf.h (ASM_OUTPUT_DEF_FROM_DECLS): Use ASM_OUTPUT_DEF.
16491 * config/alpha/vms.h (ASM_OUTPUT_ALIGN): Do not undefine before define.
16492
16493 2012-03-22 Jan Hubicka <jh@suse.cz>
16494
16495 PR middle-end/51737
16496 * cgraph.c (cgraph_remove_node_and_inline_clones): Add FORBIDDEN_NODE
16497 parameter.
16498 * cgraph.h (cgraph_remove_node_and_inline_clones): Update prototype.
16499 * ipa-inline-transform.c (save_inline_function_body): Remove
16500 copied clone if needed.
16501 * tree-inline.c (delete_unreachable_blocks_update_callgraph): Update.
16502
16503 2012-03-22 Richard Guenther <rguenther@suse.de>
16504
16505 PR middle-end/52666
16506 * fold-const.c (fold_ternary_loc): Fix typo.
16507
16508 2012-03-22 Georg-Johann Lay <avr@gjlay.de>
16509
16510 PR target/52496
16511 * config/avr/avr.md (unspec): Remove UNSPEC_MEMORY_BARRIER.
16512 (unspecv): Add UNSPECV_MEMORY_BARRIER.
16513 (cli_sei): Use unspec_volatile instead of unspec for memory barrier.
16514 (delay_cycles_1, delay_cycles_2): Ditto.
16515 (delay_cycles_3, delay_cycles_4): Ditto.
16516 (nopv, *nopv): Ditto.
16517 (sleep, *sleep): Ditto.
16518 (wdr, *wdr): Ditto.
16519
16520 2012-03-22 Richard Guenther <rguenther@suse.de>
16521
16522 PR tree-optimization/52548
16523 * tree-ssa-pre.c (valid_in_sets): Remove handling of invalidation
16524 because of clobbers.
16525 (prune_clobbered_mems): New function.
16526 (compute_antic_aux): Use it to prune ANTIC_OUT.
16527 (compute_partial_antic_aux): Use it to prune PA_IN.
16528 (compute_avail): Only insert expressions into EXP_GEN that are not
16529 invalidated when translated up to the beginning of the block.
16530
16531 2012-03-22 Richard Guenther <rguenther@suse.de>
16532
16533 PR tree-optimization/52638
16534 * tree-vect-stmts.c (vect_init_vector_1): New function, split
16535 out from ...
16536 (vect_init_vector): ... here. Handle scalar vector inits.
16537 (vect_get_vec_def_for_operand): Adjust.
16538 (vectorizable_load): Likewise.
16539
16540 2012-03-22 Uros Bizjak <ubizjak@gmail.com>
16541
16542 * config.gcc (alpha*-*-linux*): Add elfos.h to tm_file.
16543 (alpha*-*-freebsd*): Ditto.
16544 (alpha*-*-netbsd*): Ditto.
16545 (alpha*-*-openbsd*): Ditto.
16546 * config/alpha/elf.h (OBJECT_FORMAT_ELF): Remove.
16547 (DWARF2_DEBUGGING_INFO): Remove.
16548 (PREFERRED_DEBUGGING_TYPE): Remove.
16549 (ASM_FINAL_SPEC): Remove.
16550 (IDENT_ASM_OP): Remove.
16551 (ASM_OUTPUT_IDENT): Remove.
16552 (SKIP_ASM_OP): Remove.
16553 (ASM_OUTPUT_SKIP): Remove.
16554 (ALIGN_ASM_OP): Remove.
16555 (ASM_OUTPUT_BEFORE_CASE_LABEL): Remove.
16556 (ASM_OUTPUT_CASE_LABEL): Remove.
16557 (ASM_OUTPUT_EXTERNAL_LIBCALL): Remove.
16558 (COMMON_ASM_OP): Remove.
16559 (ASM_OUTPUT_ALIGNED_COMMON): Remove.
16560 (ASCII_DATA_ASM_OP): Remove.
16561 (READONLY_DATA_SECTION_ASM_OP): Remove.
16562 (INIT_SECTION_ASM_OP): Remove.
16563 (FINI_SECTION_ASM_OP): Remove.
16564 (ASM_SECTION_START_OP): Remove.
16565 (ASM_OUTPUT_SECTION_START_FILE): Remove.
16566 (TARGET_ASM_NAMED_SECTION): Remove.
16567 (TARGET_ASM_SELECT_SECTION): Remove.
16568 (MAKE_DECL_ONE_ONLY): Remove.
16569 (TYPE_ASM_OP): Remove.
16570 (SIZE_ASM_OP): Remove.
16571 (ASM_WEAKEN_LABEL): Remove.
16572 (TYPE_OPERAND_FMT): Remove.
16573 (ASM_DECLARE_RESULT): Remove.
16574 (ASM_DECLARE_OBJECT_NAME): Remove.
16575 (ASM_FINISH_DECLARE_OBJECT): Remove.
16576 (ELF_ASCII_ESCAPES): Remove.
16577 (ELF_STRING_LIMIT): Remove.
16578 (STRING_ASM_OP): Remove.
16579 (ASM_OUTPUT_EXTERNAL): Remove.
16580 (TARGET_ASM_FILE_START_FILE_DIRECTIVE): Redefine to false.
16581 * config/alpha/alpha.h (PCC_BITFIELD_TYPE_MATTERS): Undefine
16582 before define.
16583 (ASM_DECLARE_FUNCTION_NAME): Ditto.
16584 (ASM_DECLARE_FUNCTION_SIZE): Ditto.
16585 (ASM_GENERATE_INTERNAL_LABEL): Ditto.
16586 (ASM_OUTPUT_SKIP): Ditto.
16587 (READONLY_DATA_SECTION_ASM_OP): Remove.
16588 (USER_LABEL_PREFIX): Remove.
16589 (ASM_OUTPUT_ASCII): Remove.
16590 (ASM_OUTPUT_CASE_LABEL): Remove.
16591 (NO_DOLLAR_IN_LABEL): Undefine.
16592
16593 2012-03-22 Richard Guenther <rguenther@suse.de>
16594
16595 PR tree-optimization/52459
16596 * tree-ssa-pre.c (inhibit_phi_insertion): Do not inhibit
16597 PHI insertion for calls.
16598
16599 2012-03-21 Steven Bosscher <steven@gcc.gnu.org>
16600
16601 * cse.c (invalidate_from_sets_and_clobbers, try_back_substitute_reg,
16602 find_sets_in_insn, canonicalize_insn): Split out from ...
16603 (cse_insn): ... here.
16604 (invalidate_from_clobbers): Take an insn instead of the pattern.
16605
16606 2012-03-21 Oleg Endo <olegendo@gcc.gnu.org>
16607
16608 PR target/52479
16609 * config/sh/sh-protos.h (sh_fsca_df2int): Remove.
16610 * config/sh/sh.c (sh_fsca_df2int_rtx, sh_fsca_df2int): Remove.
16611 * config/sh/sh.md (sindf2, cosdf2): Remove.
16612
16613 2012-03-21 Kaz Kojima <kkojima@gcc.gnu.org>
16614
16615 PR target/52642
16616 * config/sh/sh.c (sh_expand_prologue): Emit blockage at the end of
16617 prologue for unwinder and profiler.
16618
16619 2012-03-21 Andreas Tobler <andreast@fgznet.ch>
16620
16621 * configure.ac (HAVE_LD_NO_DOT_SYMBOLS): Add powerpc64-*-freebsd*.
16622 Introduce emul_name to select the right linker emulation for
16623 powerpc64-*-freebsd*.
16624 * configure: Regenerate.
16625 * config.gcc: Add bits to support powerpc64-*-freebsd*.
16626 * config/rs6000/freebsd.h (POWERPC_FREEBSD): Define.
16627 * config/rs6000/freebsd64.h: New file.
16628 * config/rs6000/rs6000.c (rs6000_option_override_internal): Use
16629 POWERPC_FREEBSD.
16630 (rs6000_savres_strategy): Likewise.
16631 (rs6000_savres_routine_name): Likewise.
16632 (rs6000_elf_file_end): Likewise.
16633 * config/rs6000/t-freebsd64: New file.
16634 * config/rs6000/sysv4.h (SUBTARGET_OVERRIDE_OPTIONS): Set the
16635 rs6000_current_abi for 64-bit FreeBSD to ABI_AIX.
16636
16637 * config/rs6000/freebsd64.h: Remove duplicated entries from last
16638 commit.
16639 * config/rs6000/t-freebsd64: Likewise.
16640
16641 2012-03-21 Georg-Johann Lay <avr@gjlay.de>
16642
16643 PR rtl-optimization/52543
16644 PR target/52461
16645 * config/avr/avr-protos.h (avr_load_lpm): New prototype.
16646 * config/avr/avr.c (avr_mode_dependent_address_p): New function.
16647 (TARGET_MODE_DEPENDENT_ADDRESS_P): New define.
16648 (avr_load_libgcc_p): Restrict to __flash loads.
16649 (avr_out_lpm): Only handle 1-byte loads from __flash.
16650 (avr_load_lpm): New function.
16651 (avr_find_unused_d_reg): Remove.
16652 (avr_out_lpm_no_lpmx): Remove.
16653 (adjust_insn_length): Handle ADJUST_LEN_LOAD_LPM.
16654 * config/avr/avr.md (unspec): Add UNSPEC_LPM.
16655 (load_<mode>_libgcc): Use UNSPEC_LPM instead of MEM.
16656 (load_<mode>, load_<mode>_clobber): New insns.
16657 (mov<mode>): For multi-byte move from non-generic
16658 16-bit address spaces: Expand to load_<mode> resp.
16659 load_<mode>_clobber.
16660 (load<mode>_libgcc): Remove expander.
16661 (split-lpmx): Remove split.
16662
16663 2012-03-21 Richard Earnshaw <rearnsha@arm.com>
16664
16665 * neon.md (neon_vget_lanev2di): Use gen_lowpart and gen_highpart.
16666 * config/arm/neon.ml (Fixed_return_reg): Renamed to fixed_vector_reg.
16667 All callers changed.
16668 (Fixed_core_reg): New feature.
16669 (Vget_lane [sizes S64 and U64]): Add Fixed_core_reg. Allow fmrrd in
16670 disassembly.
16671 * neon-testgen.ml: Handle Fixed_core_reg.
16672
16673 2012-03-21 Andrew Stubbs <ams@codesourcery.com>
16674
16675 * config/arm/arm.c (thumb2_reorg): Add complete support
16676 for 16-bit instructions.
16677 * config/arm/thumb2.md: Delete obsolete flag-clobbering peepholes.
16678
16679 2012-03-21 Richard Guenther <rguenther@suse.de>
16680
16681 PR tree-optimizer/52636
16682 * tree-vect-slp.c (vect_get_constant_vectors): Convert constants
16683 to the appropriate type.
16684
16685 2012-03-21 Richard Guenther <rguenther@suse.de>
16686
16687 * Makefile.in (cfgexpand.o): Add $(REGS_H) and $(INTEGRATE_H)
16688 dependencies.
16689 * cfgexpand.c (gimple_expand_cfg): Fold in pass_init_function,
16690 pass_jump, pass_initial_value_sets and pass_unshare_all_rtl.
16691 * passes.c (init_optimization_passes): Remove pass_init_function,
16692 pass_jump, pass_initial_value_sets and pass_unshare_all_rtl.
16693 * tree-pass.h (pass_init_function): Remove.
16694 (pass_jump): Remove.
16695 (pass_initial_value_sets): Remove.
16696 (pass_unshare_all_rtl): Remove.
16697 * integrate.c (pass_initial_value_sets): Remove.
16698 * emit-rtl.c (pass_unshare_all_rtl): Remove.
16699 * tree.h (init_function_for_compilation): Remove.
16700 * function.c (init_function_for_compilation): Remove.
16701 (pass_init_function): Remove.
16702 * cfgcleanup.c (rest_of_handle_jump): Remove.
16703 (pass_jump): Remove.
16704
16705 2012-03-20 Jason Merrill <jason@redhat.com>
16706
16707 * tree-streamer-in.c (streamer_alloc_tree): Call
16708 ggc_alloc_zone_cleared_tree_node instead of
16709 ggc_alloc_zone_cleared_tree_node_stat.
16710
16711 2012-03-20 Jonathan Wakely <jwakely.gcc@gmail.com>
16712
16713 * doc/extend.texi (Template Instantiation): Remove anachronisms.
16714
16715 2012-03-20 Jakub Jelinek <jakub@redhat.com>
16716
16717 PR target/52607
16718 * config/i386/i386.c (expand_vec_perm_vperm2f128): New function.
16719 (ix86_expand_vec_perm_const_1): Call it.
16720
16721 * config/i386/i386.c (vselect_insn): New variable.
16722 (init_vselect_insn): New function.
16723 (expand_vselect, expand_vselect_insn): Add testing_p argument.
16724 Call init_vselect_insn if vselect_insn is NULL. Adjust
16725 PATTERN (vselect_insn), instead of creating a new insn each time,
16726 only emit a copy of it if not testing and recog has been successful.
16727 (expand_vec_perm_pshufb, expand_vec_perm_1,
16728 expand_vec_perm_pshuflw_pshufhw, expand_vec_perm_broadcast_1): Adjust
16729 callers.
16730
16731 PR target/52607
16732 * config/i386/i386.md ("isa" attribute): Add avx2 and noavx2.
16733 ("enabled" attribute): Handle avx2 and noavx2 isas.
16734 * config/i386/sse.md (avx2_vec_dupv8sf_1, avx2_pbroadcast<mode>_1):
16735 New insns.
16736 (vec_dup<mode>): Add avx2 =x,x alternative.
16737 (vec_dup<mode> splitter): Don't split if TARGET_AVX2.
16738 (*avx_vperm_broadcast_<mode>): Don't split V4DFmode if TARGET_AVX2.
16739 For TARGET_AVX2, V8SFmode and elt == 0 split into vbroadcastss.
16740 * config/i386/i386.c (expand_vec_perm_pshufb): Emit also vpermps
16741 for V8SFmode.
16742 (expand_vec_perm_1): For broadcasts, use avx2_pbroadcast<mode>_1
16743 if possible, handle also V8SFmode.
16744
16745 2012-03-20 Richard Earnshaw <rearnsha@arm.com>
16746
16747 * arm/predicates.md (zero_operand, reg_or_zero_operand): New predicates.
16748 * arm/neon.md (neon_vceq<mode>, neon_vcge<mode>): Use
16749 reg_or_zero_operand predicate.
16750 (neon_vcle<mode>, neon_vclt<mode>): Use zero_operand predicate.
16751
16752 2012-03-20 Jakub Jelinek <jakub@redhat.com>
16753
16754 * config/i386/i386.c (ix86_decompose_address) <case ZERO_EXTEND>:
16755 If operand isn't UNSPEC, return 0.
16756
16757 2012-03-20 Richard Guenther <rguenther@suse.de>
16758
16759 * tree-pass.h (pass_rtl_eh): Remove.
16760 * except.c (gate_handle_eh): Likewise.
16761 (rest_of_handle_eh): Likewise.
16762 (pass_rtl_eh): Likewise.
16763 (finish_eh_generation): Export.
16764 * except.h (finish_eh_generation): Declare.
16765 * passes.c (init_optimization_passes): Remove pass_rtl_eh.
16766 * cfgexpand.c (gimple_expand_cfg): Call finish_eh_generation
16767 after expanding stack alignment. Instead of compacting blocks
16768 call cleanup_cfg.
16769
16770 2012-03-20 Richard Guenther <rguenther@suse.de>
16771
16772 * stor-layout.c (finish_bitfield_representative): Fallback
16773 to conservative maximum size if the padding up to the next
16774 field cannot be computed as a constant.
16775 (finish_bitfield_layout): If we cannot compute the distance
16776 between the start of the bitfield representative and the
16777 bitfield member start a new representative.
16778 * expr.c (get_bit_range): The distance between the start of
16779 the bitfield representative and the bitfield member is zero
16780 if the field offsets are not constants.
16781
16782 2012-03-20 Tristan Gingold <gingold@adacore.com>
16783
16784 * tree.h (enum size_type_kind): Add stk_ prefix to constants,
16785 convert in lowercase.
16786 (sizetype_tab, sizetype, bitsizetype, ssizetype, sbitsizetype)
16787 (size_int, ssize_int, bitsize_int, sbitsize_int): Adjust.
16788 * stor-layout.c (sizetype_tab): Adjust.
16789 (initialize_sizetypes): Use SIZETYPE instead of SIZE_TYPE.
16790 * tree-streamer.c (preload_common_nodes): Use stk_type_kind_last
16791 instead of type_kind_last.
16792 * tree-scalar-evolution.c (interpret_rhs_expr): Use size_int
16793 instead of size_int_kind.
16794 * doc/tm.texi.in (Type Layout): Document SIZETYPE.
16795 * doc/tm.texi: Regenerate.
16796 * defaults.h (SIZETYPE): Provide a default value.
16797 * config/vms/vms.h (SIZE_TYPE): Define as "unsigned int".
16798 (SIZETYPE): Define.
16799
16800 2012-03-20 Oleg Endo <olegendo@gcc.gnu.org>
16801
16802 * config/sh/sh.md: Use braced string notation where applicable.
16803
16804 2012-03-19 Uros Bizjak <ubizjak@gmail.com>
16805
16806 * config/i386/i386.md (allocate_stack): Simplify.
16807
16808 2012-03-19 Uros Bizjak <ubizjak@gmail.com>
16809
16810 * builtins.c (expand_builtin_cexpi): Use copy_addr_to_reg instead of
16811 copy_to_mode_reg (Pmode, ...).
16812 (expand_builtin_frame_address): Ditto.
16813 * expr.c (emit_block_move_via_libcall): Ditto.
16814 (set_storage_via_libcall): Ditto.
16815
16816 * config/i386/i386.c (ix86_expand_movmem): Ditto.
16817 (ix86_expand_setmem): Ditto.
16818 (ix86_trampoline_init): DItto.
16819 * config/i386/i386.md (cmpstrnsi): Ditto.
16820
16821 2012-03-19 Sandra Loosemore <sandra@codesourcery.com>
16822
16823 * config/sh/sh.opt (madjust-unroll): Mark as ignored/obsolete.
16824 * config/sh/sh.h (TARGET_OPT_DEFAULT): Don't use MASK_ADJUST_UNROLL.
16825 * doc/invoke.texi (Option Summary): Remove -madjust-unroll.
16826 (SH Options): Likewise.
16827
16828 2012-03-19 Uros Bizjak <ubizjak@gmail.com>
16829
16830 * config/i386/i386.c (get_thread_pointer): Add tp_mode argument.
16831 Generate ZERO_EXTEND in place if GET_MODE (tp) != tp_mode.
16832 (legitimize_tls_address) <TLS_MODEL_INITIAL_EXEC>: Always generate
16833 DImode UNSPEC_GOTNTPOFF references on TARGET_64BIT.
16834 (ix86_decompose_address): Allow zero extended UNSPEC_TP references.
16835
16836 Revert:
16837 2012-03-13 Uros Bizjak <ubizjak@gmail.com>
16838
16839 * config/i386/i386.h (TARGET_TLS_INDIRECT_SEG_REFS): New.
16840 * config/i386/i386.c (ix86_decompose_address): Use
16841 TARGET_TLS_INDIRECT_SEG_REFS to prevent %fs:(%reg) addresses.
16842 (legitimize_tls_address): Use TARGET_TLS_INDIRECT_SEG_REFS to load
16843 thread pointer to a register.
16844
16845 Revert:
16846 2012-03-10 H.J. Lu <hongjiu.lu@intel.com>
16847
16848 * config/i386/i386.c (ix86_decompose_address): Disallow fs:(reg)
16849 if Pmode != word_mode.
16850 (legitimize_tls_address): Call gen_tls_initial_exec_x32 if
16851 Pmode == SImode for TARGET_X32.
16852
16853 * config/i386/i386.md (UNSPEC_TLS_IE_X32): New.
16854 (tls_initial_exec_x32): Likewise.
16855
16856 2012-03-19 Oleg Endo <olegendo@gcc.gnu.org>
16857
16858 PR target/50751
16859 * config/sh/sh.h (CONST_OK_FOR_K04, CONST_OK_FOR_K12, DISP_ADDR_P,
16860 DISP_ADDR_OFFSET): New macros.
16861 * config/sh/sh.c (sh_address_cost): Add SH2A special case.
16862 (sh_legitimate_index_p): Allow QImode displacements for non-SH2A.
16863 (sh_legitimize_address): Add QImode displacement handling.
16864 (sh_cannot_change_mode_class): Disallow GENERAL_REGS for SFmode
16865 vector subregs.
16866 (sh_secondary_reload): Add QImode displacement handling.
16867 * config/sh/predicates.md (movsrc_no_disp_mem_operand): New predicate.
16868 * config/sh/constraints.md (K04, Snd, Sdd): New constraints.
16869 * config/sh/sh.md (extendqisi2): Remove constraints from expander.
16870 (*extendqisi2_compact): Rename to *extendqisi2_compact_reg, restrict
16871 to register operands only.
16872 (*extendqisi2_compact_mem_disp, *extendqisi2_compact_snd): New insns.
16873 (extendqihi2): Change insn to expander.
16874 (*extendqihi2_compact_reg): New insn.
16875 (movqi_i, movqi): Replace with ...
16876 (movqi, *movqi_reg_reg, *movqi_store_mem_disp12,
16877 *movqi_load_mem_disp, *movqi_load_mem_disp): ... these.
16878 Add new peepholes for QImode displacement addressing.
16879
16880 2012-03-19 Paolo Carlini <paolo.carlini@oracle.com>
16881
16882 PR c++/14710
16883 * doc/invoke.texi: Document -Wuseless-cast.
16884
16885 2012-03-19 Eric Botcazou <ebotcazou@adacore.com>
16886
16887 * tree.def (REALPART_EXPR, IMAGPART_EXPR, VIEW_CONVERT_EXPR): Move.
16888 * tree.h (handled_component_p): Reorder cases.
16889 * dwarf2out.c (loc_list_for_address_of_addr_expr_of_indirect_ref): Do
16890 not initialize unsignedp.
16891 (loc_list_from_tree): Likewise.
16892 (fortran_common): Likewise.
16893 * simplify-rtx.c (delegitimize_mem_from_attrs): Likewise.
16894
16895 2012-03-19 Uros Bizjak <ubizjak@gmail.com>
16896
16897 * config/i386/i386.c (ix86_expand_prologue) <CM_LARGE_PIC>: Use Pmode
16898 mode consistently. Use ix86_gen_add3. Assert that Pmode == DImode.
16899 (ix86_expand_split_stack_prologue): Use ix86_gen_add3.
16900 (ix86_split_long_move): Ditto.
16901 (legitimize_tls_address): Use ix86_gen_sub3.
16902 (construct_plt_address): Assert that Pmode == DImode.
16903
16904 2012-03-18 Uros Bizjak <ubizjak@gmail.com>
16905
16906 * config/i386/i386.md: Remove empty predicates and/or constraints.
16907 * config/i386/sync.md: Ditto.
16908 * config/i386/sse.md: Ditto.
16909 * config/i386/mmx.md: Ditto.
16910 * config/i386/pentium.md: Ditto.
16911 * config/i386/athlon.md: Ditto.
16912
16913 2012-03-16 Richard Guenther <rguenther@suse.de>
16914
16915 PR tree-optimization/52603
16916 * tree-vect-data-refs.c (vect_can_force_dr_alignment_p): Clarify
16917 comment.
16918
16919 Revert
16920 2012-03-14 Richard Guenther <rguenther@suse.de>
16921
16922 PR tree-optimization/52571
16923 * tree-vect-data-refs.c (vect_compute_data_ref_alignment): Move
16924 flag_section_anchors check ...
16925 (vect_can_force_dr_alignment_p): ... here.
16926
16927 2012-03-16 Martin Jambor <mjambor@suse.cz>
16928
16929 * expr.c (expand_expr_real_1): Handle misaligned scalar reads from
16930 memory through MEM_REFs by calling extract_bit_field.
16931
16932 2012-03-16 Richard Guenther <rguenther@suse.de>
16933
16934 * fold-const.c (native_interpret_expr): Also support POINTER_TYPE
16935 and REFERENCE_TYPE interpretations.
16936 (can_native_interpret_type_p): New function.
16937 (fold_ternary_loc): Use native encode/interpret to fold
16938 BIT_FIELD_REFs of constants.
16939
16940 2012-03-16 Richard Guenther <rguenther@suse.de>
16941
16942 PR middle-end/52584
16943 * fold-const.c (fold_ternary_loc): Fold vector typed BIT_FIELD_REFs
16944 of vector constants and constructors.
16945
16946 2012-03-16 Richard Guenther <rguenther@suse.de>
16947
16948 * tree-vect-stmts.c (vect_get_vec_def_for_operand): Use
16949 VIEW_CONVERT_EXPR to convert constants.
16950 (vect_is_simple_use): Treat all constants as vec_constant_def.
16951
16952 2012-03-16 Richard Guenther <rguenther@suse.de>
16953 Kai Tietz <ktietz@redhat.com>
16954
16955 PR middle-end/48814
16956 * gimplify.c (gimplify_self_mod_expr): Evaluate postfix
16957 side-effects completely in the pre-queue and use a temporary
16958 for the result.
16959
16960 2012-03-16 Richard Guenther <rguenther@suse.de>
16961
16962 * stor-layout.c (finish_bitfield_representative): Fall back
16963 to the conservative maximum size if we cannot compute the
16964 size of the tail padding.
16965
16966 2012-03-16 Tristan Gingold <gingold@adacore.com>
16967
16968 * config/vms/vms.h (TARGET_OS_CPP_BUILTINS): Define
16969 __CRTL_VER and __VMS_VER.
16970 * config/vms/vms-protos.h: Declare vms_c_get_crtl_ver
16971 and vms_c_get_vms_ver.
16972 * config/vms/vms-c.c (vms_c_get_crtl_ver, vms_c_get_vms_ver): New
16973 functions.
16974 * config/alpha/vms.h (VMS_DEFAULT_CRTL_VER)
16975 (VMS_DEFAULT_VMS_VER): Define.
16976 * config/ia64/vms.h (VMS_DEFAULT_CRTL_VER)
16977 (VMS_DEFAULT_VMS_VER): Define.
16978
16979 2012-03-16 Richard Guenther <rguenther@suse.de>
16980
16981 * tree-vect-loop.c (get_initial_def_for_induction): Use
16982 build_constructor directly.
16983 * tree-vect-stmts.c (vect_get_vec_def_for_operand): Use
16984 build_vector_from_val.
16985 * tree.c (build_vector_from_val): Avoid creating a constructor
16986 first when we want a constant vector.
16987
16988 2012-03-16 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
16989
16990 * doc/install.texi (Specific, *-*-solaris2*): Improve wording.
16991
16992 2012-03-16 Richard Guenther <rguenther@suse.de>
16993
16994 * tree.h (TREE_VECTOR_CST_ELTS): Remove.
16995 (VECTOR_CST_NELTS, VECTOR_CST_ELTS, VECTOR_CST_ELT): New defines.
16996 (struct tree_vector): Remove elements member, add variable size
16997 elts array member.
16998 (build_vector_stat): Declare.
16999 (build_vector): Define in terms of build_vector_stat.
17000 * tree.c (build_vector): Rename to ...
17001 (build_vector_stat): ... this. Take array of trees as parameter.
17002 (build_vector_from_ctor): Adjust.
17003 (integer_zerop, integer_onep, integer_all_onesp, iterative_hash_expr,
17004 initializer_zerop): Adjust.
17005 * cfgexpand.c (expand_debug_expr): Likewise.
17006 * expr.c (categorize_ctor_elements_1, expand_expr_real_1,
17007 const_vector_from_tree): Likewise.
17008 * fold-const.c (const_binop, operand_equal_p, native_encode_vector,
17009 native_interpret_vector, fold_unary_loc, vec_cst_ctor_to_array,
17010 fold_vec_perm, fold_binary_loc, fold_ternary_loc): Likewise.
17011 * tree-streamer-in.c (streamer_alloc_tree): Handle TS_VECTOR.
17012 (lto_input_ts_vector_tree_pointers): Adjust.
17013 * tree-streamer-out.c (streamer_write_tree_header): Handle TS_VECTOR.
17014 (write_ts_vector_tree_pointers): Adjust.
17015 * varasm.c (const_hash_1, compare_constant, copy_constant,
17016 output_constant): Adjust.
17017 * gimple-fold.c (gimple_fold_stmt_to_constant_1): Adjust.
17018 * print-tree.c (print_node): Adjust.
17019 * tree-pretty-print.c (dump_generic_node): Adjust.
17020 * tree-vect-generic.c (uniform_vector_p, vector_element,
17021 lower_vec_perm): Adjust.
17022 * tree-vect-loop.c (get_initial_def_for_reduction): Adjust.
17023 * tree-vect-slp.c (vect_get_constant_vectors,
17024 vect_transform_slp_perm_load): Adjust.
17025 * tree-vect-stmts.c (vect_gen_perm_mask): Adjust.
17026 * expmed.c (make_tree): Adjust.
17027 * config/i386/i386.c (ix86_expand_builtin): Adjust.
17028 * config/sparc/sparc.c (sparc_handle_vis_mul8x16): Adjust interface
17029 and implementation.
17030 (sparc_fold_builtin): Adjust.
17031
17032 2012-03-16 Tristan Gingold <gingold@adacore.com>
17033
17034 * config.gcc (*-*-*vms*): Define use_gcc_stdint and tm_file.
17035 * config/vms/vms-stdint.h: New file.
17036
17037 2012-03-16 Tristan Gingold <gingold@adacore.com>
17038
17039 * config.host (alpha64-dec-*vms*, alpha*-dec-*vms*)
17040 (ia64-hp-*vms*): Replaced by ...
17041 (*-*-*vms*): ... This new entry.
17042
17043 2012-03-15 Jakub Jelinek <jakub@redhat.com>
17044
17045 PR target/52568
17046 * config/i386/i386.c (expand_vec_perm_vperm2f128_vblend): New function.
17047 (ix86_expand_vec_perm_const_1): Use it.
17048
17049 PR target/52568
17050 * config/i386/sse.md (UNSPEC_VPERMDF): Remove.
17051 (avx2_permv4df): Remove.
17052 (avx2_permv4di): Macroize into...
17053 (avx2_perm<mode>): ... this using VI8F_256 iterator.
17054 (avx2_permv4di_1): Macroize into...
17055 (avx2_perm<mode>_1): ... this using VI8F_256 iterator.
17056
17057 2012-03-15 Ulrich Weigand <ulrich.weigand@linaro.org>
17058
17059 * combine.c (apply_distributive_law): Do not distribute SUBREG.
17060
17061 2012-03-15 Ira Rosen <irar@il.ibm.com>
17062 Ulrich Weigand <ulrich.weigand@linaro.org>
17063
17064 * tree-vect-patterns.c (widened_name_p): Rename to ...
17065 (type_conversion_p): ... this. Add new argument to determine
17066 if it's a promotion or demotion operation. Check for
17067 CONVERT_EXPR_CODE_P instead of NOP_EXPR.
17068 (vect_recog_dot_prod_pattern): Call type_conversion_p instead
17069 widened_name_p.
17070 (vect_recog_widen_mult_pattern, vect_recog_widen_sum_pattern,
17071 vect_operation_fits_smaller_type, vect_recog_widen_shift_pattern):
17072 Likewise.
17073 (vect_recog_mixed_size_cond_pattern): Likewise and allow
17074 non-constant then and else clauses.
17075
17076 2012-03-15 Ira Rosen <irar@il.ibm.com>
17077 Ulrich Weigand <ulrich.weigand@linaro.org>
17078
17079 * tree-vectorizer.h (vect_pattern_recog): Add new argument.
17080 * tree-vect-loop.c (vect_analyze_loop_2): Update call to
17081 vect_pattern_recog.
17082 * tree-vect-patterns.c (widened_name_p): Pass basic block
17083 info to vect_is_simple_use.
17084 (vect_recog_dot_prod_pattern): Fail for basic blocks.
17085 (vect_recog_widen_sum_pattern): Likewise.
17086 (vect_handle_widen_op_by_const): Support basic blocks.
17087 (vect_operation_fits_smaller_type,
17088 vect_recog_over_widening_pattern): Likewise.
17089 (vect_recog_vector_vector_shift_pattern): Support basic blocks.
17090 Update call to vect_is_simple_use.
17091 (vect_recog_mixed_size_cond_pattern): Support basic blocks.
17092 Add printing.
17093 (check_bool_pattern): Add an argument, update call to
17094 vect_is_simple_use and the recursive calls.
17095 (vect_recog_bool_pattern): Update relevant function calls.
17096 Add printing.
17097 (vect_mark_pattern_stmts): Update calls to new_stmt_vec_info.
17098 (vect_pattern_recog_1): Check for reduction only in loops.
17099 (vect_pattern_recog): Add new argument. Support basic blocks.
17100 * tree-vect-stmts.c (vectorizable_conversion): Pass basic block
17101 info to vect_is_simple_use_1.
17102 * tree-vect-slp.c (vect_get_and_check_slp_defs): Support basic blocks.
17103 (vect_slp_analyze_bb_1): Call vect_pattern_recog.
17104
17105 2012-03-15 Jakub Jelinek <jakub@redhat.com>
17106 Andrew Pinski <apinski@cavium.com>
17107
17108 PR middle-end/52592
17109 * builtins.c (expand_builtin_int_roundingfn_2): If expanding
17110 BUILT_IN_IR{INT,OUND}* using optab fails, emit lr{int,ound}*
17111 calls instead of __builtin_ir{int,ound}*.
17112
17113 2012-03-15 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
17114
17115 * doc/sourcebuild.texi (cleanup-modules, keep-modules): Update
17116 documentation.
17117
17118 2012-03-15 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
17119
17120 * config.gcc (target_type_format_char): New. Document it. Set it for
17121 arm*-*-* .
17122 * configure.ac (gnu_unique_option): Use target_type_format_char
17123 in test. Comment rationale.
17124 * configure: Regenerate .
17125
17126 2012-03-15 Jakub Jelinek <jakub@redhat.com>
17127
17128 PR tree-optimization/52267
17129 * tree-vrp.c (masked_increment): New function.
17130 (register_edge_assert_for_2): Derive ASSERT_EXPRs
17131 from (X & CST1) cmp CST2 tests.
17132
17133 2012-03-15 Richard Guenther <rguenther@suse.de>
17134
17135 PR middle-end/52580
17136 * tree-data-ref.c (subscript_dependence_tester_1): Check
17137 all dimensions for non-conflicting access functions.
17138
17139 2012-03-15 Manuel López-Ibáñez <manu@gcc.gnu.org>
17140
17141 PR c++/44783
17142 * doc/invoke.texi [C++ Language Options]: Document
17143 -ftemplate-backtrace-limit.
17144
17145 2012-03-15 Tristan Gingold <gingold@adacore.com>
17146
17147 * c-parser.c (c_parser_parameter_declaration): Handle #pragma
17148 before a parameter.
17149
17150 2012-03-15 Tristan Gingold <gingold@adacore.com>
17151
17152 * dwarf2out.c (gen_subprogram_die): Require dwarf unwinding to
17153 use DW_OP_call_frame_cfa.
17154
17155 2012-03-14 H.J. Lu <hongjiu.lu@intel.com>
17156
17157 PR target/50797
17158 * config/i386/i386-opts.h (pmode): New.
17159
17160 * config/i386/i386.c (ix86_option_override_internal): Properly
17161 check and set ix86_pmode.
17162
17163 * config/i386/i386.h (Pmode): Check ix86_pmode instead of TARGET_64BIT.
17164
17165 * config/i386/i386.opt (maddress-mode=): New.
17166
17167 * doc/invoke.texi: Document -maddress-mode=short|long for x86.
17168
17169 2012-03-14 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17170
17171 * dwarf2cfi.c (def_cfa_0): Remove MIPS_DEBUGGING_INFO handling.
17172 (dwarf2out_do_cfi_asm): Likewise.
17173 * dwarf2out.c (output_call_frame_info): Remove MIPS_DEBUGGING_INFO
17174 handling.
17175 (add_data_member_location_attribute): Likewise.
17176 (gen_array_type_die): Likewise.
17177 (gen_subprogram_die): Likewise.
17178 (gen_producer_string): Likewise.
17179 * sdbout.c (sdbout_begin_prologue): Declare unconditionally.
17180 Remove MIPS_DEBUGGING_INFO handling.
17181 (sdb_debug_hooks): Likewise.
17182 (sdbout_begin_block): Likewise.
17183 (sdbout_end_block): Likewise.
17184 (sdbout_begin_prologue): Likewise.
17185 (sdbout_start_source_file): Likewise.
17186 (sdbout_end_source_file): Likewise.
17187 (sdbout_init): Likewise.
17188 * system.h (MIPS_DEBUGGING_INFO): Poison.
17189
17190 2012-03-14 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17191
17192 * config/alpha/alpha.c [HAVE_STAMP_H]: Remove.
17193 (alpha_file_start) [MS_STAMP]: Remove.
17194
17195 * config/alpha/elf.h (TARGET_GAS): Remove.
17196 * config/alpha/freebsd.h (TARGET_DEFAULT): Remove.
17197 * config/alpha/linux.h (TARGET_DEFAULT): Remove.
17198 * config/alpha/netbsd.h (TARGET_DEFAULT): Remove.
17199 * config/alpha/vms.h (TARGET_DEFAULT): Remove.
17200 * config.gcc (alpha*-*-linux*): Remove target_cpu_default.
17201 (alpha*-*-freebsd*): Likewise.
17202 (alpha*-*-netbsd*): Likewise.
17203 (alpha*-*-openbsd*): Likewise.
17204 (alpha*-*-*): Remove target_cpu_default2.
17205 * config/alpha/alpha.c (alpha_output_filename): Remove !TARGET_GAS
17206 handling.
17207 * config/alpha/alpha.h (TARGET_AS_CAN_SUBTRACT_LABELS): Remove.
17208 (TARGET_AS_SLASH_BEFORE_SUFFIX): Remove.
17209 * config/alpha/alpha.c (print_operand): Always assume
17210 TARGET_AS_SLASH_BEFORE_SUFFIX.
17211 * config/alpha/alpha.md ("*builtin_setjmp_receiver_er_sl_1"):
17212 Remove TARGET_AS_CAN_SUBTRACT_LABELS.
17213 ("*builtin_setjmp_receiver_er_1"): Remove.
17214 * config/alpha/alpha.opt (malpha-as): Remove.
17215 (mgas): Ignore.
17216 * doc/invoke.texi (Option Summary, DEC Alpha Options): Remove
17217 -malpha-as, -mgas.
17218 Remove DEC Unix reference.
17219
17220 * config/alpha/alpha.h (OBJECT_FORMAT_COFF): Remove.
17221 (EXTENDED_COFF): Remove.
17222 * config/alpha/elf.h (OBJECT_FORMAT_COFF): Don't undef.
17223 (EXTENDED_COFF): Don't undef.
17224 * config/alpha/alpha.c (alpha_file_start): Always assume
17225 OBJECT_FORMAT_ELF.
17226 Don't set targetm.asm_file_start_file_directive.
17227 [!OBJECT_FORMAT_ELF]: Remove.
17228 (TARGET_ASM_FILE_START_FILE_DIRECTIVE): Remove.
17229
17230 * config/alpha/alpha.h (SDB_DEBUGGING_INFO): Remove.
17231 (DBX_DEBUGGING_INFO): Remove.
17232 (MIPS_DEBUGGING_INFO): Remove.
17233 (PREFERRED_DEBUGGING_TYPE): Remove.
17234 (DBX_OUTPUT_SOURCE_LINE): Remove.
17235 (SDB_OUTPUT_SOURCE_LINE): Remove.
17236 (DBX_CONTIN_LENGTH): Remove.
17237 (NO_DBX_FUNCTION_END): Remove.
17238 (ASM_STABS_OP): Remove.
17239 (ASM_STABN_OP): Remove.
17240 (ASM_STABD_OP): Remove.
17241 (SDB_ALLOW_FORWARD_REFERENCES): Remove.
17242 (SDB_ALLOW_UNKNOWN_REFERENCES): Remove.
17243 (PUT_SDB_DEF): Remove.
17244 (PUT_SDB_PLAIN_DEF): Remove.
17245 (PUT_SDB_TYPE): Remove.
17246 (sdb_label_count): Remove.
17247 (PUT_SDB_BLOCK_START): Remove.
17248 (PUT_SDB_BLOCK_END): Remove.
17249 (PUT_SDB_FUNCTION_START): Remove.
17250 (PUT_SDB_FUNCTION_END): Remove.
17251 (PUT_SDB_EPILOGUE_END): Remove.
17252 * config/alpha/elf.h (SDB_DEBUGGING_INFO): Don't undef.
17253 (MIPS_DEBUGGING_INFO): Don't undef.
17254 (DBX_DEBUGGING_INFO): Don't undef.
17255 * config/alpha/vms.h (SDB_DEBUGGING_INFO): Don't undef.
17256 (MIPS_DEBUGGING_INFO): Don't undef.
17257 (DBX_DEBUGGING_INFO): Don't undef.
17258 * config/alpha/freebsd.h (DBX_CONTIN_CHAR): Remove.
17259 * config/alpha/alpha.c (alpha_option_override): Remove SDB_DEBUG
17260 handling.
17261 (alpha_start_function): Likewise.
17262 (sdb_label_count): Remove.
17263 (alpha_output_filename): Remove DBX_DEBUG handling.
17264 (alpha_file_start): Likewise.
17265
17266 2012-03-14 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17267
17268 * config.gcc (enable_obsolete): Remove *-*-solaris2.8*.
17269 (*-*-solaris2.[0-8], *-*-solaris2.[0-8].*): Mark unsupported.
17270 (i[34567]86-*-solaris2*, x86_64-*-solaris2.1[0-9]*): Remove
17271 Solaris 8 support.
17272 * configure.ac (gcc_cv_ld_hidden): Remove *-*-solaris2.8*.
17273 (ld_tls_support): Remove Solaris 8 references.
17274 (lwp_dir, lwp_spec): Remove support for alternate thread library.
17275 * acinclude.m4 (gcc_cv_initfini_array): Remove *-*-solaris2.* tests.
17276 * configure: Regenerate.
17277 * config.in: Regenerate.
17278
17279 * config/sol2.h (LINK_SPEC): Remove LIB_THREAD_LDFLAGS_SPEC.
17280 * config/i386/sol2.h: Remove Solaris 8 references.
17281
17282 * doc/install.texi (Specific, i?86-*-solaris2.[89]): Rename to ...
17283 (i?86-*-solaris2.9): ... this.
17284 Remove Solaris 8 references.
17285 (Specific, *-*-solaris2*): Document Solaris 8 removal.
17286 Remove Solaris 8 references.
17287
17288 2012-03-14 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17289
17290 * config.gcc (enable_obsolete): Remove mips-sgi-irix6.5.
17291 (mips-sgi-irix6.5*): Remove.
17292 * config.host (mips-sgi-irix*): Remove.
17293 * configure.ac (enable_fixed_point): Remove mips*-sgi-irix*.
17294 (set_have_as_tls): Remove *-*-irix6*.
17295 (gcc_cv_ld_static_dynamic): Remove mips-sgi-irix6*.
17296 * configure: Regenerate.
17297
17298 * config/mips/iris6.h: Remove.
17299 * config/mips/iris6.opt: Remove.
17300 * config/mips/t-irix6: Remove.
17301
17302 * config/mips/mips.h (TARGET_GPWORD): Remove IRIX 6 N64 handling.
17303 (TARGET_IRIX6): Remove.
17304 (TARGET_CPU_CPP_BUILTINS): Remove IRIX 6 handling.
17305 Don't define LANGUAGE_C, _LANGUAGE_C for Objective-C.
17306 * config/mips/mips.c (mips_build_builtin_va_list): Remove IRIX 6
17307 handling.
17308 (mips_file_start): Likewise.
17309 * config/mips/mips-protos.h (irix_asm_output_align): Remove.
17310
17311 * config/mips/driver-native.c [__sgi__]: Remove.
17312 (host_detect_local_cpu) [__sgi__]: Remove.
17313
17314 * config/mips/gnu-user.h: Remove iris5.h reference.
17315
17316 * config/mips/mips-modes.def: Remove IRIX 6 reference.
17317 * config/mips/gnu-user64.h (MIPS_TFMODE_FORMAT): Remove.
17318 * config/mips/mips.c (mips_option_override) [MIPS_TFMODE_FORMAT]:
17319 Remove.
17320
17321 * gcc.c (main): Move asm_debug initialization ...
17322 (asm_debug): ... here.
17323
17324 * ginclude/stddef.h (__STDDEF_H__): Don't define.
17325
17326 * defaults.h (LINK_ELIMINATE_DUPLICATE_LDIRECTORIES): Remove.
17327 * system.h (LINK_ELIMINATE_DUPLICATE_LDIRECTORIES): Poison.
17328 * collect2.c [LINK_ELIMINATE_DUPLICATE_LDIRECTORIES]: Remove.
17329 (main) [LINK_ELIMINATE_DUPLICATE_LDIRECTORIES]: Remove.
17330 [LINK_ELIMINATE_DUPLICATE_LDIRECTORIES] (is_in_args): Remove.
17331 * doc/tm.texi.in (Driver, LINK_ELIMINATE_DUPLICATE_LDIRECTORIES):
17332 Remove.
17333 * doc/tm.texi: Regenerate.
17334
17335 * doc/invoke.texi (Debugging Options, -gdwarf-<version>): Remove
17336 IRIX 6 reference.
17337 (MIPS Options, -march): Remove IRIX reference.
17338 * doc/install.texi (Binaries, SGI IRIX): Remove.
17339 (Specific, mips-sgi-irix6): Document IRIX 6.5 removal, remove rest
17340 of section.
17341 * doc/trouble.texi (Interoperation): Remove -lgl_s handling.
17342
17343 2012-03-14 Martin Jambor <mjambor@suse.cz>
17344
17345 * expr.c (expand_assignment): Use expand_expr with EXPAND_WRITE
17346 when expanding MEM_REFs, MEM_TARGET_REFs and handled_component bases.
17347 (expand_expr_real_1): Do not handle misalignment if modifier is
17348 EXPAND_WRITE.
17349
17350 2012-03-14 Richard Guenther <rguenther@suse.de>
17351
17352 PR middle-end/52584
17353 * tree-vect-generic.c (type_for_widest_vector_mode): Take
17354 element type instead of mode, use build_vector_type_for_mode
17355 instead of the langhook, build a vector of proper signedness.
17356 (expand_vector_operations_1): Adjust.
17357
17358 2012-03-14 Richard Guenther <rguenther@suse.de>
17359
17360 PR middle-end/52582
17361 * gimple-fold.c (canonicalize_constructor_val): Make sure we have
17362 a cgraph node for a FUNCTION_DECL that comes from a constructor.
17363 (gimple_get_virt_method_for_binfo): Likewise.
17364
17365 2012-03-14 Richard Guenther <rguenther@suse.de>
17366
17367 PR tree-optimization/52571
17368 * tree-vect-data-refs.c (vect_compute_data_ref_alignment): Move
17369 flag_section_anchors check ...
17370 (vect_can_force_dr_alignment_p): ... here. Do not re-align
17371 DECL_COMMON variables.
17372
17373 2012-03-14 Richard Guenther <rguenther@suse.de>
17374
17375 * tree.h (DECL_BIT_FIELD_REPRESENTATIVE): New define.
17376 * stor-layout.c (start_bitfield_representative): New function.
17377 (finish_bitfield_representative): Likewise.
17378 (finish_bitfield_layout): Likewise.
17379 (finish_record_layout): Call finish_bitfield_layout.
17380 * tree.c (free_lang_data_in_decl): Only free DECL_QUALIFIER
17381 for QUAL_UNION_TYPE fields.
17382 * tree-streamer-in.c (lto_input_ts_field_decl_tree_pointers):
17383 Stream DECL_BIT_FIELD_REPRESENTATIVE.
17384 * tree-streamer-out.c (write_ts_field_decl_tree_pointers): Likewise.
17385
17386 PR middle-end/52080
17387 PR middle-end/52097
17388 PR middle-end/48124
17389 * expr.c (get_bit_range): Unconditionally extract bitrange
17390 from DECL_BIT_FIELD_REPRESENTATIVE.
17391 (expand_assignment): Adjust call to get_bit_range.
17392
17393 2012-03-14 Richard Guenther <rguenther@suse.de>
17394
17395 PR middle-end/52578
17396 * fold-const.c (fold_unary_loc): Fold (T1)(T2)x to (T1)x if
17397 the outermost conversion is a sign-change only.
17398 (fold_binary_loc): Disregard widening and sign-changing
17399 conversions when we determine if two variables are equal
17400 for reassociation.
17401 * tree-ssa-forwprop.c (combine_conversions): Fold (T1)(T2)x to
17402 (T1)x if the outermost conversion is a sign-change only.
17403
17404 2012-03-14 Uros Bizjak <ubizjak@gmail.com>
17405
17406 Revert:
17407 2012-03-14 Uros Bizjak <ubizjak@gmail.com>
17408
17409 * config/i386/predicates.md (constant_call_address_operand): Declare
17410 as special predicate. Update all uses.
17411
17412 2012-03-13 Jakub Jelinek <jakub@redhat.com>
17413
17414 PR c/52577
17415 * c-parser.c (c_parser_postfix_expression)
17416 <case RID_BUILTIN_SHUFFLE>: Call mark_exp_read on argument values.
17417
17418 * config/i386/smmintrin.h: Avoid /* within a comment.
17419 * config/i386/nmmintrin.h: Likewise.
17420
17421 2012-03-13 Uros Bizjak <ubizjak@gmail.com>
17422
17423 * config/i386/i386.md (xbegin): Remove constraint from expander.
17424
17425 2012-03-13 Uros Bizjak <ubizjak@gmail.com>
17426
17427 * config/i386/predicates.md (constant_call_address_operand): Declare
17428 as special predicate. Update all uses.
17429 * config/i386/i386.md: Remove mode from constant_call_address_operand
17430 predicates.
17431 * config/i386/i386.c (ix86_output_call_insn): Call
17432 constant_call_address_operand with VOIDmode.
17433
17434 2012-03-13 Uros Bizjak <ubizjak@gmail.com>
17435
17436 * config/i386/i386.c (ix86_decompose_address): Handle subregs of
17437 AND zero extended address correctly.
17438
17439 2012-03-13 Uros Bizjak <ubizjak@gmail.com>
17440
17441 * config/i386/predicates.md (tls_symbolic_operand): Declare as
17442 special predicate.
17443 (tls_modbase_operand): Ditto.
17444 * config/i386/i386.md: Remove mode from tls_symbolic_operand and
17445 tls_modbase_operand predicates.
17446
17447 2012-03-13 Martin Jambor <mjambor@suse.cz>
17448
17449 * expr.c (expand_assignment): Handle misaligned scalar writes to
17450 memory through top-level MEM_REFs by calling store_bit_field.
17451
17452 2012-03-13 Richard Guenther <rguenther@suse.de>
17453
17454 PR middle-end/52134
17455 * fold-const.c (fold_binary_loc): Fold (X * Y) & -(1 << CST) to X * Y
17456 if Y is a constant multiple of 1 << CST.
17457
17458 2012-03-13 Georg-Johann Lay <avr@gjlay.de>
17459
17460 PR target/52488
17461 * config/avr/avr.c (avr_prologue_setup_frame): Cut down stack
17462 offset (size) to a value the insns can deal with.
17463 (expand_epilogue): Ditto.
17464
17465 2012-03-13 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
17466
17467 * config/arm/neon.ml (ops): Fixup expected instructions for
17468 unsigned vector compares.
17469
17470 2012-03-13 Uros Bizjak <ubizjak@gmail.com>
17471
17472 * config/i386/i386.c (ix86_decompose_address): Prevent %fs:(%reg)
17473 addresses only when %reg is not in word mode.
17474
17475 2012-03-13 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17476
17477 * config/microblaze/microblaze.md: Fix typo.
17478 * tree-if-conv.c: Likewise.
17479 * tree-vect-patterns.c: Likewise.
17480
17481 2012-03-13 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17482
17483 * config.gcc (extra_passes): Remove.
17484 * configure.ac (extra_passes): Don't substitute.
17485 * configure: Regenerate.
17486 * Makefile.in (EXTRA_PASSES): Remove.
17487 (GCC_PASSES): Remove $(EXTRA_PASSES).
17488 (MOSTLYCLEANFILES): Likewise.
17489 (native): Likewise.
17490 (install-common): Likewise.
17491
17492 2012-03-13 Uros Bizjak <ubizjak@gmail.com>
17493
17494 * config/i386/i386.h (TARGET_TLS_INDIRECT_SEG_REFS): New.
17495 * config/i386/i386.c (ix86_decompose_address): Use
17496 TARGET_TLS_INDIRECT_SEG_REFS to prevent %fs:(%reg) addresses.
17497 (legitimize_tls_address): Use TARGET_TLS_INDIRECT_SEG_REFS to load
17498 thread pointer to a register.
17499
17500 2012-03-12 H.J. Lu <hongjiu.lu@intel.com>
17501
17502 * config/i386/i386.md (*tls_global_dynamic_64_<mode>): Remove :P
17503 on tls_symbolic_operand.
17504 (tls_global_dynamic_64_<mode>): Likewise.
17505
17506 2012-03-12 Georg-Johann Lay <avr@gjlay.de>
17507
17508 PR other/52545
17509 * output.h (SECTION_EXCLUDE, SECTION_MACH_DEP): Don't use
17510 SECTION_MACH_DEP reserved bits for SECTION_EXCLUDE.
17511
17512 2012-03-12 Georg-Johann Lay <avr@gjlay.de>
17513
17514 PR target/52499
17515 * config/avr/avr.c (avr_mode_code_base_reg_class): Change return
17516 type from reg_class_t to enum reg_class.
17517 * config/avr/avr-protos.h (avr_mode_code_base_reg_class): Ditto.
17518
17519 2012-03-12 Andrew Pinski <apinski@cavium.com>
17520
17521 * tree-ssa-phiopt.c (single_non_singleton_phi_for_edges): New function.
17522 (tree_ssa_phiopt_worker): Use single_non_singleton_phi_for_edges.
17523 (value_replacement): Likewise.
17524 (empty_block_p): Check also if the PHIs for the block are empty.
17525
17526 2012-03-12 Georg-Johann Lay <avr@gjlay.de>
17527
17528 PR target/52148
17529 * config/avr/avr.c (avr_out_movmem): Fix typo in output template
17530 for the case ADDR_SPACE_FLASH and AVR_HAVE_LPMX introduced in
17531 r184615 from 2012-02-28.
17532
17533 2012-03-12 H.J. Lu <hongjiu.lu@intel.com>
17534
17535 * config/i386/i386.c (ix86_gen_tls_global_dynamic_64): New.
17536 (ix86_gen_tls_local_dynamic_base_64): Likewise.
17537 (ix86_option_override_internal): Set ix86_gen_tls_global_dynamic_64
17538 and ix86_gen_tls_local_dynamic_base_64.
17539 (legitimize_tls_address): Use ix86_gen_tls_global_dynamic_64 and
17540 ix86_gen_tls_local_dynamic_base_64.
17541
17542 * config/i386/i386.md (*tls_global_dynamic_64): Renamed to ...
17543 (*tls_global_dynamic_64_<mode>): This.
17544 (tls_global_dynamic_64): Renamed to ...
17545 (tls_global_dynamic_64_<mode>): This.
17546 (*tls_local_dynamic_base_64): Renamed to ...
17547 (*tls_local_dynamic_base_64_<mode>): This.
17548 (tls_local_dynamic_base_64): Renamed to ...
17549 (tls_local_dynamic_base_64_<mode>): This.
17550
17551 2012-03-12 H.J. Lu <hongjiu.lu@intel.com>
17552
17553 * config/i386/i386.c (ix86_option_override_internal): Properly
17554 set ix86_gen_leave and ix86_gen_monitor. Check Pmode == DImode,
17555 instead of TARGET_64BIT, to set ix86_gen_add3, ix86_gen_sub3,
17556 ix86_gen_one_cmpl2, ix86_gen_andsp, ix86_gen_allocate_stack_worker,
17557 ix86_gen_adjust_stack_and_probe and ix86_gen_probe_stack_range.
17558
17559 * config/i386/sse.md (sse3_monitor64): Renamed to ...
17560 (sse3_monitor64_<mode>): This.
17561
17562 2012-03-12 Tristan Gingold <gingold@adacore.com>
17563
17564 * config/ia64/ia64.c (ia64_function_arg_1): Move code around.
17565 (ia64_function_arg_advance): Ditto.
17566
17567 2012-03-12 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17568
17569 * config.gcc (mips*-*-openbsd*): Remove.
17570 * config/mips/openbsd.h: Remove.
17571 * config/mips/sdb.h: Remove.
17572
17573 * config/mips/mips.h (SDB_OUTPUT_SOURCE_LINE): Remove.
17574 * config/mips/mips.c (sdb_label_count): Remove.
17575 (mips_debugger_offset): Remove #if 0 code.
17576 (mips_output_function_prologue) [SDB_DEBUGGING_INFO]: Remove.
17577 * config/mips/sde.h (SDB_DEBUGGING_INFO): Don't undef.
17578
17579 2012-03-12 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17580
17581 * doc/install.texi (Specific, i?86-*-solaris2.[89]): Update
17582 binutils reference.
17583 (Specific, i?86-*-solaris2.10): Remove GCC 4.0 reference.
17584 Update binutils references.
17585 (Specific, *-*-solaris2*): Mention bundled GCC in Solaris 10 and 11.
17586 Update binutils reference.
17587 Update Sun as/GNU ld caveat.
17588 Document binutils largefile requirement for LTO plugin.
17589 Remove reference to alternate libpthread.
17590
17591 2012-03-12 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17592
17593 * config.gcc (alpha*-dec-osf5.1*): Remove.
17594 * config.host (alpha*-dec-osf*): Remove.
17595 * configure.ac (*-*-osf*): Remove.
17596 (alpha*-dec-osf*): Remove.
17597 * configure: Regenerate.
17598
17599 * config/alpha/host-osf.c, config/alpha/osf5.h, config/alpha/osf5.opt,
17600 config/alpha/va_list.h, config/alpha/x-osf: Remove.
17601
17602 * config/alpha/alpha.h (TARGET_LD_BUGGY_LDGP): Remove.
17603 * config/alpha/alpha.c (struct machine_function): Update comment.
17604 (alpha_start_function): Remove Tru64 UNIX as handling for
17605 max_frame_size.
17606 * config/alpha/alpha.md ("exception_receiver"): Remove
17607 TARGET_LD_BUGGY_LDGP.
17608 ("*exception_receiver_2"): Likewise.
17609 * except.c (finish_eh_generation): Remove Tru64 reference.
17610 * ginclude/stdarg.h [_HIDDEN_VA_LIST]: Don't undef _VA_LIST.
17611 * system.h (TARGET_HANDLE_PRAGMA_EXTERN_PREFIX): Poison.
17612 * target.def (handle_pragma_extern_prefix): Remove.
17613
17614 * Makefile.in (mips-tfile.o-warn): Remove.
17615 (ALL_HOST_BACKEND_OBJS): Remove mips-tfile.o, mips-tdump.o.
17616 (mips-tfile, mips-tfile.o, mips-tdump, mips-tdump.o): Remove.
17617 * mips-tdump.c, mips-tfile.c: Remove.
17618
17619 * doc/extend.texi (Symbol-Renaming Pragmas): Remove #pragma
17620 extern_prefix.
17621 * doc/install.texi (Binaries): Remove Tru64 UNIX reference.
17622 (Specific, alpha*-dec-osf5.1): Note removal.
17623 * doc/tm.texi.in (Misc, TARGET_HANDLE_PRAGMA_EXTERN_PREFIX):
17624 Remove.
17625 * doc/tm.texi: Regenerate.
17626 * doc/trouble.texi (Cross-Compiler Problems): Remove.
17627
17628 2012-03-12 Richard Guenther <rguenther@suse.de>
17629
17630 * config/arm/arm.c (neon_dereference_pointer): Do not call
17631 covert during RTL expansion.
17632
17633 2012-03-12 Tristan Gingold <gingold@adacore.com>
17634
17635 * doc/invoke.texi (VMS Options): Merge Alpha/VMS and IA-64/VMS
17636 Options. Mention -mpointer-size.
17637
17638 2012-03-12 Richard Guenther <rguenther@suse.de>
17639
17640 * config/alpha/alpha.c (alpha_gimplify_va_arg): Use
17641 build_nonstandard_integer_type.
17642
17643 2012-03-12 Richard Guenther <rguenther@suse.de>
17644
17645 * tree.c (signed_or_unsigned_type_for): Use
17646 build_nonstandard_integer_type.
17647 (signed_type_for): Adjust documentation.
17648 (unsigned_type_for): Likewise.
17649 * tree-pretty-print.c (dump_generic_node): Use standard names
17650 for non-standard integer types if available.
17651
17652 2012-03-12 Tristan Gingold <gingold@adacore.com>
17653
17654 * config/vms/vms.opt: Add vms-opts.h header.
17655 (mmalloc64): Use flag_vms_malloc64 flag instead of MALLOC64
17656 target mask.
17657 (-mvms-return-codes): Document.
17658 (-mpointer-size): New option.
17659 (vms_pointer_size): Add enumeration.
17660 * config/vms/vms-opts.h: New file.
17661 * config/vms/vms.h (TARGET_OS_CPP_BUILTINS): Define
17662 __INITIAL_POINTER_SIZE.
17663 (POINTER_SIZE, SIZE_TYPE, PTRDIFF_TYPE): Adjust definition.
17664 (C_COMMON_OVERRIDE_OPTIONS): Define.
17665 (DWARF2_ADDR_SIZE): Define.
17666 * config/vms/vms.c (vms_patch_builtins): Adjust condition.
17667 * config/vms/vms-protos.h (vms_c_common_override_options):
17668 New prototype.
17669 * config/vms/vms-c.c (vms_pragma_pointer_size): Ignore pragma
17670 if -mno-pointer-size.
17671 (vms_c_common_override_options): New function.
17672 * config/ia64/vms.h (TARGET_DEFAULT): Remove MASK_MALLOC64.
17673 * config/alpha/vms.h (TARGET_DEFAULT): Remove MASK_MALLOC64.
17674 (MALLOC_ABI_ALIGNMENT): Use flag_vms_malloc64
17675 and flag_vms_pointer_size.
17676 (MASK_RETURN_ADDR): Set according to flag_vms_pointer_size.
17677 * config.gcc (*-*-*vms*): Define xm_file.
17678 (alpha*-dec-*vms*): Do not define xm_file.
17679 (alpha64-dec-*vms*): Remove.
17680 (ia64-hp-*vms*): Do not define xm_file. Simplify tm_file
17681 and tmake_file.
17682
17683 2012-03-12 Jakub Jelinek <jakub@redhat.com>
17684
17685 PR tree-optimization/51721
17686 * tree-vrp.c (register_edge_assert_for_2): Add asserts for unsvar
17687 if (int) unsvar cmp CST.
17688
17689 2012-03-12 Richard Guenther <rguenther@suse.de>
17690
17691 * tree-sra.c (create_access_replacement): Only rename the replacement
17692 if we can rewrite it into SSA form. Properly mark register typed
17693 replacements that we cannot rewrite with TREE_ADDRESSABLE.
17694 * tree-cfg.c (verify_expr): Fix BIT_FIELD_REF verification
17695 for aggregate or BLKmode results.
17696
17697 2012-03-12 Jakub Jelinek <jakub@redhat.com>
17698
17699 PR tree-optimization/52533
17700 * tree-vrp.c (register_edge_assert_for_2): Use double_int
17701 type for mask, only handle shifts by non-zero in-range
17702 shift count, for LE_EXPR and GT_EXPR if new_val is
17703 maximum, don't add the assertion.
17704
17705 2012-02-12 Kirill Yukhin <kirill.yukhin@intel.com>
17706
17707 * doc/invoke.texi: Document -mrtm option.
17708 * common/config/i386/i386-common.c (OPTION_MASK_ISA_RTM_SET): New.
17709 (OPTION_MASK_ISA_RTM_UNSET): Ditto.
17710 (ix86_handle_option): Handle OPT_mrtm.
17711 * config.gcc (i[34567]86-*-*): Add rtmintrin.h and
17712 xtestintrin.h.
17713 (x86_64-*-*): Ditto.
17714 * i386-builtin-types.def (INT_FTYPE_VOID): New.
17715 * config/i386/i386-c.c (ix86_target_macros_internal): Define
17716 __RTM__ if needed.
17717 (ix86_target_string): Define -mrtm option.
17718 (PTA_RTM): New.
17719 (ix86_option_override_internal): Extend "corei7-avx" with RTM option.
17720 Handle new option.
17721 (ix86_valid_target_attribute_inner_p): Add OPT_mrtm.
17722 (ix86_builtins): Add IX86_BUILTIN_XBEGIN, IX86_BUILTIN_XEND,
17723 IX86_BUILTIN_XTEST.
17724 (bdesc_special_args): Ditto.
17725 (ix86_init_mmx_sse_builtins): Add IX86_BUILTIN_XABORT.
17726 (ix86_expand_special_args_builtin): Handle new built-in type.
17727 (ix86_expand_builtin): Handle XABORT instruction.
17728 * config/i386/i386.h (TARGET_RTM): New.
17729 * config/i386/i386.md (UNSPECV_XBEGIN): New.
17730 (UNSPECV_XEND): Ditto.
17731 (UNSPECV_XABORT): Ditto.
17732 (UNSPECV_XTEST): Ditto.
17733 (xbegin): Ditto.
17734 (xbegin_1): Ditto.
17735 (xend): Ditto.
17736 (xabort): Ditto
17737 (xtest): Ditto.
17738 (xtest_1): Ditto.
17739 * config/i386/i386.opt (mrtm): New.
17740 * config/i386/immintrin.h: Include rtmintrin.h and xtestintrin.h.
17741 * config/i386/rtmintrin.h: New header.
17742 * config/i386/xtestintrin.h: Ditto.
17743
17744 2012-03-12 Tristan Gingold <gingold@adacore.com>
17745
17746 * ginclude/stddef.h: Adjust previous patch.
17747 Use __VMS__ instead of VMS.
17748
17749 2012-03-12 Uros Bizjak <ubizjak@gmail.com>
17750
17751 * config/i386/i386.md (setcc + movzbl to xor + setcc peephole2):
17752 Also convert sequences with CC setting arithmetic instruction.
17753
17754 2012-03-11 Sandra Loosemore <sandra@codesourcery.com>
17755
17756 * doc/invoke.texi (Option Summary): Move -no-integrated-cpp
17757 from C Language Options to Preprocessor Options.
17758 (C Dialect Options): Move -no-integrated-cpp documentation
17759 from here...
17760 (Preprocessor Options): ...to here. Rewrite the description
17761 so it makes more sense, and remove discussion of merging front ends.
17762
17763 2012-03-11 H.J. Lu <hongjiu.lu@intel.com>
17764
17765 * config/i386/i386.c (ix86_expand_movmem): Use word_mode for size
17766 needed for loop.
17767 (ix86_expand_setmem): Likewise.
17768
17769 2012-03-11 Uros Bizjak <ubizjak@gmail.com>
17770
17771 * config/i386/i386.c (ix86_zero_extend_to_Pmode): Rewrite using
17772 convert_to_mode.
17773
17774 2012-03-11 H.J. Lu <hongjiu.lu@intel.com>
17775
17776 * config/i386/i386.c (ix86_trampoline_init): Use movl for 64bit if
17777 ptr_mode == SImode. Replace DImode with Pmode or ptr_mode.
17778
17779 2012-03-11 H.J. Lu <hongjiu.lu@intel.com>
17780
17781 * config/i386/i386.c (x86_this_parameter): Replace DImode with Pmode.
17782
17783 2012-03-11 H.J. Lu <hongjiu.lu@intel.com>
17784
17785 * config/i386/i386.md (lwp_slwpcb): Check Pmode instead of
17786 TARGET_64BIT.
17787
17788 2012-03-11 H.J. Lu <hongjiu.lu@intel.com>
17789 Uros Bizjak <ubizjak@gmail.com>
17790
17791 * config/i386/predicates.md (call_insn_operand): Allow
17792 constant_call_address_operand in Pmode only.
17793 (sibcall_insn_operand): Ditto.
17794 * config/i386/i386.md (*call): Use W mode iterator instead of P mode.
17795 (*call_vzeroupper): Ditto.
17796 (*sibcall): Ditto.
17797 (*sibcall_vzeroupper): Ditto.
17798 (*call_value): Ditto.
17799 (*call_value_vzeroupper): Ditto.
17800 (*sibcall_value): Ditto.
17801 (*sibcall_value_vzeroupper): Ditto.
17802 (*indirect_jump): Ditto.
17803 (*tablejump_1): Ditto.
17804 (indirect_jump): Convert memory address to word mode for TARGET_X32.
17805 (tablejump): Ditto.
17806 * config/i386/i386.c (ix86_expand_call): Convert indirect operands
17807 to word mode.
17808
17809 2012-03-11 Oleg Endo <olegendo@gcc.gnu.org>
17810
17811 PR target/51244
17812 * config/sh/sh.md (movnegt): Expand into respective insns immediately.
17813 Use movrt_negc instead of negc pattern for non-SH2A.
17814 (*movnegt): Remove.
17815 (*movrt_negc, *negnegt, *movtt, *movt_qi): New insns and splits.
17816
17817 2012-03-10 H.J. Lu <hongjiu.lu@intel.com>
17818
17819 * config/i386/i386.c (ix86_decompose_address): Disallow fs:(reg)
17820 if Pmode != word_mode.
17821 (legitimize_tls_address): Call gen_tls_initial_exec_x32 if
17822 Pmode == SImode for TARGET_X32.
17823
17824 * config/i386/i386.md (UNSPEC_TLS_IE_X32): New.
17825 (tls_initial_exec_x32): Likewise.
17826
17827 2012-03-10 Chung-Lin Tang <cltang@codesourcery.com>
17828
17829 PR rtl-optimization/52528
17830 * combine.c (can_combine_p): Add setting of subst_low_luid
17831 before call to expand_field_assignment().
17832
17833 2012-03-09 Sandra Loosemore <sandra@codesourcery.com>
17834
17835 * doc/invoke.texi: Use correct names/markup for "GCC", "GDB", "ld",
17836 and related program names.
17837
17838 2012-03-09 Sandra Loosemore <sandra@codesourcery.com>
17839
17840 * doc/invoke.texi: Use correct names for "DWARF", "stabs", and "ELF".
17841
17842 2012-03-09 Uros Bizjak <ubizjak@gmail.com>
17843
17844 PR target/52530
17845 * config/i386/i386.c (ix86_print_operand): Handle 'E' operand modifier.
17846 (ix86_print_operand_address): Handle UNSPEC_LEA_ADDR. Do not fallback
17847 to set code to 'q'.
17848 * config/i386/i386.md (UNSPEC_LEA_ADDR): New unspec.
17849 (*movdi_internal_rex64): Use %E operand modifier for lea.
17850 (*movsi_internal): Ditto.
17851 (*lea_1): Ditto.
17852 (*lea<mode>_2): Ditto.
17853 (*lea_{3,4,5,6}_zext): Ditto.
17854 (*tls_global_dynamic_32_gnu): Ditto.
17855 (*tls_global_dynamic_64): Ditto.
17856 (*tls_dynamic_gnu2_lea_32): Ditto.
17857 (*tls_dynamic_gnu2_lea_64): Ditto.
17858 (pro_epilogue_adjust_stack_<mode>_add): Ditto.
17859
17860 2012-03-09 Michael Meissner <meissner@linux.vnet.ibm.com>
17861
17862 * config/rs6000/linux64.h (OPTION_TARGET_CPU_DEFAULT): Do not
17863 redefine to be NULL if the current bit-size is different from the
17864 configured bit-size.
17865
17866 * config/rs6000/rs6000.c (rs6000_option_override_internal): If the
17867 cpu is defaulted, use PROCESSOR_DEFAULT and PROCESSOR_DEFAULT64 to
17868 set the default tuning. Add asserts to make sure the cpu and tune
17869 indexes are defined. Fix tests for cpu/tune index to use >= 0 to
17870 test whether the index is set, instead of > 0.
17871 (rs6000_file_start): Do not reset the default cpu if the current
17872 bit-size is different from the configured bit-size.
17873
17874 2012-03-09 Tristan Gingold <gingold@adacore.com>
17875
17876 * config/vms/vms-crtlmap.map: Add comments.
17877 Add entries needed to build Ada RTS.
17878
17879 2012-03-09 Tristan Gingold <gingold@adacore.com>
17880
17881 * ginclude/stddef.h: Do not define __size_t on VMS.
17882
17883 2012-03-09 Tristan Gingold <gingold@adacore.com>
17884
17885 * c-tree.h (c_default_pointer_mode): New variable.
17886 * c-decl.c (c_default_pointer_mode): New variable.
17887 (c_build_pointer_type): New function.
17888 (grokdeclarator): Call c_build_pointer_type instead
17889 of build_pointer_type.
17890
17891 * config/vms/vms-c.c: Include c-tree.h
17892 (saved_pointer_mode): New variable.
17893 (handle_pragma_pointer_size): New function.
17894 (vms_pragma_pointer_size, vms_pragma_required_pointer_size): Likewise.
17895 (vms_c_register_pragma): Register __pointer_size and
17896 __required_pointer_size pragmas.
17897
17898 2012-03-09 Tristan Gingold <gingold@adacore.com>
17899
17900 * config/vms/vms-c.c (vms_construct_include_filename): New function.
17901 (vms_c_register_includes): Reference it.
17902
17903 2012-03-09 Andrew Pinski <apinski@cavium.com>
17904
17905 PR middle-end/51988
17906 * tree-ssa-phiopt.c: Include tree-pretty-print.h for
17907 print_generic_expr.
17908 (tree_ssa_phiopt_worker): Go through all the PHIs for
17909 value_replacement instead of just the singleton one.
17910 (value_replacement): Change return type to int. Return 0 instead of
17911 false.
17912 Allow the middle basic block to contain more than just the defining
17913 statement.
17914 Handle non empty middle basic blocks.
17915 * Makefile.in (tree-ssa-phiopt.o): Add tree-pretty-print.h.
17916
17917 2012-03-09 Jiangning Liu <jiangning.liu@arm.com>
17918
17919 * tree-scalar-evolution (interpret_rhs_expr): generate chrec for
17920 array reference and component reference.
17921 (analyze_scalar_evolution_for_address_of): New.
17922
17923 2012-03-08 Jie Zhang <jzhang918@gmail.com>
17924
17925 PR target/49862
17926 * config/bfin/bfin.c (hwloop_optimize): Fix unused variable warnings.
17927 (hwloop_pattern_reg): Fix set but not used warning.
17928 (bfin_reorg_loops): Remove unused parameter.
17929 (bfin_reorg): Update use of bfin_reorg_loops.
17930
17931 2012-03-08 H.J. Lu <hongjiu.lu@intel.com>
17932
17933 * config/i386/i386.c (setup_incoming_varargs_64): Use word_mode
17934 with integer parameters in registers.
17935 (gen_push): Push register in word_mode instead of Pmode.
17936 (ix86_emit_save_regs): Likewise.
17937 (ix86_emit_save_regs_using_mov): Save integer registers in word_mode.
17938 (gen_pop): Pop register in word_mode instead of Pmode.
17939 (ix86_emit_restore_regs_using_pop): Likewise.
17940 (ix86_expand_prologue): Replace Pmode with word_mode for push
17941 immediate. Use ix86_gen_pro_epilogue_adjust_stack. Save and
17942 restore RAX and R10 in word_mode.
17943 (ix86_emit_restore_regs_using_mov): Restore integer registers
17944 in word_mode.
17945 (ix86_expand_split_stack_prologue): Save R10_REG and restore in
17946 word_mode.
17947 (ix86_split_to_parts): Use word_mode with PUT_MODE for push.
17948 (ix86_split_long_move): Likewise.
17949
17950 * config/i386/i386.md (W): New.
17951 (*push<mode>2_prologue): Replace :P with :W.
17952 (*pop<mode>1): Likewise.
17953 (*pop<mode>1_epilogue): Likewise.
17954 (push/pop peephole2): Use word_mode scratch registers.
17955
17956 2012-03-08 Uros Bizjak <ubizjak@gmail.com>
17957
17958 * config/i386/predicates.md (indirect_branch_operand): Simplify.
17959
17960 2012-03-08 Georg-Johann Lay <avr@gjlay.de>
17961
17962 * config/avr/avr.md (*addhi3, addhi3_clobber): Add "w" alternative
17963 for constants in [-63,63].
17964
17965 2012-03-08 Uros Bizjak <ubizjak@gmail.com>
17966
17967 PR target/52530
17968 Revert:
17969 2012-03-04 H.J. Lu <hongjiu.lu@intel.com>
17970
17971 * config/i386/i386.c (ix86_print_operand_address): Only handle
17972 zero-extended DImode addresses.
17973
17974 2012-03-08 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
17975
17976 * configure.ac (gcc_cv_as_ix86_tlsldmplt): Add label.
17977 * configure: Regenerate.
17978
17979 2012-03-08 Georg-Johann Lay <avr@gjlay.de>
17980
17981 PR target/52496
17982 * config/avr/avr.c (avr_mem_clobber): New static function.
17983 (avr_expand_delay_cycles): Add memory clobber operand to
17984 delay_cycles_1, delay_cycles_2, delay_cycles_3, delay_cycles_4.
17985 * config/avr/avr.md (unspec): Add UNSPEC_MEMORY_BARRIER.
17986 (enable_interrupt, disable_interrupt): New expander.
17987 (nopv, sleep, wdr): New expanders.
17988 (delay_cycles_1): Add memory clobber.
17989 (delay_cycles_2): Add memory clobber.
17990 (delay_cycles_3): Add memory clobber.
17991 (delay_cycles_4): Add memory clobber.
17992 (cli_sei): New insn from former "enable_interrupt",
17993 "disable_interrupt" with memory clobber.
17994 (*wdt): New insn from former "wdt" with memory clobber.
17995 (*nopv): Similar, but for "nopv".
17996 (*sleep): Similar, but for "sleep".
17997
17998 2012-03-07 Oleg Endo <olegendo@gcc.gnu.org>
17999 Kaz Kojima <kkojima@gcc.gnu.org>
18000
18001 PR target/52503
18002 * config/sh/sh.opt (msoft-atomic): Use Var instead of Mask.
18003 * config/sh/linux.h (TARGET_DEFAULT): Remove MASK_SOFT_ATOMIC.
18004 (SUBTARGET_OVERRIDE_OPTIONS): Define.
18005
18006 2012-03-07 Uros Bizjak <ubizjak@gmail.com>
18007
18008 * config/i386/predicates.md (x86_64_zext_general_operand): New.
18009 * config/i386/i386.md (*zero_extendsidi2_rex64): Change operand 1
18010 predicate to x86_64_zext_general_operand. Accept "Z" constraint.
18011
18012 2012-03-07 Walter Lee <walt@tilera.com>
18013
18014 * config/tilegx/tilegx.c (tilegx_expand_prologue): Don't generate
18015 REG_CFA_* notes for the stack pointer.
18016 (tilegx_expand_epilogue): Restore stack pointer by adjusting it by
18017 EH_RETURN_STACKADJ_RTX.
18018 * config/tilepro/tilepro.c (tilepro_expand_prologue): Don't
18019 generate REG_CFA_* notes for the stack pointer.
18020 (tilepro_expand_epilogue): Restore stack pointer by adjusting it
18021 by EH_RETURN_STACKADJ_RTX.
18022
18023 2012-03-07 Georg-Johann Lay <avr@gjlay.de>
18024
18025 * doc/invoke.texi (AVR Built-in Macros): Correct condition for
18026 when __AVR_3_BYTE_PC__ is defined.
18027
18028 2012-03-07 Uros Bizjak <ubizjak@gmail.com>
18029
18030 * config/i386/i386.c (ix86_print_operand_punct_valid_p): Add '^'.
18031 (ix86_print_operand): Handle '^'.
18032 * config/i386/i386.md (*strmovdi_rex_1): Macroize memory operands
18033 using P mode iterator. Add %^ to asm template to conditionally emit
18034 addr32 prefix.
18035 (*rep_movdi_rex64): Ditto.
18036 (*strsetdi_rex_1): Ditto.
18037 (*rep_stosdi_rex64): Ditto.
18038 (*strmov{si,hi,qi}_1): Add %^ to asm template to
18039 conditionally emit addr32 prefix.
18040 (*rep_mov{si,qi}): Ditto.
18041 (*strset{si,hi,qi}): Ditto.
18042 (*rep_stos{si,qi}): Ditto.
18043 (*cmpstrnqi_nz_1): Ditto.
18044 (*cmpstrnqi_1): Ditto.
18045 (*strlenqi_1): Ditto.
18046
18047 2012-03-07 H.J. Lu <hongjiu.lu@intel.com>
18048
18049 * config/i386/i386.c (function_value_64): Return pointers in
18050 word_mode instead of Pmode.
18051 (ix86_promote_function_mode): Likewise.
18052
18053 2012-03-07 Richard Guenther <rguenther@suse.de>
18054
18055 * coverage.c (get_gcov_type): Use type_for_mode.
18056 (get_gcov_unsigned_t): Likewise.
18057 * expr.c (store_constructor): Use type_for_mode.
18058 (try_casesi): Likewise.
18059 * tree-ssa-loop-ivopts.c (add_standard_iv_candidates_for_size): Remove.
18060 (add_standard_iv_candidates): Use standard type trees.
18061 * dojump.c (do_jump): Remove dead code.
18062
18063 2012-03-07 Richard Guenther <rguenther@suse.de>
18064
18065 * c-typeck.c (pointer_diff): Use c_common_type_for_size.
18066
18067 2012-03-07 Richard Guenther <rguenther@suse.de>
18068
18069 * convert.c (strip_float_extensions): Move ...
18070 * tree.c (strip_float_extensions): ... here.
18071
18072 2012-03-07 Georg-Johann Lay <avr@gjlay.de>
18073
18074 PR target/52484
18075 * config/avr/avr.md (xload<mode>_A): Add R22... to register footprint.
18076
18077 2012-03-07 Richard Guenther <rguenther@suse.de>
18078
18079 * omp-low.c (extract_omp_for_data): Use signed_type_for.
18080 (expand_omp_for_generic): Likewise.
18081 (expand_omp_for_static_nochunk): Likewise.
18082 (expand_omp_for_static_chunk): Likewise.
18083 * tree-vect-stmts.c (vect_gen_perm_mask): Use type_for_mode.
18084 * tree-vect-slp.c (vect_transform_slp_perm_load): Likewise.
18085 * tree-vect-loop-manip.c (vect_gen_niters_for_prolog_loop):
18086 Use unsigned_type_for.
18087 (vect_create_cond_for_align_checks): Use signed_type_for.
18088
18089 2012-03-07 Andrey Belevantsev <abel@ispras.ru>
18090
18091 PR rtl-optimization/52203
18092 * sel-sched.c (estimate_insn_cost): New parameter pempty. Adjust
18093 all callers to pass NULL except ...
18094 (reset_sched_cycles_in_current_ebb): ... here, save the value
18095 in new variable 'empty'. Increase issue_rate only for
18096 non-empty insns.
18097
18098 2012-03-07 Ralf Corsépius <ralf.corsepius@rtems.org>
18099
18100 PR target/51417
18101 * Makefile.in: Let install-gcc-ar depend on installdirs,
18102 gcc-ar$(exeext), gcc-nm$(exeext), gcc-ranlib$(exeext).
18103 Don't double canonicalize if cross-compiling.
18104
18105 2012-03-07 Georg-Johann Lay <avr@gjlay.de>
18106
18107 PR target/52506
18108 * gcc/config/avr/avr.c (expand_epilogue): Fix order of restoration
18109 to: RAMPZ, RAMPY, RAMPX, RAMPD.
18110 (expand_prologue): Only clear RAMPZ if it has effect on RAM-read.
18111
18112 2012-03-07 Georg-Johann Lay <avr@gjlay.de>
18113
18114 PR target/52505
18115 * config/avr/avr.c (avr_out_xload): Don't read unintentionally
18116 from RAM.
18117 * config/avr/avr.md (xload_8): Adjust insn length.
18118
18119 2012-03-07 Georg-Johann Lay <avr@gjlay.de>
18120
18121 PR target/52461
18122 * gcc/config/avr/avr.c (avr_out_lpm): Clear RAMPZ after usage
18123 if RAMPZ affects reading from RAM.
18124
18125 2012-03-07 Richard Guenther <rguenther@suse.de>
18126
18127 PR pch/52518
18128 PR pch/38987
18129 * doc/invoke.texi (Precompiled Headers): Remove sentence that
18130 suggests you can include PCHs from inside another header.
18131
18132 2012-03-07 Richard Sandiford <rdsandiford@googlemail.com>
18133
18134 PR middle-end/52515
18135 * rtl.h (pc_rtx, cc0_rtx, ret_rtx, simple_return_rtx): Add GTY markers.
18136
18137 2012-03-07 Kai Tietz <ktietz@redhat.com>
18138
18139 * doc/invoke.texi (fwritable-relocated-rdata): Document
18140 new Cygwin/MinGW target option.
18141 * config/i386/winnt.c (i386_pe_unique_section): Ignore
18142 reloc if flag -fwritable-relocated-rdata is not set.
18143 (i386_pe_section_type_flags): Likewise.
18144 * config/i386/cygming.opt (fwritable-relocated-rdata):
18145 Add new flag variable flag_writable_rel_rdata.
18146
18147 2012-03-07 Richard Guenther <rguenther@suse.de>
18148
18149 * tree-ssa-math-opts.c (convert_mult_to_widen): Check actual
18150 precision against gimple constraints.
18151
18152 2012-03-06 Richard Sandiford <rdsandiford@googlemail.com>
18153
18154 PR middle-end/52372
18155 * rtl.h (pc_rtx, ret_rtx, simple_return_rtx, cc0_rtx): Redefine as
18156 variables.
18157 (GR_PC, GR_CC0, GR_RETURN, GR_SIMPLE_RETURN): Delete.
18158 * emit-rtl.c (pc_rtx, ret_rtx, simple_return_rtx, cc0_rtx): New
18159 variables.
18160 (init_emit_regs): Move associated initialization to...
18161 (init_emit_once): ...here.
18162
18163 2012-03-06 Richard Henderson <rth@redhat.com>
18164
18165 * config/m68k/m68k.h (ISA_HAS_TAS): New.
18166 * config/m68k/sync.md (atomic_test_and_set): Use it.
18167 (atomic_test_and_set_1): Likewise.
18168
18169 2012-03-06 Michael Meissner <meissner@linux.vnet.ibm.com>
18170
18171 PR target/50310
18172 * config/rs6000/vector.md (vector_uneq<mode>): Add support for
18173 UNEQ, LTGT, ORDERED, and UNORDERED IEEE vector comparisons.
18174 (vector_ltgt<mode>): Likewise.
18175 (vector_ordered<mode>): Likewise.
18176 (vector_unordered<mode>): Likewise.
18177 * config/rs6000/rs6000.c (rs6000_emit_vector_compare_inner): Likewise.
18178
18179 2012-03-06 Aldy Hernandez <aldyh@redhat.com>
18180
18181 * trans-mem.c: New typedef for tm_region_p.
18182 Define vector types for tm_region_p.
18183 (tm_region_init): Replace region_worklist to a vector called
18184 bb_regions.
18185
18186 2012-03-06 Richard Guenther <rguenther@suse.de>
18187
18188 * fold-const.c (build_fold_addr_expr_with_type_loc): Fold
18189 MEM_REF with constant pointer operand.
18190
18191 2012-03-06 Richard Guenther <rguenther@suse.de>
18192
18193 PR middle-end/52493
18194 * tree-ssa-alias.c (ptr_derefs_may_alias_p): Robustify.
18195
18196 2012-03-06 Tristan Gingold <gingold@adacore.com>
18197
18198 * config/vms/vms-c.c (vms_pragma_nomember_alignment): Handle octaword.
18199 (external_model_kind): Improve documentation.
18200 (vms_pragma_extern_model): Handle relaxed_redef.
18201 (vms_c_register_pragma): Allow expansion for nomember_alignment.
18202
18203 2012-03-06 Georg-Johann Lay <avr@gjlay.de>
18204
18205 * doc/invoke.texi (AVR Options): -mmcu=: Document the XMEGA cores.
18206 Explain RAMPD, RAMPX, RAMPDY, RAMPZ usage by avr-gcc.
18207 Some more notes on EIND usage and reorder EIND subsection.
18208
18209 2012-03-06 Tristan Gingold <gingold@adacore.com>
18210
18211 * config/vms/vms.c (VMS_CRTL_LDBL): Rename from VMS_CRTL_PRNTF.
18212 * config/vms/vms-crtlmap.map: Rename PRNTF to LDBL.
18213
18214 2012-03-06 Tristan Gingold <gingold@adacore.com>
18215
18216 * config/vms/t-vmsnative (version): Define.
18217 * config/vms/t-vms (STMP_FIXPROTO, STMP_FIXINC, version): Remove.
18218
18219 2012-03-06 Andrey Belevantsev <abel@ispras.ru>
18220
18221 PR rtl-optimization/52250
18222 * sel-sched-ir.c (maybe_tidy_empty_bb): Try harder to find a bb
18223 to put note list into. Unconditionally call move_bb_info.
18224 (move_bb_info): Do not assert the blocks being in the same region,
18225 just drop the note list if they are not.
18226
18227 2012-03-06 Oleg Endo <olegendo@gcc.gnu.org>
18228
18229 PR target/51244
18230 * config/sh/sh.c (sh_expand_t_scc): Remove SH2A special case
18231 and use unified expansion logic.
18232 * config/sh/sh.md (xorsi3_movrt): Rename to movrt. Move
18233 closer to the existing movt insn.
18234 (negc): Rename insn to *negc. Add new expander.
18235 (movnegt): Use xor pattern for T bit negation. Reserve helper
18236 constant for negc pattern.
18237 (*movnegt): New insn and splitter.
18238
18239 2012-03-05 Bernd Schmidt <bernds@codesourcery.com>
18240
18241 * c-typeck.c (pointer_diff): Check for POINTER_PLUS_EXPR, not
18242 PLUS_EXPR.
18243
18244 2012-03-05 Richard Henderson <rth@redhat.com>
18245
18246 * genemit.c (main): Include "target.h" in insn-emit.c.
18247 * Makefile.in (insn-emit.o): Depend on TARGET_H.
18248 * config/sh/sync.md (atomic_test_and_set): Reference
18249 targetm.atomic_test_and_set_trueval instead of
18250 TARGET_ATOMIC_TEST_AND_SET_TRUEVAL.
18251
18252 2012-03-05 Joern Rennecke <joern.rennecke@embecosm.com>
18253
18254 * config/epiphany/epiphany.c (epiphany_function_value_regno_p):
18255 Make static.
18256
18257 2012-03-05 Steven Bosscher <steven@gcc.gnu.org>
18258
18259 * langhooks.c (add_builtin_type): New function.
18260 * langhooks.h (add_builtin_type): Export it.
18261 * config/mep/mep.c (mep_init_builtins): Use it.
18262 * config/rs6000/rs6000.c (rs6000_init_builtins): Use it.
18263
18264 2012-03-05 Jakub Jelinek <jakub@redhat.com>
18265
18266 PR debug/51902
18267 * tree.h (BLOCK_SAME_RANGE): Define.
18268 * function.c (block_fragments_nreverse): Clear BLOCK_SAME_RANGE
18269 if BLOCK_FRAGMENT_CHAIN is non-NULL, but has it cleared.
18270 Also clear BLOCK_SAME_RANGE if fragment chain's supercontext fragment
18271 isn't equal to supercontext fragment's fragment chain.
18272 Adjust BLOCK_SUPERCONTEXT to point to supercontext fragment's
18273 fragment origin.
18274 (blocks_nreverse_all): Likewise.
18275 (reorder_blocks_1): Compute BLOCK_SAME_RANGE bits. Set
18276 BLOCK_SUPERCONTEXT to supercontext fragment instead of
18277 supercontext fragment's fragment origin.
18278 * dwarf2out.c (add_high_low_attributes): If stmt has the same
18279 range as its parent (or parents thereof etc.), use the parent's
18280 DW_AT_ranges value instead of creating a new .debug_ranges range.
18281
18282 2012-03-05 Richard Henderson <rth@redhat.com>
18283
18284 PR tree-opt/52242
18285 Revert: 2011-11-26 Richard Henderson <rth@redhat.com>
18286 * omp-low.c (expand_omp_atomic): Assume anything aligned to
18287 BIGGEST_ALIGNMENT is aligned.
18288
18289 2012-03-05 Richard Henderson <rth@redhat.com>
18290
18291 * config/sh/sh.h (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): Move...
18292 * config/sh/sh.c: ... here.
18293
18294 2012-03-05 Richard Henderson <rth@redhat.com>
18295
18296 PR target/52481
18297 * config/m68k/sync.md (atomic_test_and_set): Use expand_simple_unop
18298 instead of calling negqi2 directly.
18299
18300 2012-03-05 Aldy Hernandez <aldyh@redhat.com>
18301
18302 PR middle-end/52463
18303 * trans-mem.c (tm_region_init): Use last_basic_block.
18304
18305 2012-03-05 Oleg Endo <olegendo@gcc.gnu.org>
18306
18307 * config/sh/sh.h (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New hook.
18308 * config/sh/sync.md (atomic_test_and_set): New expander.
18309 (tasb, atomic_test_and_set_soft): New insns.
18310 * config/sh/sh.opt (menable-tas): New option.
18311 * doc/invoke.texi (SH Options): Document it.
18312
18313 2012-03-05 Richard Guenther <rguenther@suse.de>
18314
18315 * cfgloop.c (verify_loop_structure): Verify dominators before
18316 using them.
18317 * graphite-clast-to-gimple.c (graphite_verify): Do not verify
18318 dominators from here.
18319 * graphite-scop-detection.c (create_sese_edges): Likewise.
18320 * loop-doloop.c (doloop_optimize_loops): Likewise.
18321 * loop-init.c (loop_optimizer_init): Likewise.
18322 * loop-unroll.c (unroll_and_peel_loops): Likewise.
18323 * loop-unswitch.c (unswitch_loops): Likewise.
18324 * tree-ssa-loop-manip.c (tree_transform_and_unroll_loop): Likewise.
18325 * tree-parloops.c (parallelize_loops): Likewise. Verify
18326 only when checking is enabled.
18327 * tree-loop-distribution.c (tree_loop_distribution): Likewise.
18328
18329 2012-03-05 Bernd Schmidt <bernds@codesourcery.com>
18330
18331 * genautomata.c (parse_automata_opt): New static function.
18332 (initiate_automaton_gen): Remove all option handling code. Remove
18333 argc argument. All callers changed.
18334 (main): Call init_rtx_reader_args_cb with the new function as argument.
18335
18336 2012-03-05 Richard Guenther <rguenther@suse.de>
18337
18338 * cfgexpand.c (gimple_expand_cfg): Free dominator info.
18339 * tree-if-conv.c (combine_blocks): Free post-dominator info
18340 after breaking it.
18341 * tree-parloops.c (create_parallel_loop): Free and re-compute
18342 dominator info after breaking it.
18343
18344 2012-03-05 Richard Guenther <rguenther@suse.de>
18345
18346 PR middle-end/52353
18347 * optabs.h (trapv_unoptab_p): New function.
18348 (trapv_binoptab_p): Likewise.
18349 * optabs.c (expand_binop): Use emit_libcall_block_1 with
18350 a proper equiv_may_trap argument.
18351 (expand_unop): Likewise.
18352 (emit_libcall_block_1): Take extra argument whether the
18353 instruction may trap. Renamed from ...
18354 (emit_libcall_block): ... this. New wrapper.
18355
18356 2012-03-05 Jakub Jelinek <jakub@redhat.com>
18357
18358 PR tree-optimization/51721
18359 * tree-vrp.c (register_edge_assert_for_2): If comparing
18360 lhs of right shift by constant with an integer constant,
18361 add ASSERT_EXPRs for the rhs1 of the right shift.
18362
18363 * cfgrtl.c (cfg_layout_merge_blocks): Cleanup.
18364
18365 2012-03-05 Richard Guenther <rguenther@suse.de>
18366
18367 * tree.c (integer_zerop): Handle VECTOR_CSTs.
18368 (integer_onep): Likewise.
18369 (integer_all_onesp): Likewise.
18370
18371 2012-03-05 Georg-Johann Lay <avr@gjlay.de>
18372
18373 * config/avr/avr.md (*umaddqihi4.2): New insn-and-split.
18374
18375 2012-03-04 H.J. Lu <hongjiu.lu@intel.com>
18376
18377 * config/i386/i386.c (pro_epilogue_adjust_stack): Check Pmode
18378 instead of TARGET_64BIT.
18379
18380 2012-03-04 H.J. Lu <hongjiu.lu@intel.com>
18381
18382 * config/i386/i386.c (ix86_expand_prologue): Check Pmode to set
18383 adjust_stack_insn.
18384
18385 2012-03-04 H.J. Lu <hongjiu.lu@intel.com>
18386
18387 * config/i386/i386.c (ix86_print_operand_address): Only handle
18388 zero-extended DImode addresses.
18389
18390 2012-03-04 Uros Bizjak <ubizjak@gmail.com>
18391
18392 * config/i386/i386.c (ix86_print_operand) <case '+'>: Declare
18393 taken and cputaken as bool.
18394
18395 2012-03-04 Uros Bizjak <ubizjak@gmail.com>
18396
18397 * config/i386/constraints.md (Ya): New internal constraint.
18398 * config/i386/i386.md (zero_extendsidi2): Remove expansion.
18399 (*zero_extendsidi2_rex64): Add x,x alternative.
18400 (*zero_extendsidi2): Ditto. Add o,0 alternative.
18401 Remove flags reg clobber. Adjust corresponding splits.
18402 (zero_extend<mode>si2): Macroize expander from zero_extendhisi2 and
18403 zero_extendqisi2 expanders using SWI12 mode iterator.
18404 (zero_extend<mode>si2_and): Macroize insn from
18405 zero_extendhisi2_and and zero_extendqisi2_and. Merge corresponding
18406 splitters.
18407 (*zero_extend<mode>si2): Macroize insn from
18408 *zero_extendhisi2_movzbl and *zero_extendqisi2_movzbl.
18409 (*zero_extend*2_movzbl_and): Remove insn patterns.
18410 (zero_extendqihi2_and): Merge corresponding splitter.
18411 (*zero_extendqihi2): Rename from *zero_extendqihi2_movzbl.
18412 (*zero_extend*2_movzbl_and): Remove insn patterns.
18413 (*anddi_1): Split TYPE_IMOVX instructions.
18414 (*andsi_1): Use Ya for alternative 2. Split TYPE_IMOVX instructions.
18415 (*andhi_1): Ditto.
18416 (and->zext splitter): Add splitter pattern.
18417 (zero extend with andsi3 splitter): Adjust zero_extend pattern.
18418
18419 2012-03-04 Sandra Loosemore <sandra@codesourcery.com>
18420
18421 * doc/invoke.texi (C++ Dialect Options): Minor copy-edits to
18422 x86-specific text.
18423 (Debugging Options): Likewise.
18424 (Optimize Options): Likewise.
18425 (i386 and x86-64 Options): Discuss -march before -mtune, consistently
18426 with other architectures. Use official processor names with correct
18427 spelling/capitalization. Fix formatting and grammar issues.
18428 (i386 and x86-64 Windows Options): Similar cleanup here.
18429
18430 2012-03-03 Kaz Kojima <kkojima@gcc.gnu.org>
18431
18432 * config/sh/sh.md (abssi2): Add TARGET_SH1 condition.
18433
18434 2012-03-03 Kaz Kojima <kkojima@gcc.gnu.org>
18435
18436 * config/sh/sh.c (sh_dwarf_register_span): Don't apply
18437 DBX_REGISTER_NUMBER.
18438
18439 2012-03-03 Kaz Kojima <kkojima@gcc.gnu.org>
18440
18441 * config/sh/sh.c (shiftcosts): Return MAX_COST when the first
18442 operand is CONST_INT. Take COSTS_N_INSNS into account.
18443 (sh_rtx_costs): Don't apply COSTS_N_INSNS to the return value
18444 of shiftcosts.
18445
18446 2012-03-02 Richard Henderson <rth@redhat.com>
18447
18448 * optabs.c (expand_atomic_test_and_set): Honor
18449 atomic_test_and_set_trueval even when atomic_test_and_set
18450 optab is not in use.
18451
18452 2012-03-02 Kaz Kojima <kkojima@gcc.gnu.org>
18453
18454 PR target/48596
18455 PR target/48806
18456 * config/sh/sh.c (sh_register_move_cost): Increase cost between
18457 GENERAL_REGS and FP_REGS for SImode.
18458
18459 2012-03-02 Oleg Endo <olegendo@gcc.gnu.org>
18460
18461 PR target/49486
18462 * config/sh/sh.md (negdi2): Add TARGET_SH1 condition.
18463 (absdi2): New expander.
18464 (*absdi2, *negabsdi2, negdi_cond): New insns and splits.
18465
18466 2012-03-02 Oleg Endo <olegendo@gcc.gnu.org>
18467
18468 * config/sh/sync.md (atomic_exchange<mode>): New expander.
18469 (atomic_exchange<mode>_soft): New insn.
18470
18471 2012-03-02 Oleg Endo <olegendo@gcc.gnu.org>
18472
18473 * config/sh/sync.md: Update copyright notice dates.
18474 (atomic_compare_and_swap<mode>): Use SImode for return value instead
18475 of QImode.
18476 (atomic_compare_and_swap<mode>_soft): Likewise.
18477
18478 2012-03-02 Oleg Endo <olegendo@gcc.gnu.org>
18479
18480 PR target/31640
18481 * config/sh/sh.h (LOOP_ALIGN): Move logic to sh_loop_align.
18482 * config/sh/sh.c: Update copyright notice dates.
18483 (sh_loop_align): Add logic from LOOP_ALIGN. Don't disable loop
18484 alignment for TARGET_HARD_SH4.
18485 (sh_option_override): Reduce default function alignment. Set
18486 loop alignment to 4 bytes when not optimizing for size.
18487
18488 2012-03-02 Maxim Kuvyrkov <maxim@codesourcery.com>
18489
18490 PR middle-end/50335
18491 * doc/invoke.texi (floop-flatten): Remove.
18492 * toplev.c (process_options): Remove references to flag_loop_flatten.
18493 * tree-ssa-loop.c (gate_graphite_transform): Same.
18494 * common.opt (floop-flatten): Obsolete.
18495 * graphite-poly.c (apply_poly_transforms): Remove reference to
18496 flag_loop_flatten.
18497 * Makefile.in (graphite-flattening.o): Remove.
18498 * graphite-flattening.c: Remove.
18499
18500 2012-03-02 Uros Bizjak <ubizjak@gmail.com>
18501
18502 * compare-elim.c (find_comparisons_in_bb): Eliminate only compares
18503 having mode compatible with the mode of previous compare. Substitute
18504 compare mode of previous compare with the mode, compatible
18505 with eliminated and previous compare.
18506
18507 2012-03-02 Peter Bergner <bergner@vnet.ibm.com>
18508
18509 * config/rs6000/dfp.md (floatdidd2): New define_insn.
18510
18511 2012-03-02 Uros Bizjak <ubizjak@gmail.com>
18512
18513 * config/i386/i386.c (ix86_cc_modes_compatible): Declare CCZmode
18514 compatible with CCGOCmode and CCGCmode.
18515
18516 2012-03-02 Peter Bergner <bergner@vnet.ibm.com>
18517
18518 * config/rs6000/vsx.md (vsx_set_<mode>): Reorder operands.
18519
18520 2012-03-02 Ulrich Weigand <ulrich.weigand@linaro.org>
18521
18522 * config/arm/arm.c (arm_sat_operator_match): New function.
18523 * config/arm/arm-protos.h (arm_sat_operator_match): Add prototype.
18524 * config/arm/arm.md ("insn" attribute): Add "sat" value.
18525 ("SAT", "SATrev"): New code iterators.
18526 ("SATlo", "SAThi"): New code iterator attributes.
18527 ("*satsi_<SAT:code>"): New pattern.
18528 ("*satsi_<SAT:code>_shift"): Likewise.
18529 * config/arm/arm-fixed.md ("arm_ssatsihi_shift"): Add "insn"
18530 and "shift" attributes.
18531 ("arm_usatsihi"): Add "insn" attribute.
18532 * config/arm/predicates.md (sat_shift_operator): Allow multiplication
18533 by powers of two. Do not allow shift by 32.
18534
18535 2012-03-02 Uros Bizjak <ubizjak@gmail.com>
18536
18537 PR target/46716
18538 * config/i386/i386.c (construct_container): Use gen_reg_or_parallel
18539 to pass the argument in the register of "natural" mode.
18540
18541 2012-03-02 Richard Guenther <rguenther@suse.de>
18542
18543 PR tree-optimization/52406
18544 * tree-data-ref.h: Update documentation about DR_BASE_OBJECT.
18545 (struct indices): Add unconstrained_base member.
18546 (struct dr_alias): Remove unused vops member.
18547 (DR_UNCONSTRAINED_BASE): New define.
18548 * tree-data-ref.c (dr_analyze_indices): For COMPONENT_REFs
18549 add indices to allow their disambiguation. Make DR_BASE_OBJECT
18550 be an artificial access that covers the whole indexed object,
18551 or mark it with DR_UNCONSTRAINED_BASE if we cannot do so. Canonicalize
18552 plain decl base-objects to their MEM_REF variant.
18553 (dr_may_alias_p): When the base-object of either data reference
18554 has unknown size use only points-to information.
18555 (compute_affine_dependence): Make dumps easier to read and
18556 more verbose.
18557 * tree-vect-data-ref.c (vector_alignment_reachable_p): Use
18558 DR_REF when looking for packed references.
18559 (vect_supportable_dr_alignment): Likewise.
18560
18561 2012-03-02 Greta Yorsh <Greta.Yorsh@arm.com>
18562
18563 * config/arm/arm-ldmstm.ml (write_ldm_commutative_peephole):
18564 Improve conditions for peepholes of loads followed by commutative
18565 operators.
18566 * config/arm/ldmstm.md: Regenerated.
18567
18568 2012-03-02 Richard Guenther <rguenther@suse.de>
18569
18570 * BASE-VER: Set to 4.8.0.
18571
18572 2012-03-01 Richard Earnshaw <rearnsha@arm.com>
18573
18574 * config.gcc (obsolete): Add all ARM targets using the FPA.
18575 (with_fpu): Obsolete selection of the FPA or Maverick on ARM.
18576 * doc/install.texi: Avoid references to obsolete ARM ports.
18577
18578 2012-03-01 Joern Rennecke <joern.rennecke@embecosm.com>
18579
18580 * config/epiphany/epiphany.md (movmisalign<mode>): New patterns.
18581
18582 2012-03-01 Jeremy Bennett <jeremy.bennett@embecosm.com>
18583 Joern Rennecke <joern.rennecke@embecosm.com>
18584
18585 * doc/extend.texi: Expand and update information on interrupt
18586 attribute for Epiphany.
18587
18588 2012-03-01 Oleg Endo <olegendo@gcc.gnu.org>
18589
18590 * config/sh/sh-protos.h: Update copyright notice dates.
18591 * config/sh/sh.h: Likewise.
18592 * config/sh/sh.md: Likewise.
18593 * config/sh/constraints.md: Likewise.
18594 * config/sh/predicates.md: Likewise.
18595
18596 2012-03-01 Oleg Endo <olegendo@gcc.gnu.org>
18597
18598 * config/sh/sh-protos.h (tertiary_reload_operand): Remove dead function.
18599 * config/sh/sh.c (tertiary_reload_operand): Likewise.
18600
18601 2012-03-01 Oleg Endo <olegendo@gcc.gnu.org>
18602
18603 * config/sh/constraints.md: Fix comment typo.
18604
18605 2012-03-01 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
18606
18607 PR target/52408
18608 * config/pa/pa.md (zvdep_imm32): Change type of variable x from int to
18609 unsigned HOST_WIDE_INT.
18610 (zvdep_imm64): Likewise.
18611 (vdepi_ior): Change type of variable x from int to HOST_WIDE_INT.
18612 (vdepi_and): Likewise.
18613 Likewise for unamed 64-bit patterns.
18614 * config/pa/predicates.md (lhs_lshift_cint_operand): Update comment.
18615
18616 2012-03-01 Alexandre Oliva <aoliva@redhat.com>
18617
18618 PR debug/52001
18619 PR rtl-optimization/52417
18620 * cselib.c (cselib_any_perm_equivs): New variable.
18621 (cselib_reset_table): Check that it's not set when not
18622 preserving constants.
18623 (cselib_add_permanent_equiv): Set it.
18624 (cselib_have_permanent_equivalences): New.
18625 (cselib_init, cselib_finish): Reset it.
18626 * cselib.h (cselib_have_permanent_equivalences): Declare.
18627 * alias.c (get_addr): Restore earlier behavior when there
18628 aren't permanent equivalences.
18629
18630 2012-03-01 Steven Bosscher <steven@gcc.gnu.org>
18631
18632 * config/mn10300/mn10300-modes.def: Fix copyright notice.
18633 * config/v850/v850-modes.def: Fix copyright notice.
18634
18635 2012-03-01 Georg-Johann Lay <avr@gjlay.de>
18636
18637 * doc/extend.texi (AVR Built-in Functions): Document
18638 __builtin_avr_flash_segment.
18639
18640 * config/avr/builtins.def (__builtin_avr_flash_segment): New entry.
18641 * config/avr/avr.md (flash_segment, flash_segment1): New expanders.
18642 (*split.flash_segment): New insn-and-split.
18643 * config/avr/avr.c (avr_init_builtins): Add local variables:
18644 const_memx_void_node, const_memx_ptr_type_node,
18645 char_ftype_const_memx_ptr.
18646
18647 2012-03-01 Jakub Jelinek <jakub@redhat.com>
18648
18649 PR tree-optimization/52445
18650 * tree-ssa-phiopt.c (struct name_to_bb): Remove ssa_name field,
18651 add ssa_name_ver, offset and size fields and change store field
18652 to bool.
18653 (name_to_bb_hash, name_to_bb_eq): Adjust for the above changes.
18654 (add_or_mark_expr): Likewise. Only consider previous stores
18655 with the same size and offset.
18656 (nt_init_block): Only look at gimple_assign_single_p stmts,
18657 doesn't look at rhs2.
18658
18659 2012-03-01 Richard Guenther <rguenther@suse.de>
18660
18661 PR middle-end/52443
18662 * tree-cfg.c (verify_gimple_assign_unary): Allow any
18663 conversions from integral types to pointer types.
18664
18665 2012-03-01 Georg-Johann Lay <avr@gjlay.de>
18666
18667 * config/avr/avr-c.c (avr_cpu_cpp_builtins): Restore built-in
18668 defines for __UINT24_MAX__, __INT24_MAX__, __INT24_MIN__
18669 unintentionally removed in r184616.
18670
18671 2012-03-01 Venkataramanan Kumar <venkataramanan.kumar@amd.com>
18672
18673 * doc/invoke.texi: Document AMD bdver2 and remove mentioning
18674 3DNow from bdver1.
18675
18676 2012-02-29 Jakub Jelinek <jakub@redhat.com>
18677 Uros Bizjak <ubizjak@gmail.com>
18678
18679 PR target/52437
18680 * config/i386/sse.md (vec_set<mode>_0): Swap "*r" and "fF"
18681 alternatives, add "e" constraint to the new last alternative
18682 and ! to last 3 alternatives.
18683
18684 2012-02-29 Eric Botcazou <ebotcazou@adacore.com>
18685
18686 * dwarf2out.c (modified_type_die): Set DW_AT_GNAT_descriptive_type and
18687 DW_AT_artificial attributes at the end of the processing.
18688 (gen_array_type_die): Likewise.
18689 (gen_enumeration_type_die): Likewise.
18690 (gen_struct_or_union_type_die): Likewise.
18691 (add_gnat_descriptive_type_attribute): Do not suppress debug info for
18692 the parent type.
18693
18694 2012-02-29 Jakub Jelinek <jakub@redhat.com>
18695
18696 PR middle-end/52419
18697 * expr.c (expand_assignment): If doing misaligned store that doesn't
18698 cover all mode bits, perform a RMW cycle.
18699
18700 PR tree-optimization/52429
18701 * tree-parloops.c (separate_decls_in_region_debug): Return early
18702 if var is LABEL_DECL.
18703
18704 2012-02-29 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
18705
18706 PR tree-optimization/52424
18707 * tree-ssa-dom.c (dom_opt_leave_block): Push a marker before
18708 calling dom_thread_across_edge.
18709
18710 2012-02-29 Georg-Johann Lay <avr@gjlay.de>
18711
18712 * config/avr/avr.c: Move definition of TARGET macros to end of file.
18713
18714 2012-02-29 Georg-Johann Lay <avr@gjlay.de>
18715
18716 * config/avr/avr-protos.h (avr_output_bld): Remove unused prototype.
18717 * config/avr/avr.c (avr_output_bld): Remove unused function.
18718 (avr_out_sbxx_branch): Use "%T" to print bit position.
18719
18720 2012-02-29 Georg-Johann Lay <avr@gjlay.de>
18721
18722 * config/avr/avr.md: Untabify.
18723
18724 2012-02-29 Georg-Johann Lay <avr@gjlay.de>
18725
18726 * config/avr/avr.md (eqne): New code iterator.
18727 (*dec-and-branchsi): Use it in text peephole's condition.
18728 (*dec-and-branchhi): Ditto.
18729 (*dec-and-branchqi): Ditto.
18730
18731 2012-02-29 Georg-Johann Lay <avr@gjlay.de>
18732
18733 PR target/49939
18734 * config/avr/avr.h (ASM_SPEC): Add -mno-skip-bug if we know that
18735 the device does not have the skip-bug.
18736
18737 2012-02-29 Oleg Endo <olegendo@gcc.gnu.org>
18738
18739 * doc/invoke.texi (-msoft-atomic): Add more detailed description.
18740 (-mbranch-cost, -mcbranchdi -mcmpeqdi -mfused-madd
18741 -mpretend-cmove): New.
18742
18743 2012-02-29 Jakub Jelinek <jakub@redhat.com>
18744
18745 PR bootstrap/52397
18746 * df.h (struct df_d): Adjust comment that hard_regs_live_count
18747 doesn't count DEBUG_INSN refs.
18748 * df-scan.c (df_ref_create_structure): Don't set DF_HARD_REG_LIVE
18749 for DEBUG_INSN refs.
18750
18751 2012-02-28 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
18752
18753 Partially revert:
18754
18755 2012-02-20 Richard Guenther <rguenther@suse.de>
18756 PR tree-optimization/52298
18757 * tree-vect-stmts.c (vectorizable_load): Properly use
18758 STMT_VINFO_DR_STEP instead of DR_STEP when vectorizing outer loops.
18759
18760 2012-02-28 Aldy Hernandez <aldyh@redhat.com>
18761
18762 PR middle-end/51752
18763 * gimple.h (gimple_in_transaction): New.
18764 (gimple_set_in_transaction): New.
18765 (struct gimple_statement_base): Add in_transaction field.
18766 * tree-ssa-loop-im.c: (movement_possibility): Restrict movement of
18767 transaction loads.
18768 (tree_ssa_lim_initialize): Compute transaction bits.
18769 * tree.h (compute_transaction_bits): Protoize.
18770 * trans-mem.c (tm_region_init): Use the heap to store BB
18771 auxilliary data.
18772 (compute_transaction_bits): New.
18773
18774 2012-02-28 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
18775
18776 * gcc.c (display_help): Document --help=common and sort entries
18777 alphabetically.
18778
18779 2012-02-28 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
18780
18781 * doc/install.texi: Document check-$LANG specific shortcuts
18782
18783 2012-02-28 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
18784
18785 PR target/51534
18786 * config/arm/arm.c (neon_builtin_data): Add entries for vcgeu
18787 and vcgtu.
18788 * config/arm/arm_neon.h: Regenerate.
18789 * config/arm/neon.md (unspec): Add UNSPEC_VCGEU, and UNSPEC_VCGTU.
18790 (neon_vcgeu): New insn.
18791 (neon_vcgtu): Likewise.
18792 * config/arm/neon.ml (s_8_32, u_8_32): New lists.
18793 (ops): Unsigned comparison intrinsics call a different builtin.
18794
18795 2012-02-28 Richard Guenther <rguenther@suse.de>
18796
18797 PR target/52407
18798 * config/i386/i386.c (ix86_expand_vector_set): Fix element
18799 ordering for the VEC_CONCAT for two element vectors for
18800 V2SFmode, V2SImode and V2DImode.
18801
18802 2012-02-28 Richard Earnshaw <rearnsha@arm.com>
18803
18804 PR target/49448
18805 * config.gcc (arm*-*-linux*): Use an unambiguous pattern for
18806 detecting big-endian triplets.
18807
18808 2012-02-28 Richard Earnshaw <rearnsha@arm.com>
18809
18810 * arm.c (aapcs_vfp_is_call_or_return_candidate): Only use the machine
18811 mode if there is no type information available.
18812
18813 2012-02-28 Thomas Koenig <tkoenig@gcc.gnu.org>
18814
18815 PR tree-optimization/53207
18816 * doc/invoke.texi: Document as experimental and relying on graphite.
18817
18818 2012-02-28 Georg-Johann Lay <avr@gjlay.de>
18819
18820 * config/avr/avr-devices.c (avr_mcu_type): Adjust NULL part
18821 of initializer to changes from r184614.
18822
18823 2012-02-28 Richard Guenther <rguenther@suse.de>
18824
18825 PR tree-optimization/52395
18826 * tree-sra.c (build_ref_for_offset): Also look at the base
18827 TYPE_ALIGN when figuring out the alignment of the replacement.
18828
18829 2012-02-28 Richard Guenther <rguenther@suse.de>
18830
18831 PR tree-optimization/52402
18832 * ipa-prop.c (ipa_modify_call_arguments): Properly use
18833 mis-aligned types when creating the accesses at the call site.
18834
18835 2012-02-28 Georg-Johann Lay <avr@gjlay.de>
18836
18837 * config/avr/builtins.def: New file.
18838 * config/avr/t-avr (avr.o, avr-c.o): Depend on it.
18839 * config/avr/avr.c (enum avr_builtin_id): Use it.
18840 (avr_init_builtins): Use it. And use avr_bdesc.
18841 (bdesc_1arg): Remove.
18842 (bdesc_2arg): Remove.
18843 (bdesc_3arg): Remove.
18844 (struct avr_builtin_description): Add field n_args.
18845 (avr_bdesc): New static variable using builtins.def.
18846 (avr_expand_builtin): Use it.
18847 Don't call avr_expand_delay_cycles if op0 is not CONST_INT.
18848 (avr_fold_builtin): Fold AVR_BUILTIN_SWAP.
18849 Don't fold AVR_BUILTIN_INSERT_BITS if arg0 is not INTEGER_CST.
18850
18851 2012-02-28 Georg-Johann Lay <avr@gjlay.de>
18852
18853 PR target/52148
18854 * config/avr/avr.md (movmem_<mode>): Replace match_operand that
18855 match only one single hard register with respective hard reg rtx.
18856 (movmemx_<mode>): Ditto.
18857 * config/avr/avr.c (avr_emit_movmemhi): Adapt expanding to new
18858 insn anatomy of movmem[x]_<mode>.
18859 (avr_out_movmem): Same for printing assembler and operand usage.
18860
18861 2012-02-28 Georg-Johann Lay <avr@gjlay.de>
18862
18863 PR target/49868
18864 PR target/52261
18865 * doc/extend.texi (AVR Named Address Spaces): No more try to fix
18866 address spaces located outside of device flash.
18867
18868 * config/avr/avr.h (base_arch_s): Remove field n_segments.
18869 (mcu_type_s): Add field n_flash.
18870 * config/avr/avr-devices.c (avr_arch_types): Remove .n_segments.
18871 Set .have_elpm and .have_elpmx to 1 for avrxmega4 and avrxmega5.
18872 (AVR_MCU): Add N_FLASH argument.
18873 * config/avr/avr-mcus.def (AVR_MCU): Add initializer for .n_flash.
18874 * config/avr/avr-c.c (avr_cpu_cpp_builtins): Only define built-in
18875 macro __FLASH<n> if that address space makes sense for the device.
18876 * config/avr/avr.c (avr_out_lpm): Don't try to fix address spaces
18877 outside of target flash.
18878 (avr_asm_named_section): Ditto.
18879 (avr_asm_select_section): Ditto.
18880 (avr_addr_space_convert): Ditto.
18881 (avr_emit_movmemhi): Ditto.
18882 (avr_nonconst_pointer_addrspace, avr_pgm_check_var_decl): Error if
18883 address space is outside of device flash.
18884 (avr_insert_attributes): Ditto.
18885 (avr_xload_libgcc_p): Use avr_current_device->n_flash instead of
18886 avr_current_arch->n_segments.
18887
18888 2012-02-27 H.J. Lu <hongjiu.lu@intel.com>
18889
18890 PR target/52352
18891 * config/i386/i386.md (*movabs<mode>_1): Enable only for TARGET_LP64.
18892 (*movabs<mode>_2): Likewise.
18893
18894 2012-02-27 Jakub Jelinek <jakub@redhat.com>
18895
18896 PR target/52375
18897 * config/arm/neon.md (vashr<mode>3, vlshr<mode>3): Use
18898 s_register_operand in the test instead of REG_P. Don't call
18899 gen_reg_rtx if it won't be used.
18900
18901 PR tree-optimization/52376
18902 * ipa-split.c (split_function): Ignore CLOBBER stmts.
18903
18904 2012-02-27 Stuart Henderson <shenders@gcc.gnu.org>
18905
18906 * ifcvt.c (noce_get_condition): Check condition variable is not
18907 small_register_classes_for_mode_p before accepting.
18908
18909 2012-02-27 Uros Bizjak <ubizjak@gmail.com>
18910
18911 * config/i386/i386.md (*movabs<mode>_1): Fix operand 1 constraints.
18912
18913 2012-02-27 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
18914
18915 Revert:
18916 2012-01-09 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
18917 * config/arm/arm-cores.def (cortex-a15): Use cortex_a15_tune for
18918 tuning parameters.
18919 * config/arm/arm.c (arm_cortex_a15_tune): New static variable.
18920
18921 2012-02-27 Oleg Endo <olegendo@gcc.gnu.org>
18922
18923 * config/sh/sh.h: Delete dead GO_IF_LEGITIMATE_INDEX macro.
18924
18925 2012-02-26 Oleg Endo <olegendo@gcc.gnu.org>
18926
18927 * config/sh/predicates.md: Remove blank lines.
18928 * config/sh/sh.c: Fix typos in comments.
18929 * config/sh/constraints.md: Likewise.
18930 * config/sh/sh.md: Remove blank lines.
18931 Fix typos in comments. Use ;; as comment characters.
18932
18933 2012-02-26 Walter Lee <walt@tilera.com>
18934
18935 * config/tilegx/tilegx.c (match_pcrel_step2): Fix instruction pattern.
18936 (replace_mov_pcrel_step2): Ditto.
18937
18938 2012-02-25 Alexandre Oliva <aoliva@redhat.com>
18939
18940 PR debug/52001
18941 * alias.c (refs_newer_value_cb, refs_newer_value_p): New.
18942 (get_addr): Walk canonical value's locs. Avoid returning VALUEs
18943 and locs that reference values newer than the non-canonical value
18944 at hand. Return the canonical value as a worst case.
18945 (memrefs_conflict_p): Walk canonical value's locs.
18946
18947 PR debug/52001
18948 * cselib.c (preserve_only_constants): Rename to...
18949 (preserve_constants_and_equivs): ... this. Split out...
18950 (invariant_or_equiv_p): ... this. Preserve plus expressions
18951 of other preserved expressions too.
18952 (cselib_reset_table): Adjust.
18953 * var-tracking.c (reverse_op): Use canonical value to build
18954 reverse operation.
18955
18956 2012-02-23 Kai Tietz <ktietz@redhat.com>
18957
18958 * config/i386/i386.c (ix86_delegitimize_address): Handle
18959 UNSPEC_PCREL plus displacement.
18960
18961 2012-02-24 Georg-Johann Lay <avr@gjlay.de>
18962
18963 PR target/52261
18964 * config/avr/avr.c (avr_out_movhi_mr_r_xmega): Use base
18965 to test for unusedness in st X addressing.
18966
18967 2012-02-24 Richard Guenther <rguenther@suse.de>
18968
18969 PR middle-end/52361
18970 * gimple.c (walk_gimple_op): Use predicates with less redundant tests.
18971 (is_gimple_reg_type): Move inline ...
18972 * gimple.h (is_gimple_reg_type): ... here.
18973
18974 2012-02-24 Richard Guenther <rguenther@suse.de>
18975
18976 PR middle-end/52361
18977 * passes.c (execute_function_todo): When verifying SSA form
18978 verify gimple form first.
18979 * tree-ssa.c (verify_ssa): Do not verify gimple form here.
18980
18981 2012-02-24 Richard Guenther <rguenther@suse.de>
18982
18983 PR middle-end/52355
18984 * fold-const.c (fold_addr_of_array_ref_difference): New function.
18985 (fold_binary_loc): Use it to extend the existing &a[i] - &a[j] folding.
18986
18987 2012-02-13 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
18988
18989 * tree-if-conv (predicate_scalar_phi): Commentary typo fix.
18990
18991 2012-02-23 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
18992
18993 * tree-phinodes.c (make_phi_node): Mark static.
18994 * tree-flow.h (make_phi_node): Remove extern decl.
18995 * doc/gimple.texi (make_phi_node): Remove documentation.
18996
18997 2012-02-23 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
18998
18999 * tree-into-ssa (update_ssa): Avoid trailing whitespace in dump_file.
19000 * tree-ssa-sccvn.c (print_scc): Ditto.
19001
19002 2012-02-23 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
19003
19004 * doc/passes.texi (Full redundancy elimination): Fix typo.
19005
19006 2012-02-23 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
19007
19008 * doc/invoke.texi (-fdse, -fdce): Remove duplicate entries.
19009
19010 2012-02-23 Eric Botcazou <ebotcazou@adacore.com>
19011
19012 PR bootstrap/52287
19013 * haifa-sched.c (rank_for_schedule): Stabilize sort for debug insns.
19014
19015 2012-02-23 Uros Bizjak <ubizjak@gmail.com>
19016
19017 PR c/52290
19018 * c-decl.c (start_function): Exit early if decl1 is not FUNTION_DECL.
19019
19020 2012-02-23 Georg-Johann Lay <avr@gjlay.de>
19021
19022 * config/avr/avr.md (code_stdname): Add ior, xor.
19023 (xior): New code iterator.
19024 (*<code_stdname><mode>qi.byte0): Use xior instead of ior.
19025 (*<code_stdname><mode>qi.byte1-3): Ditto.
19026
19027 2012-02-23 Jakub Jelinek <jakub@redhat.com>
19028
19029 PR tree-optimization/52019
19030 * ipa-split.c (find_return_bb, find_retval, visit_bb): Ignore
19031 CLOBBER stmts.
19032
19033 2012-02-23 Ulrich Weigand <Ulrich.Weigand@de.ibm.com>
19034
19035 * acinclude.m4: Use HAVE_INITFINI_ARRAY_SUPPORT instead of
19036 HAVE_INITFINI_ARRAY to work around namespace pollution in
19037 certain versions of newlib system headers.
19038 * config.in: Regenerate.
19039 * configure: Regenerate.
19040 * config/initfini-array.h: Use HAVE_INITFINI_ARRAY_SUPPORT
19041 instead of HAVE_INITFINI_ARRAY.
19042
19043 2012-02-22 Uros Bizjak <ubizjak@gmail.com>
19044
19045 PR target/52330
19046 * config/i386/i386.c (ix86_print_operand) <case 'H'>: Error out if x
19047 is not offsettable memory reference.
19048
19049 2012-02-22 Georg-Johann Lay <avr@gjlay.de>
19050
19051 PR target/18145
19052 * config/avr/avr.c (avr_asm_output_aligned_decl_common): Skip
19053 setting avr_need_clear_bss_p for __gnu_lto* symbols.
19054
19055 2012-02-22 Georg-Johann Lay <avr@gjlay.de>
19056
19057 * config/avr/avr.h (avr_accumulate_outgoing_args): Return int.
19058 * config/avr/avr.c (avr_accumulate_outgoing_args): Return int.
19059
19060 2012-02-22 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
19061
19062 * configure.ac (LIB_TLS_SPEC): Enforce use of alternate thread
19063 library on Solaris 8 even without TLS support.
19064 * configure: Regenerate.
19065
19066 2012-02-22 Richard Guenther <rguenther@suse.de>
19067
19068 PR middle-end/52329
19069 * gimple-fold.c (fold_stmt_1): Also canonicalize ADDR_EXPRs
19070 for GIMPLE_DEBUG stmts.
19071
19072 2012-02-22 Martin Jambor <mjambor@suse.cz>
19073
19074 PR middle-end/51782
19075 * emit-rtl.c (set_mem_attributes_minus_bitpos): Set address space
19076 according to the base object.
19077
19078 2012-02-22 Georg-Johann Lay <avr@gjlay.de>
19079
19080 PR rtl-optimization/50063
19081 * config/avr/avr.md (movhi_sp_r): Handle -1 (unknown IRQ state)
19082 and 2 (8-bit SP) in operand 2.
19083 * config/avr/avr.c (avr_prologue_setup_frame): Adjust prologue
19084 setup to use movhi_sp_r instead of vanilla move to write SP.
19085 Adjust REG_CFA notes to superseed unspec.
19086 (expand_epilogue): Adjust epilogue setup to use movhi_sp_r instead
19087 of vanilla move.
19088 As function body might contain CLI or SEI: Use irq_state 0 (IRQ
19089 known to be off) only with TARGET_NO_INTERRUPTS. Never use
19090 irq_state 1 (IRQ known to be on) here.
19091
19092 2012-02-21 Bernd Schmidt <bernds@codesourcery.com>
19093
19094 * ira.c (check_allocation): Use REG_WORDS_BIG_ENDIAN, not
19095 WORDS_BIG_ENDIAN.
19096 * ira-color.c (setup_profitable_hard_regs, check_hard_reg_p,
19097 assign_hard_reg): Likewise.
19098
19099 2012-02-21 Georg-Johann Lay <avr@gjlay.de>
19100
19101 * config/avr/avr.md (neghi2): Remove "!d,0" alternative. Tweak "r,0".
19102
19103 2012-02-21 Georg-Johann Lay <avr@gjlay.de>
19104
19105 * config/avr/avr.md
19106 (*dec-and-branchhi!=-1.d.clobber): New text peephole.
19107 (*dec-and-branchhi!=-1.l.clobber): New text peephole.
19108
19109 2012-02-21 Georg-Johann Lay <avr@gjlay.de>
19110
19111 * config/avr/avr-protos.h (avr_accumulate_outgoing_args): Move
19112 prototype from here to...
19113 * config/avr/avr.h: ...here.
19114
19115 2012-02-21 Richard Earnshaw <rearnsha@arm.com>
19116
19117 PR target/52294
19118 * thumb2.md (thumb2_shiftsi3_short): Split register and
19119 immediate shifts. For register shifts tie operands 0 and 1.
19120 (peephole2 for above): Check that register-controlled shifts
19121 have suitably tied operands.
19122
19123 2012-02-21 Quentin Neill <quentin.neill@amd.com>
19124
19125 PR target/52137
19126 * config/i386/bdver1.md (bdver1_call, bdver1_push,
19127 bdver1_pop, bdver1_leave, bdver1_lea, bdver1_imul_DI, bdver1_imul,
19128 bdver1_imul_mem_DI, bdver1_imul_mem, bdver1_idiv, bdver1_idiv_mem,
19129 bdver1_str, bdver1_idirect, bdver1_ivector, bdver1_idirect_loadmov,
19130 bdver1_idirect_load, bdver1_ivector_load, bdver1_idirect_movstore,
19131 bdver1_idirect_both, bdver1_ivector_both, bdver1_idirect_store,
19132 bdver1_ivector_store, bdver1_fldxf, bdver1_fld, bdver1_fstxf,
19133 bdver1_fst, bdver1_fist, bdver1_fmov_bdver1, bdver1_fadd_load,
19134 bdver1_fadd, bdver1_fmul_load, bdver1_fmul, bdver1_fsgn,
19135 bdver1_fdiv_load, bdver1_fdiv, bdver1_fpspc_load, bdver1_fpspc,
19136 bdver1_fcmov_load, bdver1_fcmov, bdver1_fcomi_load,
19137 bdver1_fcomi, bdver1_fcom_load, bdver1_fcom,
19138 bdver1_fxch, bdver1_ssevector_avx128_unaligned_load,
19139 bdver1_ssevector_avx256_unaligned_load,
19140 bdver1_ssevector_sse128_unaligned_load,
19141 bdver1_ssevector_avx128_load, bdver1_ssevector_avx256_load,
19142 bdver1_ssevector_sse128_load, bdver1_ssescalar_movq_load,
19143 bdver1_ssescalar_vmovss_load, bdver1_ssescalar_sse128_load,
19144 bdver1_mmxsse_load, bdver1_sse_store_avx256, bdver1_sse_store,
19145 bdver1_mmxsse_store_short, bdver1_ssevector_avx256,
19146 bdver1_movss_movsd, bdver1_mmxssemov, bdver1_sselog_load_256,
19147 bdver1_sselog_256, bdver1_sselog_load, bdver1_sselog,
19148 bdver1_ssecmp_load, bdver1_ssecmp, bdver1_ssecomi_load,
19149 bdver1_ssecomi, bdver1_vcvtX2Y_avx256_load, bdver1_vcvtX2Y_avx256,
19150 bdver1_ssecvt_cvtss2sd_load, bdver1_ssecvt_cvtss2sd,
19151 bdver1_sseicvt_cvtsi2sd_load, bdver1_sseicvt_cvtsi2sd,
19152 bdver1_ssecvt_cvtpd2ps_load, bdver1_ssecvt_cvtpd2ps,
19153 bdver1_ssecvt_cvtdq2ps_load, bdver1_ssecvt_cvtdq2ps,
19154 bdver1_ssecvt_cvtdq2pd_load, bdver1_ssecvt_cvtdq2pd,
19155 bdver1_ssecvt_cvtps2pd_load, bdver1_ssecvt_cvtps2pd,
19156 bdver1_ssecvt_cvtsX2si_load, bdver1_ssecvt_cvtsX2si,
19157 bdver1_ssecvt_cvtpd2pi_load, bdver1_ssecvt_cvtpd2pi,
19158 bdver1_ssecvt_cvtpd2dq_load, bdver1_ssecvt_cvtpd2dq,
19159 bdver1_ssecvt_cvtps2pi_load, bdver1_ssecvt_cvtps2pi,
19160 bdver1_ssemuladd_load_256, bdver1_ssemuladd_256,
19161 bdver1_ssemuladd_load, bdver1_ssemuladd, bdver1_sseimul_load,
19162 bdver1_sseimul, bdver1_sseiadd_load, bdver1_sseiadd,
19163 bdver1_ssediv_double_load_256, bdver1_ssediv_double_256,
19164 bdver1_ssediv_single_load_256, bdver1_ssediv_single_256,
19165 bdver1_ssediv_double_load, bdver1_ssediv_double,
19166 bdver1_ssediv_single_load, bdver1_ssediv_single, bdver1_sseins):
19167 Add "bdver2" attribute.
19168
19169 2012-02-21 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
19170
19171 * config/s390/s390.c (s390_option_override): Make -mhard-dfp the
19172 default if possible and not specified otherwise.
19173
19174 2012-02-21 Richard Guenther <rguenther@suse.de>
19175
19176 PR middle-end/52314
19177 * gimplify.c (create_tmp_from_val): Use the main variant type
19178 for the type of the temporary we create.
19179
19180 2012-02-21 Richard Guenther <rguenther@suse.de>
19181
19182 PR tree-optimization/52324
19183 * gimplify.c (gimplify_expr): When re-gimplifying expressions
19184 do not gimplify a MEM_REF address operand if it is already
19185 in suitable form.
19186
19187 2012-02-21 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
19188
19189 * config/s390/s390.md ("fixuns_trunc<mode>si2"): Replace
19190 TARGET_HARD_FLOAT with TARGET_HARD_DFP.
19191
19192 2012-02-21 Richard Guenther <rguenther@suse.de>
19193
19194 * tree-vect-stmts.c (vectorizable_load): Use pre-computed
19195 nested_in_vect_loop.
19196
19197 2012-02-21 Jakub Jelinek <jakub@redhat.com>
19198
19199 PR tree-optimization/52318
19200 * gimple-fold.c (gimplify_and_update_call_from_tree): Add
19201 vdef also to non-pure/const call stmts in the sequence.
19202
19203 2012-02-21 Tristan Gingold <gingold@adacore.com>
19204
19205 * config/vms/vms-ld.c (main): Fix IDENTIFICATION padding.
19206
19207 2012-02-20 David S. Miller <davem@davemloft.net>
19208
19209 * config/sparc/sparc.md (load_pcrel_sym<P:mode>): Explain why we
19210 don't use the "rd %pc" instruction on v9 for PIC register loads.
19211
19212 2012-02-20 Aldy Hernandez <aldyh@redhat.com>
19213
19214 PR middle-end/52141
19215 * trans-mem.c (ipa_tm_scan_irr_block): Error out on GIMPLE_ASM's
19216 in a transaction safe function.
19217
19218 2012-02-20 Kai Tietz <ktietz@redhat.com>
19219
19220 PR target/52238
19221 * stor-layout.c (place_field): Handle desired_align for
19222 ms-bitfields, too.
19223
19224 2012-02-20 Richard Guenther <rguenther@suse.de>
19225
19226 PR tree-optimization/52298
19227 * tree-vect-stmts.c (vectorizable_store): Properly use
19228 STMT_VINFO_DR_STEP instead of DR_STEP when vectorizing
19229 outer loops.
19230 (vectorizable_load): Likewise.
19231 * tree-vect-data-refs.c (vect_analyze_data_ref_access):
19232 Access DR_STEP after ensuring it is not NULL.
19233
19234 2012-02-20 Jakub Jelinek <jakub@redhat.com>
19235
19236 PR tree-optimization/52286
19237 * fold-const.c (fold_binary_loc): For (X & C1) | C2
19238 optimization use double_int_to_tree instead of build_int_cst_wide,
19239 rewrite to use double_int vars.
19240
19241 2012-02-20 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
19242
19243 PR target/50166
19244 * acinclude.m4 (gcc_AC_INITFINI_ARRAY): Require gcc_SUN_LD_VERSION.
19245 Define _start.
19246 Remove -e 0 from $gcc_cv_ld invocation.
19247 Only use __GLIBC_PREREQ if defined.
19248 Enable on Solaris since Solaris 8 patch.
19249 (gcc_SUN_LD_VERSION): New macro.
19250 * configure.ac (ld_ver) <*-*-solaris2*>: Refer to
19251 gcc_SUN_LD_VERSION for version number format.
19252 * configure: Regenerate.
19253 * varasm.c (get_elf_initfini_array_priority_section): Set
19254 SECTION_NOTYPE for non-default priority.
19255 Use get_section instead of get_unnamed_section to emit
19256 .init_array/.fini_array with default priority.
19257
19258 2012-02-19 Richard Sandiford <rdsandiford@googlemail.com>
19259
19260 * config/mips/mips.c (mips_need_mips16_rdhwr_p): New variable.
19261 (mips_get_tp): Set it. Record that __mips16_rdhwr binds locally.
19262 (mips_start_unique_function, mips_output_mips16_rdhwr)
19263 (mips_code_end): New functions.
19264 (TARGET_ASM_CODE_END): Define.
19265
19266 2012-02-19 Richard Sandiford <rdsandiford@googlemail.com>
19267
19268 * config/mips/mips.c (mips16_build_call_stub): Add CFI information
19269 to stubs with non-sibling calls.
19270
19271 2012-02-18 Sandra Loosemore <sandra@codesourcery.com>
19272
19273 * doc/invoke.texi (-fira-* options): Copy-edit.
19274 (ira-* parameters): Copy-edit.
19275
19276 2012-02-17 Sandra Loosemore <sandra@codesourcery.com>
19277
19278 * doc/invoke.texi: Minor copy-edits to bring into conformance with
19279 GCC coding conventions.
19280
19281 2012-02-17 Sandra Loosemore <sandra@codesourcery.com>
19282
19283 * doc/invoke.texi: Consistently hyphenate "big-endian"/"little-endian"
19284 when used as adjectives.
19285
19286 2012-02-16 Sandra Loosemore <sandra@codesourcery.com>
19287
19288 * doc/invoke.texi: Clean up "that"/"which" confusion.
19289
19290 2012-02-17 Steven Bosscher <steven@gcc.gnu.org>
19291
19292 * system.h: Poison SMALL_REGISTER_CLASSES
19293 * config/rl78/rl78.h: Replace SMALL_REGISTER_CLASSES with hook.
19294 * config/rx/rx.h: Remove SMALL_REGISTER_CLASSES.
19295
19296 2012-02-16 Jakub Jelinek <jakub@redhat.com>
19297
19298 PR tree-optimization/52285
19299 * tree-tailcall.c (find_tail_calls): Ignore gimple_clobber_p stmts
19300 when deciding if a call is a tail call or tail recursion.
19301
19302 2012-02-16 Kai Tietz <ktietz@redhat.com>
19303
19304 * config/i386/i386.c (legitimate_pic_address_disp_p): Allow
19305 interger-constant displacement for UNSPEC_PCREL.
19306
19307 2012-02-16 Jakub Jelinek <jakub@redhat.com>
19308
19309 PR rtl-optimization/52208
19310 * ira-costs.c (scan_one_insn): Don't decrease mem_cost
19311 for MEMs with REG_EQUIV, if the MEM isn't general_operand.
19312
19313 PR tree-optimization/52255
19314 * tree-vect-loop-manip.c (slpeel_tree_peel_loop_to_edge): If
19315 loop->header has virtual PHI, but exit_e->dest doesn't, add
19316 virtual PHI to exit_e->dest and adjust all uses after the loop.
19317
19318 PR debug/52260
19319 * dwarf2out.c (copy_decls_walk): Fill in *slot before traversing
19320 children with clone_tree_hash, not after it.
19321
19322 2012-02-16 Iain Sandoe <iains@gcc.gnu.org>
19323
19324 * config/darwin.h (ASM_OUTPUT_LABELREF): Add user label prefix for
19325 extended identifiers.
19326
19327 2012-02-16 Jakub Jelinek <jakub@redhat.com>
19328
19329 PR middle-end/51929
19330 * cgraphunit.c (verify_edge_corresponds_to_fndecl): If node is
19331 a same_body_alias, also test whether e->callee isn't a former
19332 or current clone of the decl this is a same body alias of.
19333
19334 PR translation/52264
19335 * cgraphunit.c (verify_cgraph_node): Fix a typo.
19336
19337 2012-02-15 Sandra Loosemore <sandra@codesourcery.com>
19338
19339 * doc/invoke.texi: Clean up "n-bit/byte/word" modifiers.
19340
19341 2012-02-15 Michael Meissner <meissner@linux.vnet.ibm.com>
19342
19343 PR target/52199
19344 * config/rs6000/rs6000.c (rs6000_expand_vector_init): Use
19345 force_reg instead of copy_to_reg for better optimization. Force
19346 non-register or memory operands into a register.
19347
19348 2012-02-15 Andrew MacLeod <amacleod@redhat.com>
19349
19350 * extend.texi: Reserve upper bits of memory model for future use.
19351
19352 2012-01-15 Georg-Johann Lay <avr@gjlay.de>
19353 Anatoly Sokolov <aesok@post.ru>
19354 Eric Weddington <eric.weddington@atmel.com>
19355
19356 PR target/52261
19357 * config/avr/avr-devices.c (avr_arch_types): Add avrxmega2,
19358 avrxmega4, avrxmega5, avrxmega6, avrxmega7.
19359 Rewrite initializers for .macro.
19360 * config/avr/avr-mcus.def (AVR_MCU): Add known MCUs:
19361 avrxmega2: atxmega16a4, atxmega16d4, atxmega16x1, atxmega32a4
19362 atxmega32d4, atxmega32x1.
19363 avrxmega4: atxmega64a3, atxmega64d3.
19364 avrxmega5: atxmega64a1, atxmega64a1u.
19365 avrxmega6: atxmega128a3, atxmega128d3, atxmega192a3, atxmega192d3,
19366 atxmega256a3, atxmega256a3b, atxmega256a3bu, atxmega256d3.
19367 avrxmega7: atxmega128a1, atxmega128a1u.
19368 * config/avr/avr.h (enum avr_arch): Add: ARCH_AVRXMEGA2,
19369 ARCH_AVRXMEGA4, ARCH_AVRXMEGA5, ARCH_AVRXMEGA6, ARCH_AVRXMEGA7.
19370 (struct base_arch_s): Rename reserved to xmega_p.
19371 Rename reserved2 to have_rampd.
19372 (AVR_XMEGA): New define.
19373 (AVR_HAVE_RAMPD, AVR_HAVE_RAMPX, AVR_HAVE_RAMPY): New defines.
19374 (AVR_HAVE_RAMPZ): Change definition to fit xmega.
19375 * config/avr/predicates.md (io_address_operand): Take into
19376 account SFR offset.
19377 (low_io_address_operand): Ditto.
19378 (high_io_address_operand): Ditto.
19379 * config/avr/avr.md (isa): Add alternatives no_xmega, xmega.
19380 (enabled, movhi_sp_r): Use them.
19381 * config/avr/avr-c.c (avr_cpu_cpp_builtins): Use
19382 cpp_define_formatted to built-in define __AVR_ARCH__.
19383 (__AVR_XMEGA__): New built-in define.
19384 (__AVR_HAVE_RAMPD__): New built-in define.
19385 (__AVR_HAVE_RAMPX__): New built-in define.
19386 (__AVR_HAVE_RAMPY__): New built-in define.
19387 (__AVR_HAVE_RAMPZ__): Change condition when to built-in define it.
19388
19389 * config/avr/avr.c (avr_addr_t): Add ccp, rampd, rampx, rampy.
19390 (avr_option_override): Initialize them.
19391 (sreg_rtx, rampd_rtx, rampx_rtx, rampy_rtx): New GTY rtx.
19392 (avr_init_expanders): Initialize them. No more block several calls.
19393 (emit_push_sfr): New static function.
19394 (avr_prologue_setup_frame): Use it to push SREG, RAMPD/X/Y/Z as needed.
19395 Handle AVR_XMEGA.
19396 (expand_epilogue): Handle AVR_XMEGA. Pop RAMPD/X/Y/Z as needed.
19397 (avr_print_operand): Print addreeses as symbols for
19398 RAMPX, RAMPY, RAMPD, CCP.
19399 (output_movhi): Handle AVR_XMEGA when writing to SP.
19400 (avr_out_movhi_mr_r_xmega): New static function.
19401 (out_movhi_mr_r): Forward to avr_out_movhi_mr_r_xmega for AVR_XMEGA.
19402 (avr_file_start): Print symbol defines for __RAMPX__, __RAMPY__,
19403 __RAMPD__, __CCP__ as needed.
19404
19405 * config/avr/multilib.h: Regenerate.
19406 * config/avr/t-multilib: Regenerate.
19407 * config/avr/avr-tables.opt: Regenerate.
19408
19409 2012-02-15 Tobias Grosser <grosser@fim.uni-passau.de>
19410
19411 PR tree-optimization/50561
19412 * graphite-flattening.c (lst_project_loop): Do not
19413 remove old scattering dimensions after flattening.
19414 (lst_do_flatten): Likewise.
19415
19416 2012-02-15 Georg-Johann Lay <avr@gjlay.de>
19417
19418 * doc/extend.texi (AVR Built-in Functions): Remove doc for
19419 __builtin_avr_map8, __builtin_avr_map16.
19420 Document __builtin_avr_insert_bits.
19421
19422 * config/avr/avr.md (map_bitsqi, map_bitshi): Remove.
19423 (insert_bits): New insn.
19424 (adjust_len.map_bits): Rename to insert_bits.
19425 (UNSPEC_MAP_BITS): Rename to UNSPEC_INSERT_BITS.
19426 * avr-protos.h (avr_out_map_bits): Remove.
19427 (avr_out_insert_bits, avr_has_nibble_0xf): New.
19428 * config/avr/constraints.md (Cxf,C0f): New.
19429 * config/avr/avr.c (avr_cpu_cpp_builtins): Remove built-in
19430 defines __BUILTIN_AVR_MAP8, __BUILTIN_AVR_MAP16.
19431 New built-in define __BUILTIN_AVR_INSERT_BITS.
19432 * config/avr/avr.c (TARGET_FOLD_BUILTIN): New define.
19433 (enum avr_builtin_id): Add AVR_BUILTIN_INSERT_BITS.
19434 (avr_move_bits): Rewrite.
19435 (avr_fold_builtin, avr_map_metric, avr_map_decompose): New static
19436 functions.
19437 (avr_map_op_t): New typedef.
19438 (avr_map_op): New static variable.
19439 (avr_out_insert_bits, avr_has_nibble_0xf): New functions.
19440 (adjust_insn_length): Handle ADJUST_LEN_INSERT_BITS.
19441 (avr_init_builtins): Add definition for __builtin_avr_insert_bits.
19442 (bdesc_3arg, avr_expand_triop_builtin): New.
19443 (avr_expand_builtin): Use them. And handle AVR_BUILTIN_INSERT_BITS.
19444 (avr_revert_map, avr_swap_map, avr_id_map, avr_sig_map): Remove.
19445 (avr_map_hamming_byte, avr_map_hamming_nonstrict): Remove.
19446 (avr_map_equal_p, avr_map_sig_p): Remove.
19447 (avr_out_swap_bits, avr_out_revert_bits, avr_out_map_bits): Remove.
19448 (bdesc_2arg): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
19449 (adjust_insn_length): Remove handling for ADJUST_LEN_MAP_BITS.
19450 (enum avr_builtin_id): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
19451 (avr_init_builtins): Remove __builtin_avr_map8, __builtin_avr_map16.
19452 (avr_expand_builtin): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
19453
19454 2012-02-14 Bernd Schmidt <bernds@codesourcery.com>
19455
19456 * config/c6x/c6x.md (reserve_cycles): New attribute.
19457 * config/c6x/c6x.c (c6x_sched_reorder_1): Ensure insns we predicate
19458 don't reserve functional units after the branch occurs.
19459
19460 2012-02-14 Aldy Hernandez <aldyh@redhat.com>
19461
19462 PR middle-end/52142
19463 * ipa-inline.c (can_inline_edge_p): Do not inline tm_pure
19464 functions into non-tm_pure functions.
19465
19466 2012-02-14 Eric Botcazou <ebotcazou@adacore.com>
19467
19468 PR lto/52178
19469 * gimple.c (iterative_hash_gimple_type): Use RECORD_OR_UNION_TYPE_P.
19470 (iterative_hash_canonical_type): Likewise.
19471 * tree-ssa-pre.c (fini_pre): Clean up the CFG only after purging all
19472 the dead edges.
19473
19474 2012-02-14 Bernd Schmidt <bernds@codesourcery.com>
19475
19476 * haifa-sched.c (prune_ready_list): Ensure that if there is a
19477 sched-group insn, it either remains alone or the entire list is pruned.
19478
19479 2012-02-14 Jonathan Wakely <jwakely.gcc@gmail.com>
19480
19481 * doc/install.texi (Prerequisites): Fix grammar.
19482 (Configuration): Likewise.
19483
19484 2012-02-14 Jonathan Wakely <jwakely.gcc@gmail.com>
19485
19486 * doc/install.texi (Prerequisites): Suggest building GMP, MPFR and
19487 MPC as part of GCC before describing configuring with --with-gmp etc.
19488 (Installing GCC: Configuration): --with-gmp etc. aren't needed if
19489 sources are present.
19490
19491 2012-02-14 Jakub Jelinek <jakub@redhat.com>
19492
19493 PR debug/51950
19494 * dwarf2out.c (clone_tree_hash): New function.
19495 (copy_decls_walk): Use it instead of clone_tree.
19496
19497 2012-02-14 Richard Guenther <rguenther@suse.de>
19498
19499 PR tree-optimization/52244
19500 PR tree-optimization/51528
19501 * tree-sra.c (analyze_access_subtree): Only create INTEGER_TYPE
19502 replacements for integral types.
19503
19504 2012-02-14 Walter Lee <walt@tilera.com>
19505
19506 * config.gcc: Handle tilegx and tilepro.
19507 * configure.ac (gcc_cv_as_dwarf2_debug_line): Enable test for
19508 tilegx and tilepro.
19509 Add HAVE_AS_TLS check for tilegx and tilepro.
19510 * configure: Regenerate.
19511 * doc/contrib.texi: Add Mat Hostetter and self.
19512 * doc/extend.texi (TILE-Gx Built-in Functions): New node.
19513 Document instruction intrinsics and network accessing intrinsics.
19514 (TILEPro Built-in Functions): New node. Document instruction
19515 intrinsics and network accessing intrinsics.
19516 * doc/install.texi (Specific, tilegx-*-linux*): Document it.
19517 (Specific, tilepro-*-linux*): Likewise.
19518 * doc/invoke.texi (TILE-Gx Options): New section.
19519 (TILEPro Options): New section.
19520 * doc/md.texi (TILE-Gx): New section.
19521 (TILEPro): New section.
19522 * common/config/tilegx/tilegx-common.c: New file.
19523 * common/config/tilepro/tilepro-common.c: New file.
19524 * config/tilegx/constraints.md: New file.
19525 * config/tilegx/linux.h: New file.
19526 * config/tilegx/mul-tables.c: New file.
19527 * config/tilegx/predicates.md: New file.
19528 * config/tilegx/sync.md: New file.
19529 * config/tilegx/t-tilegx: New file.
19530 * config/tilegx/tilegx-builtins.h: New file.
19531 * config/tilegx/tilegx-c.c: New file.
19532 * config/tilegx/tilegx-generic.md: New file.
19533 * config/tilegx/tilegx-modes.def: New file.
19534 * config/tilegx/tilegx-multiply.h: New file.
19535 * config/tilegx/tilegx-protos.h: New file.
19536 * config/tilegx/tilegx.c: New file.
19537 * config/tilegx/tilegx.h: New file.
19538 * config/tilegx/tilegx.md: New file.
19539 * config/tilegx/tilegx.opt: New file.
19540 * config/tilepro/constraints.md: New file.
19541 * config/tilepro/gen-mul-tables.cc: New file.
19542 * config/tilepro/linux.h: New file.
19543 * config/tilepro/mul-tables.c: New file.
19544 * config/tilepro/predicates.md: New file.
19545 * config/tilepro/t-tilepro: New file.
19546 * config/tilepro/tilepro-builtins.h: New file.
19547 * config/tilepro/tilepro-c.c: New file.
19548 * config/tilepro/tilepro-generic.md: New file.
19549 * config/tilepro/tilepro-modes.def: New file.
19550 * config/tilepro/tilepro-multiply.h: New file.
19551 * config/tilepro/tilepro-protos.h: New file.
19552 * config/tilepro/tilepro.c: New file.
19553 * config/tilepro/tilepro.h: New file.
19554 * config/tilepro/tilepro.md: New file.
19555 * config/tilepro/tilepro.opt: New file.
19556
19557 2012-02-14 Jakub Jelinek <jakub@redhat.com>
19558
19559 PR tree-optimization/52210
19560 * tree-vect-slp.c (vect_get_and_check_slp_defs): Call
19561 vect_model_simple_cost with two entry vect_def_type array instead
19562 of an address of dt.
19563
19564 2012-02-14 Richard Guenther <rguenther@suse.de>
19565
19566 PR lto/52178
19567 * tree-streamer-in.c (lto_input_ts_field_decl_tree_pointers):
19568 Do not stream DECL_QUALIFIER.
19569 * tree-streamer-out.c (write_ts_field_decl_tree_pointers): Likewise.
19570 * tree.c (free_lang_data_in_decl): Free DECL_QUALIFIER.
19571 (find_decls_types_r): Do not walk DECL_QUALIFIER.
19572
19573 2012-02-14 Jakub Jelinek <jakub@redhat.com>
19574
19575 PR c/52181
19576 * c-decl.c (merge_decls): Copy DECL_USER_ALIGN bit from olddecl to
19577 newdecl.
19578
19579 2012-02-13 Jakub Jelinek <jakub@redhat.com>
19580
19581 PR bootstrap/52172
19582 * cselib.h (cselib_subst_to_values_from_insn): New prototype.
19583 * cselib.c (cselib_subst_to_values_from_insn): New function.
19584 * sched-deps.c (add_insn_mem_dependence,
19585 sched_analyze_1, sched_analyze_2): Use it.
19586
19587 2012-02-13 Jan Hubicka <jh@suse.cz>
19588
19589 PR middle-end/52214
19590 * predict.c (predict_paths_for_bb): Fix thinko in prevoius patch.
19591
19592 2012-02-13 Eric Botcazou <ebotcazou@adacore.com>
19593
19594 * gcc.c (LINK_COMMAND_SPEC): Deal with -fgnu-tm.
19595 (GTM_SELF_SPECS): Define if not already defined.
19596 (driver_self_specs): Add GTM_SELF_SPECS.
19597 * config/darwin.h (LINK_COMMAND_SPEC_A): Deal with -fgnu-tm.
19598 (GTM_SELF_SPECS): Define.
19599 * config/i386/cygwin.h (GTM_SELF_SPECS): Likewise.
19600 * config/i386/mingw32.h (GTM_SELF_SPECS): Likewise.
19601
19602 2012-02-13 Jakub Jelinek <jakub@redhat.com>
19603
19604 * cselib.c (expand_loc): Return sp, fp, hfp or cfa base reg right
19605 away if seen.
19606
19607 * cselib.c (dump_cselib_val): Don't assume l->setting_insn is non-NULL.
19608
19609 PR middle-end/52230
19610 * omp-low.c (expand_omp_for): If a static schedule without chunk size
19611 has NULL region->cont, force fd.chunk_size to be integer_zero_node.
19612
19613 2012-02-13 Andrew MacLeod <amacleod@redhat.com>
19614
19615 PR c/52190
19616 * doc/extend.texi : Fix another __atomic_compare_exchange typo.
19617
19618 2012-02-13 Richard Guenther <rguenther@suse.de>
19619
19620 PR translation/52211
19621 * passes.c (enable_disable_pass): Fix typo.
19622
19623 2012-02-13 Jakub Jelinek <jakub@redhat.com>
19624
19625 PR middle-end/52209
19626 * expr.c (expand_expr_real_2) <case BIT_NOT_EXPR>: Only expand using
19627 XOR for reduce_bit_field if type is unsigned.
19628
19629 2012-02-12 Eric Botcazou <ebotcazou@adacore.com>
19630
19631 * config/sparc/sparc.h (CANNOT_CHANGE_MODE_CLASS): In 64-bit mode,
19632 disallow changes from SFmode to mode with different size in FP regs.
19633
19634 2012-02-12 Robert Millan <rmh@gnu.org>
19635 Gerald Pfeifer <gerald@pfeifer.com>
19636
19637 * ginclude/stddef.h [__FreeBSD_kernel__] (__size_t): Do not define.
19638 Tweak comment.
19639
19640 2012-02-11 Richard Sandiford <rdsandiford@googlemail.com>
19641
19642 PR rtl-optimization/52175
19643 * reorg.c (fill_slots_from_thread): Don't apply add/sub optimization
19644 to frame-related instructions.
19645
19646 2012-02-10 Jason Merrill <jason@redhat.com>
19647
19648 PR c++/51910
19649 * tlink.c (demangled_hash_entry): Change mangled to a VEC.
19650 (demangle_new_symbols): Fill it.
19651 (scan_linker_output): Walk it.
19652 (start_tweaking): Split out from scan_linker_output.
19653 (maybe_tweak): Update sym->chosen.
19654 * Makefile.in (COLLECT2_OBJS): Add vec.o and gcc-none.o
19655
19656 2012-02-11 Jakub Jelinek <jakub@redhat.com>
19657
19658 PR debug/52132
19659 * reg-stack.c (subst_stack_regs_in_debug_insn): Don't use get_true_reg.
19660
19661 2012-02-11 Uros Bizjak <ubizjak@gmail.com>
19662
19663 * compare-elim.c (find_comparisons_in_bb): Eliminate only compares
19664 having the same mode as previous compare.
19665
19666 2012-02-10 Eric Botcazou <ebotcazou@adacore.com>
19667
19668 * config/sparc/sparc.c (sparc_flat_expand_prologue): Use emit_use.
19669 * config/sparc/sparc.md (UNSPECV_GOTO): Delete.
19670 (nonlocal_goto_internal): Likewise.
19671 (nonlocal_goto): Emit a use and an indirect jump directly.
19672
19673 2012-02-10 Andrew MacLeod <amacleod@redhat.com>
19674
19675 PR c/52190
19676 * doc/extend.texi : Update comments for __atomic_compare_exchange and
19677 __atomic_{is,always}_lock_free.
19678
19679 2012-02-10 Uros Bizjak <ubizjak@gmail.com>
19680
19681 PR target/52146
19682 * config/i386/i386.c (ix86_legitimate_address_p): Disallow
19683 negative constant address for TARGET_X32.
19684
19685 2012-02-10 Richard Henderson <rth@redhat.com>
19686
19687 * tree-ssa-dce.c (propagate_necessity): Handle GIMPLE_TRANSACTION.
19688 * tree-ssa-operands.c (parse_ssa_operands): Add virtual operands
19689 for GIMPLE_TRANSACTION. Tidy if's into a switch.
19690
19691 2012-02-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
19692 Ira Rosen <irar@il.ibm.com>
19693
19694 PR tree-optimization/50031
19695 * targhooks.c (default_builtin_vectorization_cost): Handle
19696 vec_promote_demote.
19697 * target.h (enum vect_cost_for_stmt): Add vec_promote_demote.
19698 * tree-vect-loop.c (vect_get_single_scalar_iteraion_cost): Handle
19699 all types of reduction and pattern statements.
19700 (vect_estimate_min_profitable_iters): Likewise.
19701 * tree-vect-stmts.c (vect_model_promotion_demotion_cost): New function.
19702 (vect_get_load_cost): Use vec_perm for permutations; add dump logic
19703 for explicit realigns.
19704 (vectorizable_conversion): Call vect_model_promotion_demotion_cost.
19705 * config/spu/spu.c (spu_builtin_vectorization_cost): Handle
19706 vec_promote_demote.
19707 * config/i386/i386.c (ix86_builtin_vectorization_cost): Likewise.
19708 * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost): Update
19709 vec_perm for VSX and handle vec_promote_demote.
19710
19711 2012-02-10 Jakub Jelinek <jakub@redhat.com>
19712
19713 PR middle-end/52177
19714 * builtins.c (fold_builtin_atomic_always_lock_free,
19715 expand_builtin_atomic_always_lock_free,
19716 fold_builtin_atomic_is_lock_free, expand_builtin_atomic_is_lock_free):
19717 Return and/or test boolean_true_node/boolean_false_node instead of
19718 integer_one_node/integer_zero_node.
19719
19720 2012-02-10 Jan Hubicka <jh@suse.cz>
19721
19722 PR middle-end/48600
19723 * predict.c (predict_paths_for_bb): Prevent looping.
19724 (predict_paths_leading_to_edge, predict_paths_leading_to): Update.
19725
19726 2012-02-10 Roman Zhuykov <zhroma@ispras.ru>
19727
19728 * config/arm/arm.c (output_move_double): In one case properly
19729 count number of instructions that will be emitted.
19730
19731 2012-02-10 Richard Guenther <rguenther@suse.de>
19732
19733 PR translation/52193
19734 * cgraphunit.c (cgraph_mark_functions_to_output): Fix typo.
19735
19736 2012-02-09 Peter Bergner <bergner@vnet.ibm.com>
19737
19738 PR middle-end/52140
19739 * dojump.c (do_compare_rtx_and_jump): Use SCALAR_FLOAT_MODE_P.
19740
19741 2012-02-09 Jakub Jelinek <jakub@redhat.com>
19742
19743 PR debug/52165
19744 * var-tracking.c (emit_note_insn_var_location): If
19745 EMIT_NOTE_BEFORE_INSN and insn is NOTE_INSN_CALL_ARG_LOCATION,
19746 emit it before next non-NOTE_INSN_CALL_ARG_LOCATION
19747 non-NOTE_DURING_CALL_P insn.
19748
19749 2012-02-09 Bin Cheng <bin.cheng@arm.com>
19750
19751 PR middle-end/51867
19752 * builtins.c (expand_builtin): Don't check DECL_ASSEMBLER_NAME_SET_P.
19753
19754 2012-02-08 Magnus Granberg <zorry@gentoo.org>
19755
19756 PR driver/48524
19757 * gcc.c (switch_matches) Support switches with separated form,
19758 -D and -U.
19759
19760 2012-02-08 Georg-Johann Lay <avr@gjlay.de>
19761
19762 * config/avr/avr.md (SREG_ADDR): Remove constant definition.
19763 (SP_ADDR): Ditto.
19764 (RAMPZ_ADDR): Ditto.
19765 * config/avr/avr.c (avr_addr_t): New typedef.
19766 (avr_addr): New struct to hold RAM address of SPL, SPH, RAMPZ, SREG.
19767 (avr_init_expanders): Initialize it.
19768 (expand_prologue): Use avr_addr instead of RAMPZ_ADDR, SP_ADDR,
19769 SREG_ADDR.
19770 (expand_epilogue): Ditto.
19771 (avr_print_operand): Ditto.
19772 (avr_file_start): Ditto.
19773 (avr_emit_movmemhi): Ditto.
19774
19775 2012-02-08 Richard Guenther <rguenther@suse.de>
19776
19777 PR tree-optimization/46886
19778 * tree-flow.h (do_while_loop_p): Declare.
19779 * tree-ssa-loop-ch.c (do_while_loop_p): Export.
19780 * tree-parloops.c (parallelize_loops): Only parallelize do-while loops.
19781
19782 2012-02-08 Andrew MacLeod <amacleod@redhat.com>
19783
19784 * optabs.c (expand_atomic_load): Do not assume compare_and_swap will
19785 always succeed for integers larger than a native word.
19786
19787 2012-02-08 Richard Guenther <rguenther@suse.de>
19788
19789 PR rtl-optimization/52170
19790 * simplify-rtx.c (simplify_plus_minus): Use CONSTM1_RTX to
19791 properly handle integer vector modes.
19792
19793 2012-02-08 Jakub Jelinek <jakub@redhat.com>
19794
19795 PR gcov-profile/52150
19796 * coverage.c: Include target.h.
19797 (build_var): Call targetm.strip_name_encoding on the assembler name.
19798 Change one _ into . or $ if the target allows it.
19799 * Makefile.in (coverage.o): Depend on $(TARGET_H).
19800
19801 PR rtl-optimization/52139
19802 * cfgrtl.c (cfg_layout_merge_blocks): If BB_END
19803 is a BARRIER after emit_insn_after_noloc, move BB_END
19804 to the last non-BARRIER insn before it.
19805
19806 2012-02-07 Richard Sandiford <rdsandiford@googlemail.com>
19807
19808 PR middle-end/24306
19809 * config/mips/mips.c (mips_std_gimplify_va_arg_expr): New function.
19810 (mips_gimplify_va_arg_expr): Call it instead of
19811 std_gimplify_va_arg_expr.
19812
19813 2012-02-07 Michael Meissner <meissner@linux.vnet.ibm.com>
19814
19815 * config/rs6000/rs6000.c (rs6000_trampoline_init): Fix error
19816 message for -mno-pointers-to-nested-function.
19817
19818 2012-02-07 Eric Botcazou <ebotcazou@adacore.com>
19819
19820 PR middle-end/51994
19821 * expr.c (get_inner_reference): If there is an offset, add a negative
19822 bit position to it (if any).
19823
19824 2012-02-07 Jakub Jelinek <jakub@redhat.com>
19825
19826 PR rtl-optimization/52060
19827 * combine.c (try_combine): Add i0src_copy and i0src_copy2 variables,
19828 copy i1src to i1src_copy whenever added_sets_2 && i1_feeds_i2_n already
19829 before i1dest -> i1src substitution in newpat, copy i0src to i0src_copy
19830 and/or i0src_copy2 when needed.
19831
19832 2012-02-07 Jakub Jelinek <jakub@redhat.com>
19833
19834 * gcc.c (main): Don't look for lto-wrapper or lto-wrapper
19835 or LTOPLUGINSONAME if have_c.
19836
19837 * config/freebsd-spec.h: Add comment about what macros can be defined
19838 in this header.
19839 (LINK_EH_SPEC, LINK_SSP_SPEC, USE_LD_AS_NEEDED): Don't define here.
19840 * config/freebsd.h (LINK_EH_SPEC, LINK_SSP_SPEC, USE_LD_AS_NEEDED): But
19841 here instead.
19842
19843 2012-02-07 Richard Guenther <rguenther@suse.de>
19844
19845 * gimple-pretty-print.c (dump_gimple_phi): Avoid excessive
19846 newline in -alias dumps.
19847
19848 2012-02-07 Kai Tietz <ktietz@redhat.com>
19849 Dave Korn <dave.korn.cygwin@gmail.com>
19850
19851 PR target/40068
19852 * config/i386/winnt-cxx.c (i386_pe_adjust_class_at_definition):
19853 Take care that typinfo gets dllexport-attribute.
19854
19855 2012-02-07 Jakub Jelinek <jakub@redhat.com>
19856
19857 PR middle-end/52074
19858 * expr.c (expand_expr_addr_expr_1): For CONSTANT_CLASS_P or CONST_DECL
19859 if modifier < EXPAND_SUM call force_operand on the result.
19860
19861 2012-02-07 Joern Rennecke <joern.rennecke@embecosm.com>
19862
19863 * config/epiphany/epiphany.h (ASM_DECLARE_FUNCTION_SIZE): Redefine,
19864 adding __forwarder_dst__ prefix if a forwarder_section attribute is
19865 present.
19866 (epiphany_function_type): Replace types for specific interrupts with
19867 EPIPHANY_FUNCTION_INTERRUPT.
19868 (EPIPHANY_INTERRUPT_P): Update.
19869 * config/epiphany/epiphany.c (epiphany_handle_forwarder_attribute):
19870 New static function.
19871 (epiphany_attribute_table) <interrupt>: min_len is 0, max_len is 9.
19872 <disinterrupt>: Affects type identity.
19873 (epiphany_handle_interrupt_attribute): Handle variable number of
19874 arguments.
19875 (epiphany_compute_function_type): Update for new
19876 epiphany_function_type definition.
19877 (epiphany_expand_prologue): Don't save (reg:DI GPR_0) for interrupt
19878 handlers with a longcall forwarder.
19879 (epiphany_start_function): Handle multiple interrupt arguments and/or
19880 forwarder_section attribute.
19881
19882 * config/epiphany/epiphany.h (LIB_SPEC): Link libc again after
19883 libgloss.
19884
19885 2012-02-07 Alan Modra <amodra@gmail.com>
19886
19887 PR target/52107
19888 * config/rs6000/rs6000.c (rs6000_emit_move): Don't create DImode
19889 subregs of TFmode.
19890
19891 2012-02-06 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
19892
19893 PR tree-optimization/50969
19894 * tree-vect-stmts.c (vect_model_store_cost): Correct statement cost to
19895 use vec_perm rather than vector_stmt.
19896 (vect_model_load_cost): Likewise.
19897 * config/i386/i386.c (ix86_builtin_vectorization_cost): Change cost of
19898 vec_perm to be the same as other vector statements.
19899 * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost): Revise
19900 cost of vec_perm for TARGET_VSX.
19901
19902 2012-02-06 Richard Guenther <rguenther@suse.de>
19903
19904 PR tree-optimization/52115
19905 * tree-sra.c (access_has_replacements_p): New function.
19906 (sra_modify_assign): Use it to decide whether a use is uninitialized.
19907
19908 2012-02-06 Patrick Marlier <patrick.marlier@gmail.com>
19909
19910 PR middle-end/52047
19911 * trans-mem.c (expand_call_tm): Add an assertion.
19912 * calls.c (flags_from_decl_or_type): Add ECF_TM_PURE to 'no vops'
19913 functions.
19914
19915 2012-02-06 Richard Guenther <rguenther@suse.de>
19916
19917 PR tree-optimization/50955
19918 * tree-ssa-loop-ivopts.c (get_computation_cost_at): Artificially
19919 raise cost of expressions that replace an address with an
19920 expression based on a different pointer.
19921
19922 2012-02-06 Jakub Jelinek <jakub@redhat.com>
19923
19924 PR target/52129
19925 * calls.c (mem_overlaps_already_clobbered_arg_p): If val is
19926 CONST_INT_P, subtract resp. add crtl->args.pretend_args_size to it.
19927
19928 2012-02-06 Jonathan Wakely <jwakely.gcc@gmail.com>
19929
19930 PR c++/48680
19931 * doc/invoke.texi (C++ Dialect Options): Use @option markup for
19932 -Weffc++ and specify guidelines come from second edition.
19933
19934 2012-02-05 Richard Sandiford <rdsandiford@googlemail.com>
19935
19936 * config/mips/mips.md (sibcall_internal, sibcall_value_internal)
19937 (sibcall_value_multiple_internal, call_split, call_internal_direct)
19938 (call_direct_split, call_value_split, call_value_internal_direct)
19939 (call_value_direct_split, call_value_multiple_split): Use jal and
19940 jal_macro attributes.
19941
19942 2012-02-05 Richard Sandiford <rdsandiford@googlemail.com>
19943
19944 * reload1.c (reload_regs_reach_end_p): Replace with...
19945 (reload_reg_rtx_reaches_end_p): ...this function.
19946 (new_spill_reg_store): Update commentary.
19947 (emit_input_reload_insns): Don't clear new_spill_reg_store here.
19948 (emit_output_reload_insns): Check reload_reg_rtx_reaches_end_p
19949 before setting new_spill_reg_store.
19950 (emit_reload_insns): Use a separate loop to clear new_spill_reg_store.
19951 Use reload_reg_rtx_reaches_end_p instead of reload_regs_reach_end_p.
19952 Also use reload_reg_rtx_reaches_end_p when reading new_spill_reg_store
19953 for non-spill reload registers.
19954
19955 2012-02-05 Ira Rosen <irar@il.ibm.com>
19956
19957 PR tree-optimization/52091
19958 * tree-vectorizer.h (vect_is_simple_use): Add an argument.
19959 (vect_is_simple_use_1): Likewise.
19960 * tree-vect-loop.c (vectorizable_reduction): Update calls
19961 to vect_is_simple_use_1 and vect_is_simple_use.
19962 (vectorizable_live_operation): Likewise.
19963 * tree-vect-patterns.c (widened_name_p,
19964 vect_recog_vector_vector_shift_pattern, check_bool_pattern): Likewise.
19965 * tree-vect-stmts.c (process_use, vect_get_vec_def_for_operand,
19966 vectorizable_call, vectorizable_conversion, vectorizable_assignment,
19967 vectorizable_shift,vectorizable_operation, vectorizable_store,
19968 vectorizable_load): Likewise.
19969 (vect_is_simple_cond): Add an argument, pass it to
19970 vect_is_simple_use_1.
19971 (vectorizable_condition): Update calls to vect_is_simple_cond,
19972 vect_is_simple_use.
19973 (vect_is_simple_use): Add an argument, the statement in which
19974 OPERAND is used. Check that if OPERAND's def stmt is a double
19975 reduction phi node, the use is a phi node too.
19976 (vect_is_simple_use_1): Add an argument, pass it to
19977 vect_is_simple_use.
19978 * tree-vect-slp.c (vect_get_and_check_slp_defs): Update a call
19979 to vect_is_simple_use.
19980
19981 2012-02-04 Jakub Jelinek <jakub@redhat.com>
19982
19983 PR rtl-optimization/52095
19984 * modulo-sched.c (dump_insn_locator): New function.
19985 (loop_canon_p, sms_schedule): Use it.
19986
19987 PR rtl-optimization/52113
19988 * lower-subreg.c (decompose_multiword_subregs): Call recog_memoized
19989 even for decomposable shift/zext insns.
19990
19991 2012-02-03 Jakub Jelinek <jakub@redhat.com>
19992 Zdenek Dvorak <ook@ucw.cz>
19993
19994 PR rtl-optimization/52092
19995 * loop-unswitch.c (unswitch_single_loop): Call copy_rtx_if_shared
19996 on get_iv_value result.
19997
19998 2012-02-02 Andrew Pinski <apinski@cavium.com>
19999
20000 PR middle-end/47982
20001 PR middle-end/43967
20002 * doc/libgcc.texi (__udivmoddi4/__udivmodti4): Fix documentation typo.
20003
20004 2012-02-02 Jakub Jelinek <jakub@redhat.com>
20005
20006 PR middle-end/48071
20007 * diagnostic.c (diagnostic_finish): Remove trailing newlines.
20008
20009 2012-02-02 Vladimir Makarov <vmakarov@redhat.com>
20010
20011 PR rtl-optimization/49800
20012 * haifa-sched.c (sched_init): Call regstat_init_n_sets_and_refs.
20013 (sched_finish): Call regstat_free_n_sets_and_refs.
20014
20015 2012-02-02 Jia Liu <proljc@gmail.com>
20016
20017 * config/mips/mips-dspr2.md (mips_prepend): Mask operand 3 rather
20018 than operand 2.
20019
20020 2012-02-02 Jan Hubicka <jh@suse.cz>
20021 Tom de Vries <tom@codesourcery.com>
20022
20023 PR middle-end/51998
20024 * cgraphunit.c (cgraph_analyze_function): Break cyclic aliases.
20025 * varpool.c (varpool_analyze_pending_decls): Likewise.
20026
20027 2012-02-02 Sumanth G <sumanth.gundapaneni@kpitcummins.com>
20028 Jayant R Sonar <jayant.sonar@kpitcummins.com>
20029
20030 * config.gcc: Add cr16-* support.
20031
20032 * doc/extend.texi: Document cr16 extensions.
20033 * doc/install.texi: Document cr16 install.
20034 * doc/invoke.texi: Document cr16 options.
20035 * doc/md.texi: Document cr16 constraints.
20036
20037 * common/config/cr16/cr16-common.c: New file.
20038 * config/cr16/cr16.c: New file.
20039 * config/cr16/cr16.h: New file.
20040 * config/cr16/cr16.md: New file.
20041 * config/cr16/cr16.opt: New file.
20042 * config/cr16/cr16-protos.h: New file.
20043 * config/cr16/predicates.md: New file.
20044 * config/cr16/constraints.md: New file.
20045 * config/cr16/t-cr16: New file.
20046
20047 2012-02-02 Jakub Jelinek <jakub@redhat.com>
20048
20049 PR target/52086
20050 * config/i386/i386.md (*addqi_2 peephole with SImode addition): Check
20051 that operands[2] is either immediate, or q_regs_operand.
20052
20053 PR tree-optimization/52073
20054 * tree-vect-stmts.c (vect_mark_relevant): When checking uses of
20055 a pattern stmt for pattern uses, ignore uses outside of the loop.
20056
20057 2012-02-01 Georg-Johann Lay <avr@gjlay.de>
20058
20059 * config/avr/avr.c: Resolve all AS1 and AS2 macros.
20060 * config/avr/avr.h (AS1, AS2, AS2C, AS3): Remove.
20061 (OUT_AS1, OUT_AS2): Remove.
20062
20063 2012-02-01 Georg-Johann Lay <avr@gjlay.de>
20064
20065 PR rtl-optimization/51374
20066 * combine.c (can_combine_p): Don't allow volatile_refs_p insns
20067 to cross other volatile_refs_p insns.
20068
20069 2012-02-01 Richard Guenther <rguenther@suse.de>
20070
20071 * doc/invoke.texi (fno-inline): Clarify documentation.
20072 (finline-small-functions): Likewise.
20073 (finline-functions): Likewise.
20074 * common.opt (finline): Adjust comment and documentation.
20075 (finline-small-functions): Clarify documentation.
20076 (finline-functions): Likewise.
20077 (finline-functions-called-once): Likewise.
20078
20079 2012-02-01 Tristan Gingold <gingold@adacore.com>
20080
20081 * c-typeck.c (composite_type): Keep mode for pointers.
20082
20083 2012-01-31 Richard Sandiford <rdsandiford@googlemail.com>
20084
20085 * function.h (regno_reg_rtx): Adjust comment.
20086 * reginfo.c (init_reg_modes_target): Only use the previous mode
20087 if it fits within one register. Remove MIPS comment.
20088
20089 2012-01-31 Jakub Jelinek <jakub@redhat.com>
20090
20091 PR bootstrap/52058
20092 * combine.c (do_SUBST_LINK, SUBST_LINK): Guard with #ifndef HAVE_cc0.
20093
20094 2012-01-31 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
20095
20096 * config/s390/s390.md ("*ashr<mode>3_and"): Add missing z196 flag
20097 to srak instruction.
20098
20099 2012-01-31 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
20100
20101 * config/arm/thumb2.md (thumb2_mov_notscc): Use MVN for true condition.
20102
20103 2012-01-31 Jakub Jelinek <jakub@redhat.com>
20104
20105 PR bootstrap/52041
20106 PR bootstrap/52039
20107 PR target/51974
20108 * ipa-prop.c (detect_type_change_1): Call ao_ref_init.
20109
20110 2012-01-31 Richard Guenther <rguenther@suse.de>
20111
20112 PR tree-optimization/51528
20113 * tree-sra.c (sra_modify_assign): Avoid copy-in/out for aggregate
20114 assigns.
20115
20116 2012-01-31 Jakub Jelinek <jakub@redhat.com>
20117
20118 PR bootstrap/52041
20119 PR bootstrap/52039
20120 PR target/51974
20121 * ree.c (add_removable_extension): Change def_map argument
20122 to unsigned *, store in def_map 1 + offset into *insn_list vector
20123 instead of pointers into the vector.
20124 (find_removable_extensions): Adjust caller.
20125
20126 2012-01-30 Georg-Johann Lay <avr@gjlay.de>
20127
20128 * config/avr/avr.md: Resolve all AS1 and AS2 macros.
20129 Transform all "* quoted-c-code" to { c-code }.
20130 Remove redundant test for "optimize" in combine patterns.
20131 Move (include "avr-dimode.md") to end of file.
20132
20133 2012-01-30 Bin Cheng <bin.cheng@arm.com>
20134
20135 PR target/51835
20136 * config/arm/arm.c (arm_libcall_uses_aapcs_base): Use correct ABI
20137 for __aeabi_d2iz/__aeabi_d2uiz with hard-float.
20138
20139 2012-01-30 Richard Guenther <rguenther@suse.de>
20140
20141 PR tree-optimization/52028
20142 * tree-loop-distribution.c (ldist_gen): Properly update
20143 virtual SSA form.
20144
20145 2012-01-30 Jakub Jelinek <jakub@redhat.com>
20146
20147 PR debug/52027
20148 * dwarf2out.c (dwarf2out_switch_text_section): Don't call
20149 set_cur_line_info_table if not emitting debug info.
20150
20151 PR tree-optimization/52046
20152 * tree-vect-patterns.c (check_bool_pattern): Give up if
20153 a comparison could throw.
20154
20155 PR debug/52048
20156 * tree-ssa-tail-merge.c (local_def): Ignore debug uses.
20157
20158 2012-01-30 Richard Guenther <rguenther@suse.de>
20159
20160 PR tree-optimization/52045
20161 * tree-optimize.c (execute_cleanup_cfg_post_optimizing): Update
20162 SSA form if cfgcleanup did anything.
20163
20164 2012-01-30 Richard Guenther <rguenther@suse.de>
20165
20166 PR tree-optimization/52045
20167 * ipa-inline-transform.c (inline_transform): Call execute_fixup_cfg
20168 before computing final todo.
20169
20170 2012-01-30 Richard Guenther <rguenther@suse.de>
20171
20172 PR tree-optimization/51528
20173 * tree-sra.c (sra_modify_assign): Re-factor in preparation
20174 for PR51528 fix.
20175
20176 2012-01-30 Paolo Bonzini <bonzini@gnu.org>
20177
20178 * df-problems.c (df_kill_notes): Check that the use refers
20179 to the note under examination.
20180
20181 2012-01-30 Eric Botcazou <ebotcazou@adacore.com>
20182
20183 PR target/51920
20184 * config/sparc/sparc.c (vector_init_fpmerge): Remove INNER_MODE
20185 parameter and use short-lived pseudos.
20186 (vector_init_faligndata): Remove INNER_MODE parameter and use loop.
20187 (sparc_expand_vector_init): Const-ify local variables and adjust
20188 calls to above functions.
20189
20190 2012-01-30 Georg-Johann Lay <avr@gjlay.de>
20191
20192 * config/avr/avr.c (out_movqi_mr_r): Fix length computation.
20193
20194 2012-01-29 Sandra Loosemore <sandra@codesourcery.com>
20195
20196 * doc/invoke.texi: Make usage of "compile time" and
20197 "run time"/"runtime" consistent throughout the file.
20198
20199 2012-01-29 Uros Bizjak <ubizjak@gmail.com>
20200
20201 * config/alpha/alpha.c (alpha_option_override): Default to
20202 full IEEE compliance mode for Go language.
20203
20204 2012-01-29 Tijl Coosemans <tijl@coosemans.org>
20205
20206 * config/freebsd-spec.h [TARGET_LIBC_PROVIDES_SSP]
20207 (LINK_SSP_SPEC): Define.
20208
20209 2012-01-28 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
20210
20211 PR target/51871
20212 * config/pa/pa.c (pa_return_addr_rtx): Add support for PA2.0 export
20213 stubs.
20214
20215 2012-01-28 Sandra Loosemore <sandra@codesourcery.com>
20216
20217 * doc/invoke.texi: Correct hyphenation of "floating point",
20218 "double precision", and related terminology throughout the file.
20219
20220 2012-01-28 Jakub Jelinek <jakub@redhat.com>
20221
20222 PR target/52006
20223 * config/arm/arm.md (pic_add_dot_plus_eight peephole2): Use
20224 arm_general_register_operand predicate for operand 2 instead of
20225 register_operand.
20226
20227 2012-01-27 Ian Lance Taylor <iant@google.com>
20228
20229 PR go/47656
20230 * builtins.def (BUILT_IN_INIT_HEAP_TRAMPOLINE): Define.
20231 * builtins.c (expand_builtin_init_trampoline): Add onstack
20232 parameter. Change caller.
20233 (expand_builtin): Handle BUILT_IN_INIT_HEAP_TRAMPOLINE.
20234 * tree.c (build_common_builtin_nodes): Declare
20235 __builtin_init_heap_trampoline.
20236
20237 2012-01-27 Georg-Johann Lay <avr@gjlay.de>
20238
20239 * config/avr/avr-protos.h (lpm_reg_rtx, lpm_addr_reg_rtx,
20240 tmp_reg_rtx, zero_reg_rtx, all_regs_rtx, rampz_rtx): Make global.
20241 * config/avr/avr.c: Ditto.
20242 (avr_regnames): Remove because unused.
20243 * config/avr/avr.md (*cpse.ne): New peephole.
20244 (*cpse.eq): New peephole from former cpse peepholes.
20245
20246 2012-01-27 Michael Eager <eager@eagercon.com>
20247
20248 * config/microblaze.c (microblaze_emit_compare): Correct
20249 test after pcmp instruction.
20250
20251 2012-01-27 Richard Guenther <rguenther@suse.de>
20252
20253 PR tree-optimization/52020
20254 * tree-sra.c (sra_modify_assign): Do not transform clobbers.
20255
20256 2012-01-27 Richard Guenther <rguenther@suse.de>
20257
20258 * ipa-pure-const.c (check_stmt): Clobbers do not make a
20259 function non-const/pure.
20260
20261 2012-01-27 Richard Guenther <rguenther@suse.de>
20262
20263 PR tree-optimization/50444
20264 * tree-sra.c (build_ref_for_offset): Properly adjust the
20265 MEM_REF type for unaligned accesses.
20266
20267 2012-01-27 Richard Guenther <rguenther@suse.de>
20268
20269 PR tree-optimization/50444
20270 * expr.c (mem_ref_refers_to_non_mem_p): New function.
20271 (expand_assignment): Use it. Properly handle misaligned
20272 bases when expanding stores to component references.
20273 (expand_expr_real_1): Use mem_ref_refers_to_non_mem_p and
20274 refactor that case.
20275
20276 2012-01-27 Andrey Belevantsev <abel@ispras.ru>
20277
20278 PR middle-end/51389
20279 * Makefile.in (tree-data-ref.o): Depend on $(PARAMS_H).
20280 * tree-data-ref.h (find_data_references_in_loop): Remove declaration.
20281 * tree-data-ref.c (find_data_references_in_loop): Make static.
20282 (compute_all_dependences): Change return type to bool. Bail out
20283 for too many datarefs in a loop. Move the hunk resetting the data
20284 dependences vector from ...
20285 (compute_data_dependences_for_loop): ... here. Account for
20286 compute_all_dependences returning false.
20287 (compute_data_dependences_for_bb): Likewise.
20288 * params.def (PARAM_LOOP_MAX_DATAREFS_FOR_DATADEPS): New param.
20289 * doc/invoke.texi (loop-max-datarefs-for-datadeps): Document it.
20290
20291 2012-01-27 Richard Guenther <rguenther@suse.de>
20292
20293 PR middle-end/51959
20294 * expr.c (store_field): Use the alias-set of the scratch memory
20295 for storing to it.
20296
20297 2012-01-27 Tom de Vries <tom@codesourcery.com>
20298
20299 PR tree-optimization/51990
20300 * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Handle
20301 WITH_SIZE_EXPR.
20302 * tree-ssa-pre.c (create_component_ref_by_pieces_1): Same.
20303
20304 2012-01-27 Jakub Jelinek <jakub@redhat.com>
20305
20306 PR debug/52001
20307 * var-tracking.c (reverse_op): Don't add any reverse operation
20308 if V already has any constant locations.
20309
20310 2012-01-27 Sandra Loosemore <sandra@codesourcery.com>
20311
20312 * doc/invoke.texi: Correct usage of "command line" (noun)
20313 vs "command-line" (adjective) throughout.
20314
20315 2012-01-27 Sandra Loosemore <sandra@codesourcery.com>
20316
20317 * doc/invoke.texi (Language Independent Options): Move
20318 -Wcoverage-mismatch blurb from here....
20319 (Warning Options): ...to here.
20320
20321 2012-01-27 Peter Bergner <bergner@vnet.ibm.com>
20322
20323 * config/rs6000/rs6000.c (rs6000_option_override_internal):
20324 Set rs6000_always_hint to false for 476.
20325
20326 2012-01-27 Matthias Klose <doko@ubuntu.com>
20327
20328 * gcc.c (add_sysrooted_prefix): Remove trailing dir separator from
20329 system root.
20330 * incpath.c (add_standard_paths): Likewise.
20331
20332 2012-01-27 Richard Henderson <rth@redhat.com>
20333
20334 * config/m68k/m68k.c (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
20335 * config/m68k/sync.md (atomic_test_and_set): Rename from
20336 sync_test_and_setqi and adjust the operands.
20337 (atomic_test_and_set_1): Rename from sync_test_and_setqi_1
20338 and unconditionally enable.
20339
20340 2012-01-27 Richard Henderson <rth@redhat.com>
20341
20342 * config/sparc/sparc.c (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
20343 * config/sparc/sync.md (atomic_test_and_set): Only handle QImode.
20344 (ldstub): Rename from ldstubqi.
20345 (ldstub<I24MODE>): Remove.
20346
20347 2012-01-27 Richard Henderson <rth@redhat.com>
20348
20349 * target.def (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
20350 * c-cppbuiltin.c (cpp_atomic_builtins): Define
20351 __GCC_ATOMIC_TEST_AND_SET_TRUEVAL.
20352 * doc/tm.texi.in (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): Add doc hook.
20353 * doc/tm.texi: Rebuild.
20354
20355 2012-01-27 Richard Henderson <rth@redhat.com>
20356
20357 * optabs.c (gen_atomic_test_and_set): Remove default.
20358 (maybe_emit_atomic_test_and_set): Use maybe_expand_insn.
20359
20360 2012-01-26 Jakub Jelinek <jakub@redhat.com>
20361
20362 PR rtl-optimization/51978
20363 * ree.c (make_defs_and_copies_lists): Change set_pat type to const_rtx.
20364 (combine_reaching_defs): Likewise.
20365 (struct re_info): Remove.
20366 (add_removable_extension): Remove x and data arguments,
20367 add insn, insn_list and def_map. Use the arguments directly
20368 instead of using struct re_info.
20369 (find_removable_extensions): Don't call add_removable_extension
20370 through note_stores, instead just call it with single_set
20371 result if non-NULL.
20372 (find_and_remove_re): Pass curr_cand->expr instead of
20373 PATTERN (curr_cand->insn) as set_pat argument to combine_reaching_defs.
20374
20375 2012-01-26 Michael Matz <matz@suse.de>
20376
20377 PR tree-optimization/46590
20378 * cfgexpand.c: Revert last change (r183305).
20379 * gimplify.c (gimplify_bind_expr): Add clobbers for all non-gimple
20380 regs.
20381 * tree-eh.c (cleanup_empty_eh): Try to optimize clobbers before
20382 checking for emptiness.
20383
20384 2012-01-26 Jakub Jelinek <jakub@redhat.com>
20385
20386 PR middle-end/51895
20387 * expr.c (expand_expr_real_1): Handle BLKmode MEM_REF of
20388 non-addressable non-BLKmode base correctly.
20389
20390 2012-01-26 Michael Matz <matz@suse.de>
20391
20392 PR tree-optimization/48794
20393 * tree-eh.c (remove_unreachable_handlers_no_lp): Don't remove
20394 regions referenced from RESX/EH_DISPATCH.
20395
20396 2012-01-26 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
20397
20398 * config/s390/s390.h: Make BRANCH_COST an option.
20399 * config/s390/s390.opt: New option -mbranch-cost.
20400
20401 2012-01-26 Richard Henderson <rth@redhat.com>
20402
20403 Revert 2012-01-24 change:
20404 * trans-mem.c (requires_barrier): Do not instrument thread local
20405 variables and emit save/restore for them.
20406
20407 2012-01-25 Jakub Jelinek <jakub@redhat.com>
20408
20409 PR middle-end/51986
20410 * sched-deps.c (sched_get_condition_with_rev_uncached): Don't test
20411 for pat == 0.
20412
20413 2012-01-25 Richard Sandiford <rdsandiford@googlemail.com>
20414
20415 * config/mips/mips.c (mips_small_data_pattern_1): Don't process
20416 ASM_OPERANDS.
20417
20418 2012-01-25 Georg-Johann Lay <avr@gjlay.de>
20419
20420 PR target/49868
20421 Rename __pgm to __flash.
20422 Rename __pgm1 to __flash1.
20423 Rename __pgm2 to __flash2.
20424 Rename __pgm3 to __flash3.
20425 Rename __pgm4 to __flash4.
20426 Rename __pgm5 to __flash5.
20427 Rename __pgmx to __memx.
20428 * doc/extend.texi (AVR Named Address Spaces)
20429 Rename address space names as indicated above.
20430 * config/avr/avr.c (avr_addrspace): Ditto.
20431
20432 * config/avr/avr-protos.h
20433 (avr_mem_pgmx_p): Rename to avr_mem_memx_p.
20434 (avr_mem_pgm_p): Rename to avr_mem_flash_p.
20435 * config/avr/predicates.md: Ditto.
20436 * config/avr/avr.c Ditto, and
20437 (avr_decl_pgmx_p): Rename to avr_decl_memx_p.
20438 (avr_decl_pgm_p): Rename to avr_decl_flash_p.
20439
20440 * config/avr/avr.h (ADDR_SPACE_PGM): Rename to ADDR_SPACE_FLASH.
20441 (ADDR_SPACE_PGM1): Rename to ADDR_SPACE_FLASH1.
20442 (ADDR_SPACE_PGM2): Rename to ADDR_SPACE_FLASH2.
20443 (ADDR_SPACE_PGM3): Rename to ADDR_SPACE_FLASH3.
20444 (ADDR_SPACE_PGM4): Rename to ADDR_SPACE_FLASH4.
20445 (ADDR_SPACE_PGM5): Rename to ADDR_SPACE_FLASH5.
20446 (ADDR_SPACE_PGMX): Rename to ADDR_SPACE_MEMX.
20447 * config/avr/avr.c: Ditto.
20448 * config/avr/avr.md: Ditto.
20449
20450 2012-01-25 Jason Merrill <jason@redhat.com>
20451
20452 PR c++/51992
20453 * tree.c (find_decls_types_in_node): Walk gimple_call_fntype.
20454
20455 2012-01-25 Jakub Jelinek <jakub@redhat.com>
20456
20457 PR tree-optimization/51987
20458 * tree-data-ref.c (get_references_in_stmt): Handle references in
20459 non-volatile GIMPLE_ASM.
20460
20461 2012-01-25 Richard Guenther <rguenther@suse.de>
20462
20463 * tree-ssa-sccvn.c (vn_reference_eq): Also compare if both
20464 bases are dereferenced.
20465
20466 2012-01-25 Andrey Belevantsev <abel@ispras.ru>
20467
20468 PR rtl-optimization/48374
20469 * sel-sched-ir.h (get_all_loop_exits): Check for zero successors.
20470
20471 2012-01-25 Andrey Belevantsev <abel@ispras.ru>
20472
20473 * tree-predcom.c (tree_predictive_commoning_loop): Bail out when
20474 compute_data_dependences_for_loop returns false.
20475 * tree-parloops.c (loop_parallel_p): Likewise.
20476
20477 2012-01-25 Richard Guenther <rguenther@suse.de>
20478
20479 * tree.h (get_pointer_alignment_1): Declare.
20480 * builtins.c (get_pointer_alignment_1): New function.
20481 (get_pointer_alignment): Use it.
20482
20483 2012-01-25 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
20484
20485 PR rtl-optimization/48308
20486 * combine.c (enum undo_kind): Add UNDO_LINKS.
20487 (struct undo): Add member l to other_contents and where.
20488 (do_SUBST_LINK): New.
20489 (SUBST_LINK): New.
20490 (try_combine): Handle LOG_LINKS for the dummy i1 case.
20491 (undo_all): Handle UNDO_LINKS.
20492
20493 2012-01-25 Richard Henderson <rth@redhat.com>
20494
20495 * optabs.c (maybe_emit_atomic_test_and_set): Allow non-QImode
20496 mem inputs.
20497
20498 2012-01-24 Richard Sandiford <rdsandiford@googlemail.com>
20499
20500 * optabs.c (gen_atomic_test_and_set): Use each argument.
20501
20502 2012-01-24 Richard Sandiford <rdsandiford@googlemail.com>
20503
20504 * config/mips/mips-ps-3d.md (mips_addr_ps, reduc_splus_v2sf)
20505 (mips_cvt_pw_ps, mips_cvt_ps_pw, mips_mulr_ps, mips_cabs_cond_<fmt>)
20506 (mips_cabs_cond_4s, mips_cabs_cond_ps, bc1any4t, bc1any4f, bc1any2t)
20507 (bc1any2f, mips_rsqrt1_<fmt>, mips_rsqrt2_<fmt>, mips_recip1_<fmt>)
20508 (mips_recip2_<fmt>): Require TARGET_MIPS3D rather than
20509 TARGET_PAIRED_SINGLE_FLOAT.
20510
20511 2012-01-24 Richard Sandiford <rdsandiford@googlemail.com>
20512
20513 * doc/rtl.texi (MEM_IN_STRUCT_P, MEM_SCALAR_P): Delete.
20514 (in_struct, return_val): Remove MEM documentation.
20515 * rtl.h (rtx_def): Remove MEM meanings from in_struct and return_val.
20516 (MEM_IN_STRUCT_P, MEM_SCALAR_P): Delete.
20517 (MEM_COPY_ATTRIBUTES): Remove references to MEM_IN_STRUCT_P
20518 and MEM_SCALAR.
20519 * emit-rtl.c (set_mem_attributes_minus_bitpos): Likewise.
20520 * cfgexpand.c (add_alias_set_conflicts): Likewise.
20521 * expr.c (store_field): Likewise.
20522 * function.c (assign_stack_temp_for_type): Likewise.
20523 * ifcvt.c (noce_try_cmove_arith): Likewise.
20524 * reload1.c (reload): Likewise.
20525 * config/alpha/alpha.c (alpha_set_memflags_1): Likewise.
20526 (alpha_set_memflags): Likewise.
20527 * config/m32c/m32c.c (m32c_immd_dbl_mov): Nullify.
20528
20529 2012-01-24 Richard Sandiford <rdsandiford@googlemail.com>
20530
20531 * rtl.h (true_dependence, canon_true_dependence): Remove varies
20532 parameter.
20533 * alias.c (fixed_scalar_and_varying_struct_p): Delete.
20534 (true_dependence_1, write_dependence_p, may_alias_p): Don't call it.
20535 (true_dependence_1, true_dependence, canon_true_dependence): Remove
20536 varies parameter.
20537 * cselib.c (cselib_rtx_varies_p): Delete.
20538 (cselib_invalidate_mem): Update call to canon_true_dependence.
20539 * dse.c (record_store, check_mem_read_rtx): Likewise.
20540 (scan_reads_nospill): Likewise.
20541 * cse.c (check_dependence): Likewise.
20542 (cse_rtx_varies_p): Delete.
20543 * expr.c (safe_from_p): Update call to true_dependence.
20544 * ira.c (validate_equiv_mem_from_store): Likewise.
20545 (memref_referenced_p): Likewise.
20546 * postreload-gcse.c (find_mem_conflicts): Likewise.
20547 * sched-deps.c (sched_analyze_2): Likewise.
20548 * store-motion.c (load_kills_store): Likewise.
20549 * config/frv/frv.c (frv_registers_conflict_p_1): Likewise.
20550 * gcse.c (mems_conflict_for_gcse_p): Likewise.
20551 (compute_transp): Update call to canon_true_dependence.
20552
20553 2012-01-25 Richard Henderson <rth@redhat.com>
20554
20555 * optabs.c (CODE_FOR_atomic_test_and_set): Provide default.
20556 (maybe_emit_atomic_test_and_set): New.
20557 (expand_sync_lock_test_and_set): Use it.
20558 (expand_atomic_test_and_set): Likewise.
20559 * doc/extend.texi (__atomic_test_and_set): Adjust the docs to match
20560 the implementation; clarify implementation defined details.
20561 * doc/md.texi (atomic_test_and_set): Document.
20562
20563 2012-01-25 Richard Henderson <rth@redhat.com>
20564
20565 * config/sparc/predicates.md (zero_or_v7_operand): Use match_code.
20566
20567 2012-01-25 Richard Henderson <rth@redhat.com>
20568
20569 PR target/51968
20570 * config/arm/arm.c (neon_split_vcombine): Emit deleted note
20571 to effect no-op split.
20572
20573 2012-01-24 Aldy Hernandez <aldyh@redhat.com>
20574
20575 PR lto/51698
20576 * builtin-types.def: (BT_CONST_DOUBLE_PTR): New.
20577 (BT_FN_VOID_PTR_CONST_PTR_SIZE): New.
20578 (BT_FN_VOID_PTR_INT_SIZE): New.
20579 (BT_FN_UINT_UINT_VAR): Remove.
20580 (BT_FN_UINT32_UINT32_VAR): New.
20581 (BT_FN_DOUBLE_VPTR): Remove.
20582 (BT_FN_DOUBLE_CONST_DOUBLE_PTR): New.
20583
20584 * gtm-builtins.def (_ITM_abortTransaction): Set return type to void.
20585 (_ITM_changeTransactionMode): Same.
20586 (_ITM_memmoveRtWt): Change return type to void.
20587 (_ITM_memcpyRtWt): Same.
20588 (_ITM_memsetW): Same.
20589 (_ITM_RaRD): Change types to double.
20590 (_ITM_RD): Same.
20591 (_ITM_RaWD): Same.
20592 (_ITM_RfWD): Same.
20593
20594 * builtins.def (DEF_TM_BUILTIN): Set BOTH_P to true.
20595
20596 2012-01-24 Aldy Hernandez <aldyh@redhat.com>
20597 Patrick Marlier <patrick.marlier@gmail.com>
20598
20599 * trans-mem.c (requires_barrier): Do not instrument thread local
20600 variables and emit save/restore for them.
20601
20602 2012-01-24 Jason Merrill <jason@redhat.com>
20603
20604 PR c++/51812
20605 * cgraphunit.c (cgraph_decide_is_function_needed): Don't always
20606 output static aliases.
20607
20608 2012-01-24 Jakub Jelinek <jakub@redhat.com>
20609
20610 PR driver/47249
20611 * common.opt (-pie, -shared, pie, shared): Change from Common to
20612 Driver.
20613 * gcc.c (display_help): Display help for -pie and -shared.
20614
20615 2012-01-24 Georg-Johann Lay <avr@gjlay.de>
20616
20617 PR target/49868
20618 * doc/extend.texi (AVR Named Address Spaces): Move sample code up.
20619 Remove note on size/offset limitation.
20620 (AVR Variable Attributes): Add example how to read data located
20621 with progmem. Refer to named address spaces.
20622 * doc/invoke.texi (AVR Options): Fix typo.
20623
20624 2012-01-24 Richard Guenther <rguenther@suse.de>
20625
20626 Forward-port to trunk
20627 2010-09-21 Jakub Jelinek <jakub@redhat.com>
20628
20629 PR middle-end/45678
20630 * expr.c (expand_expr_real_1) <case VIEW_CONVERT_EXPR>: If
20631 op0 isn't sufficiently aligned and there is movmisalignM
20632 insn for mode, use it to load op0 into a temporary register.
20633
20634 2012-01-24 Jakub Jelinek <jakub@redhat.com>
20635
20636 PR target/51957
20637 * target.def (const_not_ok_for_debug_p): New hook.
20638 * doc/tm.texi.in (TARGET_CONST_NOT_OK_FOR_DEBUG_P): New hook
20639 documentation.
20640 * doc/tm.texi: Regenerated.
20641 * dwarf2out.c (const_ok_for_output_1): If
20642 targetm.const_not_ok_for_debug_p returns true, fail.
20643 * config/rs6000/rs6000.c (rs6000_const_not_ok_for_debug_p): New
20644 function.
20645 (TARGET_CONST_NOT_OK_FOR_DEBUG_P): Redefine.
20646
20647 2012-01-23 Kai Tietz <ktietz@redhat.com>
20648
20649 PR target/51900
20650 * config/i386/predicates.md (symbolic_operand): Allow
20651 UNSPEC_PCREL as PIC expression for lea.
20652 * config/i386/winnt.c (i386_pe_binds_local_p): Reworked.
20653 * config/i386/i386.c (ix86_delegitimize_address): Handle
20654 UNSPEC_PCREL for none-MEM, too.
20655
20656 2012-01-23 Aldy Hernandez <aldyh@redhat.com>
20657
20658 * trans-mem.c (ipa_tm_create_version): Set externally_visible.
20659 (ipa_tm_create_version_alias): Same.
20660
20661 2012-01-23 Uros Bizjak <ubizjak@gmail.com>
20662
20663 PR libitm/51830
20664 * builtin-types.def (BT_FN_UINT_UINT_VAR): New.
20665 * gtm-builtins.def (BUILT_IN_TM_START): Declare as BT_FN_UINT_UINT_VAR.
20666
20667 2012-01-23 Aldy Hernandez <aldyh@redhat.com>
20668 Patrick Marlier <patrick.marlier@gmail.com>
20669 Iain Sandoe <developer@sandoe-acoustics.co.uk>
20670
20671 PR lto/51916
20672 * lto-wrapper.c (run_gcc): Pass the LTO section name to
20673 simple_object_start_read.
20674
20675 2012-01-23 Richard Guenther <rguenther@suse.de>
20676
20677
20678 PR tree-optimization/51895
20679 * tree-sra.c (decide_one_param_reduction): Avoid sub-optimal
20680 parameter decomposition into BLKmode components.
20681
20682 2012-01-23 Eric Botcazou <ebotcazou@adacore.com>
20683
20684 * tree-ssa-structalias.c (intra_create_variable_infos): Do not create
20685 fake variables for restrict-qualified pointers whose pointed-to type
20686 contains a placeholder.
20687
20688 2012-01-23 Richard Guenther <rguenther@suse.de>
20689
20690 PR tree-optimization/51949
20691 * ipa-split.c (execute_split_functions): Do not split malloc functions.
20692
20693 2012-01-23 Jakub Jelinek <jakub@redhat.com>
20694
20695 PR rtl-optimization/51933
20696 * ree.c (transform_ifelse): Return true right away if dstreg is
20697 already wider or equal to cand->mode.
20698 (enum ext_modified_kind, struct ext_modified, ext_state): New types.
20699 (make_defs_and_copies_lists): Remove defs_list and copies_list
20700 arguments, add state argument, just truncate state->work_list
20701 instead of always allocating and freeing the vector. Assert that
20702 get_defs succeeds instead of returning 2. Changed return type to bool.
20703 (merge_def_and_ext): Add state argument. If SET_DEST doesn't
20704 have ext_src_mode, see if it has been modified already with the
20705 right kind of extension and has been extended before from the
20706 ext_src_mode. If SET_DEST is already wider or equal to cand->mode,
20707 just return true. Remember the original mode in state->modified array.
20708 (combine_reaching_defs): Add state argument. Don't allocate and
20709 free here def_list, copied_list and vec vectors, instead just
20710 VEC_truncate the vectors in *state. Don't handle outcome == 2 here.
20711 (find_and_remove_re): Set DF_DEFER_INSN_RESCAN df flag.
20712 Add state variable, clear vectors in it, initialize state.modified
20713 if needed. Free all the vectors at the end and state.modified too.
20714 Don't skip a candidate if the extension expression has been modified.
20715
20716 2012-01-22 Douglas B Rupp <rupp@gnat.com>
20717
20718 PR target/47096
20719 * config.gcc: (i[34567]86-*-interix3*): Remove from obsolete
20720 configurations. Change triplet to i[34567]86-*-interix[3-9]*.
20721 (extra_options) interix.opt -> i386/interix.opt"
20722 (extra_objs):Add winnt-stubs.o
20723 * configure.ac: Add interix to target_os .comm on PE check.
20724 * configure: Regenerate.
20725 * config/interix3.h: Delete and move bits to..
20726 * config/interix.h: Delete and move bits to..
20727 * config/i386/i386-interix3.h: Delete and move bits to..
20728 * config/i386/i386-interix.h: ..here.
20729 (TARGET_CPU_DEFAULT): Remove redefinition.
20730 (TARGET_ASM_CONSTRUCTOR): Undefine.
20731 (SUBTARGET_SWITCHES): Define for ms-bitfields.
20732 (TARGET_OS_CPP_BUILTINS): Remove __OPENNT. Add __declspec.
20733 (PTRDIFF_TYPE): Define.
20734 (LONG_DOUBLE_TYPE_SIZE): Define.
20735 (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Define.
20736 (SUBTARGET_OVERRIDE_OPTIONS): Remove.
20737 (TARGET_SECTION_TYPE_FLAGS): Define.
20738 (ASM_DECLARE_FUNCTION_NAME): Define.
20739 (ASM_OUTPUT_EXTERNAL): Define.
20740 (ASM_OUTPUT_EXTERNAL_LIBCALL): Define.
20741 (ASM_OUTPUT_ALIGNED_BSS): Define.
20742 (PCC_BITFIELD_TYPE_MATTERS): Define.
20743 (USE_CONST_SECTION): Define.
20744 (SUBTARGET_ENCODE_SECTION_INFO): Remove.
20745 (TARGET_ASM_FUNCTION_RODATA_SECTION): Remove.
20746 (SUPPORTS_ONE_ONLY): Remove.
20747 (I386_PE_STRIP_ENCODING): Define.
20748 * config/interix.opt: Delete and move bits to..
20749 * config/i386/interix.opt: ..here. New.
20750 (mpe-aligned-commons): Add.
20751 * config/i386/t-interix: Add copyright header.
20752 (winnt-stubs.o): Add rule.
20753
20754 2012-01-22 Jason Merrill <jason@redhat.com>
20755
20756 PR c++/51832
20757 * varpool.c (varpool_analyze_pending_decls): Copy DECL_EXTERNAL
20758 for extra name aliases.
20759
20760 2012-01-22 Eric Botcazou <ebotcazou@adacore.com>
20761
20762 PR rtl-optimization/51924
20763 * ree.c (combine_set_extension): Improve debugging message.
20764 (combine_reaching_defs): Likewise.
20765 (get_defs): Rename confusingly named variable.
20766 (find_and_remove_re): Skip a candidate if the extension expression has
20767 been modified.
20768
20769 2012-01-21 Robert Millan <rmh@gnu.org>
20770 Gerald Pfeifer <gerald@pfeifer.com>
20771
20772 * config/kfreebsd-gnu.h (GNU_USER_DYNAMIC_LINKERX32): New macro.
20773 (GNU_USER_DYNAMIC_LINKER): Adjust indentation.
20774
20775 2012-01-20 Jakub Jelinek <jakub@redhat.com>
20776
20777 PR tree-optimization/51914
20778 * tree-vect-stmts.c (vectorizable_conversion): For
20779 cvt_type && modifier == WIDEN, put temporary with cvt_type
20780 at the beginning of vec_dsts and set vec_dest to temporary
20781 with vectype_out.
20782
20783 2012-01-20 Eric Botcazou <ebotcazou@adacore.com>
20784
20785 * cfgrtl.c (rtl_dump_bb): Do not dump insns for {ENTRY|EXIT}_BLOCK.
20786
20787 2012-01-20 Tijl Coosemans <tijl@coosemans.org>
20788
20789 * config/i386/i386.c: Fix checks for !TARGET_MACHO.
20790 * config/rs6000/rs6000.c: Likewise.
20791
20792 2012-01-20 Jakub Jelinek <jakub@redhat.com>
20793
20794 PR target/51915
20795 * config/arm/arm.c (arm_count_output_move_double_insns): Call
20796 output_move_double on a copy of operands array.
20797
20798 2012-01-20 Cary Coutant <ccoutant@google.com>
20799 Dodji Seketeli <dodji@redhat.com>
20800
20801 PR debug/45682
20802 * dwarf2out.c (copy_declaration_context): Return ref to parent
20803 of declaration DIE, if necessary.
20804 (remove_child_or_replace_with_skeleton): Add new parameter; update
20805 caller. Place skeleton DIE under parent DIE of original declaration.
20806 Move call to copy_declaration_context to here ...
20807 (break_out_comdat_types): ... from here.
20808
20809 2012-01-20 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
20810
20811 PR rtl-optimization/51856
20812 * reload.c (find_reloads_subreg_address): Set the address_reloaded
20813 flag to reloaded.
20814
20815 2012-01-20 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
20816
20817 PR target/51819
20818 * config/arm/arm.c (arm_print_operand): Correct output of alignment
20819 hints for neon loads and stores.
20820
20821 2012-01-20 Georg-Johann Lay <avr@gjlay.de>
20822
20823 PR target/49868
20824 PR target/50887
20825 * doc/extend.texi (Named Address Spaces): Split into subsections.
20826 (AVR Named Address Spaces): New subsection.
20827 (M32C Named Address Spaces): New subsection.
20828 (RL78 Named Address Spaces): New subsection.
20829 (SPU Named Address Spaces): New subsection.
20830 (Variable Attributes): New anchor "AVR Variable Attributes".
20831 (AVR Variable Attributes): Rewrite and avoid wording
20832 "address space" in this context.
20833 * doc/invoke.texi (AVR Options): Rewrite and add documentation
20834 for -maccumulate-args, -mbranch-cost=, -mrelax, -mshort-calls.
20835 (AVR Built-in Macros): New subsubsection therein.
20836 * doc/md.texi (AVR constraints): Remove "C04", "R".
20837
20838 2012-01-20 Richard Guenther <rguenther@suse.de>
20839
20840 PR tree-optimization/51903
20841 * tree-ssa-pre.c (eliminate): Properly purging of EH edges
20842 when removing stmts.
20843
20844 2012-01-20 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
20845
20846 PR target/50313
20847 * config/arm/arm.c (arm_load_pic_register): Use
20848 gen_pic_load_addr_unified. Delete calls to gen_pic_load_addr_32bit
20849 , gen_pic_add_dot_plus_eight and gen_pic_add_dot_plus_four.
20850 (arm_pic_static_addr): Likewise.
20851 (arm_rtx_costs_1): Adjust cost for UNSPEC_PIC_UNIFIED.
20852 (arm_note_pic_base): Handle UNSPEC_PIC_UNIFIED.
20853 * config/arm/arm.md (UNSPEC_PIC_UNIFIED): Define.
20854 (pic_load_addr_unified): New.
20855
20856 2012-01-20 Andrey Belevantsev <abel@ispras.ru>
20857
20858 PR target/51106
20859 * function.c (instantiate_virtual_regs_in_insn): Use
20860 delete_insn_and_edges when removing a wrong asm insn.
20861
20862 2012-01-19 Vladimir Makarov <vmakarov@redhat.com>
20863
20864 PR rtl-optimization/40761
20865 * ira-int.h (struct ira_loop_tree_node): Add comment for member loop.
20866 Add new member loop_num.
20867 (IRA_LOOP_NODE_BY_INDEX): Modify the check.
20868 (ira_build): Remove the parameter.
20869
20870 * ira.c (ira_print_disposition): Use loop_num instead of loop->num.
20871 (ira.c): Do not build CFG loops for one region allocation. Remove
20872 argument from ira_build call.
20873
20874 * ira-build.c (init_loop_tree_node): New function.
20875 (create_loop_tree_nodes): Use it. Separate the case when CFG
20876 loops are not built.
20877 (more_one_region_p): Check current_loops.
20878 (finish_loop_tree_nodes): Separate the case when CFG loops are not
20879 built.
20880 (add_loop_to_tree): Process loop equal to NULL too.
20881 (form_loop_tree): Separate the case when CFG loops are not built.
20882 Use explicitly number for the root.
20883 (rebuild_regno_allocno_maps, create_loop_tree_node_allocnos): Add
20884 an assertion.
20885 (ira_print_expanded_allocno, loop_compare_func): Use loop_num
20886 instead of loop->num.
20887 (mark_loops_for_removal): Ditto. Use loop_num instead of loop->num.
20888 (mark_all_loops_for_removal): Ditto.
20889 (remove_unnecessary_regions): Separate the case when CFG loops
20890 are not built.
20891 (ira_build): Remove the parameter. Use explicit number of regions
20892 when CFG loops are not built.
20893
20894 * ira-color.c (print_loop_title): Separate the case for the root node.
20895 Use loop_num instead of loop->num.
20896 (move_spill_restore): Use loop_num instead of loop->num.
20897
20898 * ira-emit.c (setup_entered_from_non_parent_p): Add an assertion.
20899 (change_loop): Ditto.
20900 (change_loop): Use loop_num instead of loop->num.
20901
20902 * ira-lives.c (process_bb_node_lives): Ditto.
20903
20904 * ira-costs.c (print_allocno_costs, find_costs_and_classes): Ditto.
20905
20906 * ira-conflicts.c (print_allocno_conflicts): Ditto.
20907
20908 2012-01-19 Jakub Jelinek <jakub@redhat.com>
20909
20910 PR libmudflap/40778
20911 * tree-mudflap.c (mf_artificial): New function.
20912 (execute_mudflap_function_ops, execute_mudflap_function_decls,
20913 mx_register_decls, mudflap_enqueue_decl): Use it.
20914
20915 PR target/51876
20916 * config/arm/neon.md (*neon_vswp<mode>): Fix up operand
20917 numbers in the insn pattern.
20918
20919 2012-01-19 Michael Matz <matz@suse.de>
20920
20921 PR tree-optimization/46590
20922 * cfgexpand.c (add_scope_conflicts_1): New old_conflicts argument,
20923 use it in remembering which conflicts we already created.
20924 (add_scope_conflicts): Adjust call to above, (de)allocate helper
20925 bitmap.
20926
20927 2012-01-19 Aldy Hernandez <aldyh@redhat.com>
20928
20929 PR lto/51280
20930 * lto-wrapper.c (run_gcc): Pass -fgnu_tm on.
20931 (merge_and_complain): Same.
20932
20933 2012-01-19 Jakub Jelinek <jakub@redhat.com>
20934
20935 PR bootstrap/50237
20936 * config/initfini-array.h: Guard content of the header
20937 with #ifdef HAVE_INITFINI_ARRAY.
20938 * configure.ac: Move gcc_AC_INITFINI_ARRAY much later into the file.
20939 Add initfini-array.h to tm_file here.
20940 * acinclude.m4 (gcc_AC_INITFINI_ARRAY): For non-ia64 do a linker test.
20941 * config.gcc: Don't add initfini-array.h to tm_file here.
20942 * configure: Regenerated.
20943
20944 2012-01-19 Andrey Belevantsev <abel@ispras.ru>
20945
20946 PR rtl-optimization/51505
20947 * df-problems.c (df_kill_notes): New parameter live. Update comment.
20948 Remove REG_EQUAL/REG_EQUIV notes referring to dead registers.
20949 (df_note_bb_compute): Update the call to df_kill_notes.
20950
20951 2012-01-18 Aldy Hernandez <aldyh@redhat.com>
20952
20953 * trans-mem.c (requires_barrier): Remove call to is_global_var.
20954
20955 2012-01-18 Richard Guenther <rguenther@suse.de>
20956
20957 * tree-ssa.c (useless_type_conversion_p): Remove special-casing
20958 of conversions to void *.
20959
20960 2012-01-17 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
20961 Richard Sandiford <rdsandiford@googlemail.com>
20962
20963 PR middle-end/50325
20964 PR middle-end/51192
20965 * optabs.h (simplify_expand_binop): Declare.
20966 * optabs.c (simplify_expand_binop): Make global.
20967 * expmed.c (store_bit_field_1): Use simplify_expand_binop on big
20968 endian targets if the source cannot be exactly covered by word
20969 mode chunks.
20970
20971 2012-01-17 Jakub Jelinek <jakub@redhat.com>
20972
20973 PR bootstrap/51872
20974 * hard-reg-set.h (struct hard_reg_set_container): New type.
20975 * target.h (struct hard_reg_set_container): Forward declare.
20976 * target.def (set_up_by_prologue): New target hook.
20977 * doc/tm.texi.in (TARGET_SET_UP_BY_PROLOGUE): Document it.
20978 * doc/tm.texi: Regenerated.
20979 * function.c (thread_prologue_and_epilogue_insns): Change
20980 set_up_by_prologue HARD_REG_SET into struct hard_reg_set_container.
20981 Call targetm.set_up_by_prologue on it.
20982 * config/rs6000/rs6000.c (rs6000_set_up_by_prologue): New function.
20983 (TARGET_SET_UP_BY_PROLOGUE): Redefine to it.
20984
20985 2012-01-17 Nick Clifton <nickc@redhat.com>
20986
20987 * config/rx/rx.c (rx_can_use_simple_return): New function.
20988 * config/rx/rx-protos.h (rx_can_use_simple_return): Prototype.
20989 * config/rx/rx.md (return): Predicate on rx_can_use_simple_return.
20990
20991 2012-01-17 Richard Guenther <rguenther@suse.de>
20992
20993 PR middle-end/51782
20994 * expr.c (expand_assignment): Take address-space information
20995 from the address operand of MEM_REF and TARGET_MEM_REF.
20996 (expand_expr_real_1): Likewise.
20997
20998 2012-01-17 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
20999
21000 * ira.c (do_reload): Make sure ira_dump_file is re-set if no
21001 reload dump is requested.
21002
21003 2012-01-17 Aldy Hernandez <aldyh@redhat.com>
21004
21005 PR other/51165
21006 * trans-mem.c (requires_barrier): Call may_be_aliased.
21007
21008 2012-01-17 Jakub Jelinek <jakub@redhat.com>
21009
21010 PR tree-optimization/51877
21011 * tree-ssa-tail-merge.c (gimple_equal_p): Don't return true whenever
21012 call arguments and fndecls compare equal, instead return false if they
21013 don't. Return true only if lhs1 and lhs2 are either both NULL, or
21014 both SSA_NAMEs that are valueized the same, or they satisfy
21015 operand_equal_p.
21016
21017 2012-01-17 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
21018
21019 * configure.ac (gcc_cv_target_dl_iterate_phdr): Only check on
21020 Solaris 11+.
21021 * configure: Regenerate.
21022
21023 2012-01-16 Jan Hubicka <jh@suse.cz>
21024
21025 PR c/12245
21026 PR c++/14179
21027 * convert.c (convert_to_integer): Use fold_convert for
21028 converting an INTEGER_CST to integer type.
21029
21030 2012-01-16 Jason Merrill <jason@redhat.com>
21031
21032 PR c++/14179
21033 * vec.c (vec_gc_o_reserve_1): Use ggc_round_alloc_size.
21034
21035 2012-01-16 Jakub Jelinek <jakub@redhat.com>
21036
21037 PR bootstrap/51860
21038 * config/s390/s390.c (s390_chunkify_start): Don't skip
21039 call insns followed by NOTE_INSN_CALL_ARG_LOCATION note. Skip
21040 NOTE_INSN_VAR_LOCATION and NOTE_INSN_CALL_ARG_LOCATION notes.
21041 If insn is followed by NOTE_INSN_VAR_LOCATION or
21042 NOTE_INSN_CALL_ARG_LOCATION notes, insert jump after all those notes.
21043 Don't use location of note insns.
21044
21045 PR tree-optimization/51865
21046 * tree-inline.c (tree_function_versioning): Call remap_decl
21047 on DECL_RESULT whenever it has VOID_TYPE_P type.
21048
21049 2012-01-15 Richard Sandiford <rdsandiford@googlemail.com>
21050
21051 * config/mips/mips.c (mips16_build_call_stub): Don't use a stub
21052 for calls to locally-binding MIPS16 functions if only the return
21053 type uses float regs.
21054
21055 2012-01-15 Chung-Lin Tang <cltang@codesourcery.com>
21056 Richard Sandiford <rdsandiford@googlemail.com>
21057
21058 * config/mips/mips-protos.h (SYMBOL_FORCE_TO_MEM): Delete.
21059 (SYMBOL_32_HIGH): Likewise.
21060 (mips_output_tls_reloc_directive): Declare.
21061 * config/mips/mips.h (PIC_FUNCTION_ADDR_REGNUM): Move to mips.md.
21062 (mips_use_pcrel_pool_p, mips_lo_relocs, mips_hi_relocs): Declare.
21063 * config/mips/mips.c (mips_use_pcrel_pool_p): New variable.
21064 (mips_lo_relocs, mips_hi_relocs): Make extern.
21065 (mips16_stub_function): Move up file.
21066 (mips_classify_symbol): Remove SYMBOL_FORCE_TO_MEM handling.
21067 (mips_symbolic_constant_p): Likewise. Remove SYMBOL_32_HIGH too.
21068 (mips_symbol_insns_1): Likewise. Check mips_use_pcrel_pool_p.
21069 (mips_cannot_force_const_mem): Use mips_use_pcrel_pool_p instead of
21070 SYMBOL_FORCE_TO_MEM. Only check mips_tls_symbol_ref_1 if it's false.
21071 (mips_get_tp): Add MIPS16 support.
21072 (mips_legitimize_tls_address): Remove MIPS16 sorry().
21073 Generalize DTPREL and TPREL handling.
21074 (mips_init_relocs): Initialize mips_use_pcrel_pool_p.
21075 Add MIPS16 TLS support.
21076 (mips_output_tls_reloc_directive): New function.
21077 (mips16_rewrite_pool_refs): Ignore UNSPEC_TLS_GET_TPs.
21078 * config/mips/predicates.md (symbolic_operand_with_high)
21079 (tls_reloc_operand): New predicates.
21080 (force_to_mem_operand): Use mips_use_pcrel_pool_p.
21081 * config/mips/mips.md (UNSPEC_UNSHIFTED_HIGH): New unspec.
21082 (PIC_FUNCTION_ADDR_REGNUM): Moved from mips.h.
21083 (*unshifted_high): New instruction. Use it for MIPS16 high splitter.
21084 (consttable_tls_reloc, tls_get_tp_mips16_<mode>): New patterns.
21085 (*tls_get_tp_mips16_call_<mode>): Likewise.
21086
21087 2012-01-15 Uros Bizjak <ubizjak@gmail.com>
21088
21089 PR rtl-optimization/51821
21090 * recog.c (peep2_find_free_register): Determine clobbered registers
21091 from insn pattern.
21092
21093 2012-01-14 Denis Chertykov <chertykov@gmail.com>
21094
21095 PR target/50925
21096 * config/avr/avr-protos.h: Revert change of 2012-01-09.
21097 * config/avr/avr.c: Likewise.
21098 * config/avr/avr.h: Likewise.
21099
21100 2012-01-13 Ian Lance Taylor <iant@google.com>
21101
21102 PR c++/50012
21103 * tree.h (TYPE_QUALS): Add cast to int.
21104 (TYPE_QUALS_NO_ADDR_SPACE): Likewise.
21105
21106 2012-01-13 Ian Lance Taylor <iant@google.com>
21107
21108 * ipa-cp.c (ipa_get_indirect_edge_target): Add typecasts when
21109 comparing param_index to VEC_length result.
21110
21111 2012-01-13 Steven Bosscher <steven@gcc.gnu.org>
21112
21113 * c-decl.c: Do not include tree-mudflap.h
21114 * tree-optimize.c: Likewise.
21115 * Makefile.in: Update dependencies.
21116
21117 2012-01-13 Richard Guenther <rguenther@suse.de>
21118
21119 PR middle-end/8081
21120 * gimplify.c (gimplify_modify_expr_rhs): For calls with a
21121 variable-sized result always use RSO.
21122
21123 2012-01-12 DJ Delorie <dj@redhat.com>
21124
21125 * cfgexpand.c (convert_debug_memory_address): Allow any valid
21126 pointer type, not just the default pointer type.
21127
21128 2012-01-09 Richard Henderson <rth@redhat.com>
21129 Denis Chertykov <chertykov@gmail.com>
21130
21131 PR target/50925
21132 * config/avr/avr-protos.h (avr_hard_regno_nregs): Declare.
21133 * config/avr/avr.c (avr_can_eliminate): Simplify.
21134 (avr_initial_elimination_offset): Likewise.
21135 (avr_prologue_setup_frame): Use hard_frame_pointer_rtx.
21136 (expand_epilogue): Likewise.
21137 (avr_legitimize_address): Gut.
21138 (avr_legitimize_reload_address): Use hard_frame_pointer_rtx.
21139 (avr_hard_regno_nregs): New.
21140 (avr_hard_regno_ok): Allow only Pmode for arg and frame_pointers.
21141 (avr_regno_mode_code_ok_for_base_b): Handle arg and frame pointers.
21142 * config/avr/avr.h (FIXED_REGISTERS): Adjust arg pointer,
21143 add soft frame pointer.
21144 (CALL_USED_REGISTERS): Likewise.
21145 (REG_CLASS_CONTENTS): Likewise.
21146 (REGISTER_NAMES): Likewise.
21147 (HARD_REGNO_NREGS): Use avr_hard_regno_nregs.
21148 (HARD_FRAME_POINTER_REGNUM): New.
21149 (FRAME_POINTER_REGNUM): Use soft frame pointer.
21150 (ELIMINABLE_REGS): Eliminate from the soft frame pointer,
21151 remove the HARD_FRAME_POINTER self-elimination.
21152
21153 2012-01-12 Georg-Johann Lay <avr@gjlay.de>
21154
21155 PR target/51756
21156 * config/avr/avr.c (avr_encode_section_info): Test for absence of
21157 DECL_EXTERNAL when checking for initializers of progmem variables.
21158
21159 2012-01-12 Ira Rosen <irar@il.ibm.com>
21160
21161 PR tree-optimization/51799
21162 * tree-vect-patterns.c (vect_recog_over_widening_pattern): Check
21163 that the last operation is a type demotion.
21164
21165 2012-01-12 Uros Bizjak <ubizjak@gmail.com>
21166
21167 * config/i386/i386.md (*zero_extendsidi2_rex64): Correct movl template.
21168 (x86_shift<mode>_adj_1): Remove operand constraint from operand 3.
21169
21170 2012-01-11 Jakub Jelinek <jakub@redhat.com>
21171
21172 PR bootstrap/51796
21173 * combine.c (distribute_notes): If i3 is a noreturn call,
21174 allow old_size to be equal to args_size and make sure the
21175 noreturn call gets REG_ARGS_SIZE note.
21176 * expr.c (fixup_args_size_notes): Put REG_ARGS_SIZE notes
21177 on noreturn calls even when the delta is 0.
21178
21179 2012-01-11 Nathan Sidwell <nathan@acm.org>
21180
21181 * gcov.c (STRING_SIZE): Remove.
21182 (generate_results): Erase annotations for source files with no
21183 coverage information.
21184 (read_line): New.
21185 (output_lines): Use it.
21186
21187 2012-01-11 Eric Botcazou <ebotcazou@adacore.com>
21188
21189 * gimple.h (gimplify_body): Remove first argument.
21190 * gimplify.c (copy_if_shared): Add DATA argument. Do not create the
21191 pointer set here, instead just pass DATA to walk_tree.
21192 (unshare_body): Remove BODY_P argument and adjust. Create the pointer
21193 set here and invoke copy_if_shared on the size trees of DECL_RESULT.
21194 (unvisit_body): Likewise, but with unmark_visited.
21195 (gimplify_body): Remove BODY_P argument and adjust.
21196 (gimplify_function_tree): Adjust call to gimplify_body.
21197 * omp-low.c (finalize_task_copyfn): Likewise.
21198
21199 2012-01-11 Eric Botcazou <ebotcazou@adacore.com>
21200
21201 * tree.h (build_function_decl_skip_args): Add boolean parameter.
21202 (build_function_type_skip_args): Delete.
21203 * tree.c (build_function_type_skip_args): Make static and add
21204 SKIP_RETURN parameter. Fix thinko in the handling of variants.
21205 (build_function_decl_skip_args): Add SKIP_RETURN parameter and
21206 pass it to build_function_type_skip_args.
21207 * cgraph.h (cgraph_function_versioning): Add boolean parameter.
21208 (tree_function_versioning): Likewise.
21209 * cgraph.c (cgraph_create_virtual_clone): Adjust call to
21210 build_function_decl_skip_args.
21211 * cgraphunit.c (cgraph_function_versioning): Add SKIP_RETURN parameter
21212 and pass it to build_function_decl_skip_args/tree_function_versioning.
21213 (cgraph_materialize_clone): Adjust call to tree_function_versioning.
21214 * ipa-inline-transform.c (save_inline_function_body): Likewise.
21215 * trans-mem.c (ipa_tm_create_version): Likewise.
21216 * tree-sra.c (modify_function): Ditto for cgraph_function_versioning.
21217 * tree-inline.c (declare_return_variable): Remove always-true test.
21218 (tree_function_versioning): Add SKIP_RETURN parameter. If the function
21219 returns non-void and SKIP_RETURN, create a void-typed RESULT_DECL.
21220 * ipa-split.c (split_function): Skip the return value for the split
21221 part if it doesn't return.
21222
21223 2012-01-11 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
21224
21225 PR tree-optimization/49642
21226 * ipa-split.c (forbidden_dominators): New variable.
21227 (check_forbidden_calls): New function.
21228 (dominated_by_forbidden): Likewise.
21229 (consider_split): Check for forbidden dominators.
21230 (execute_split_functions): Initialize and free forbidden
21231 dominators info; call check_forbidden_calls.
21232
21233 2012-01-11 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
21234
21235 * config/arm/arm.md (mov_notscc): Use MVN for false condition.
21236
21237 2012-01-11 Nick Clifton <nickc@redhat.com>
21238
21239 * config/rx/rx.md (return): Define pattern.
21240
21241 2012-01-11 Richard Guenther <rguenther@suse.de>
21242
21243 * doc/extend.texi (malloc attribute): Adjust according to
21244 implementation.
21245
21246 2012-01-10 Aldy Hernandez <aldyh@redhat.com>
21247 Patrick Marlier <patrick.marlier@gmail.com>
21248
21249 PR middle-end/51516
21250 * trans-mem.c (get_cg_data): Traverse aliases if requested.
21251 (ipa_tm_scan_calls_block): Update parameters to get_cg_data.
21252 (ipa_tm_note_irrevocable): Same.
21253 (ipa_tm_scan_irr_block): Same.
21254 (ipa_tm_decrement_clone_counts): Same.
21255 (ipa_tm_scan_irr_function): Same.
21256 (ipa_tm_create_version_alias): Same.
21257 (ipa_tm_create_version): Same.
21258 (ipa_tm_transform_calls_redirect): Same.
21259 (ipa_tm_transform_calls): Same.
21260 (ipa_tm_transform_transaction): Same.
21261 (ipa_tm_execute): Same.
21262
21263 2012-01-10 Richard Guenther <rguenther@suse.de>
21264
21265 PR middle-end/51806
21266 * opts.c (common_handle_option): Handle -Werror.
21267
21268 2012-01-10 Andreas Schwab <schwab@linux-m68k.org>
21269
21270 * config/m68k/sync.md ("atomic_compare_and_swap<mode>_1"): Fix
21271 operand number.
21272
21273 2012-01-10 Jason Merrill <jason@redhat.com>
21274
21275 * doc/invoke.texi (C++ Dialect Options): Update -fabi-version=6
21276 information.
21277
21278 2012-01-10 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
21279
21280 * configure.ac (gcc_cv_as_ix86_tlsgdplt): Check if linker
21281 supports R_386_TLS_GD_PLT reloc.
21282 (gcc_cv_as_ix86_tlsldmplt): Check if linker
21283 supports R_386_TLS_LDM_PLT reloc.
21284 * configure: Regenerate.
21285 * config.in: Regenerate.
21286
21287 2012-01-10 Georg-Johann Lay <avr@gjlay.de>
21288
21289 PR target/49868
21290 Extend __pgmx semantics to linearize memory.
21291 * config/avr/avr.md (mov<mode>): Use avr_xload_libgcc_p to
21292 determine if code comes inline or from libgcc.
21293 (MOVMEM_r_d:HI): Add "w" to constraint for better preference.
21294 (movmem_qi, movmem_qi): Set constraint #2 to "n".
21295 (movmem_qi_elpm, movmem_hi_elpm): Remove insns.
21296 (movmemx_qi, movmemx_hi): New insns.
21297 (xload_<mode>_libgcc): Rewrite to new insn condition.
21298 (xload_<mode>): Remove insns.
21299 * config/avr/avr.c (avr_out_xload): Rewrite: Only need to handle
21300 cases that don't satisfy avr_xload_libgcc_p().
21301 (avr_addr_space_convert): Allow converting in any direction.
21302 (avr_addr_space_subset_p): Return always true.
21303 (avr_xload_libgcc_p): Rewrite to fit new __pgmx semantics.
21304 (avr_emit_movmemhi): Ditto.
21305 (avr_out_lpm): No need to handle ADDR_SPACE_PGMX any more.
21306 (avr_out_movmem): Ditto.
21307 (AVR_SYMBOL_FLAG_PROGMEM): New macro.
21308 (AVR_SYMBOL_SET_ADDR_SPACE): New macro.
21309 (AVR_SYMBOL_GET_ADDR_SPACE): New macro.
21310 (avr_encode_section_info): Encode 'progmem' in symbol flags.
21311 (output_reload_in_const): Don't zero-extend any 24-bit symbols.
21312
21313 2012-01-10 Richard Guenther <rguenther@suse.de>
21314
21315 PR tree-optimization/50913
21316 * graphite-scop-detection.c (stmt_has_simple_data_refs_p):
21317 Require data-refs to be representable by Graphite with respect
21318 to any loop nest.
21319
21320 2012-01-10 Uros Bizjak <ubizjak@gmail.com>
21321
21322 * config/i386/constraints.md ("L"): Return true for 0xffffffff.
21323 * config/i386/i386.c (*anddi_1): Emit AND with 0xffffffff as MOV.
21324
21325 2012-01-10 Tom de Vries <tom@codesourcery.com>
21326
21327 PR rtl-optimization/51271
21328 * dwarf2cfi.c (scan_trace): Save and restore cur_row->reg_save when
21329 handling annulled branch.
21330
21331 2012-01-10 Richard Henderson <rth@redhat.com>
21332
21333 * config/arm/arm.c (arm_vectorize_vec_perm_const_ok,
21334 TARGET_VECTORIZE_VEC_PERM_CONST_OK, neon_split_vcombine, MAX_VECT_LEN,
21335 struct expand_vec_perm_d, arm_expand_vec_perm_1, arm_expand_vec_perm,
21336 arm_evpc_neon_vuzp, arm_evpc_neon_vzip, arm_evpc_neon_vrev,
21337 arm_evpc_neon_vtrn, arm_evpc_neon_vtbl, arm_expand_vec_perm_const_1,
21338 arm_expand_vec_perm_const): New.
21339 * config/arm/arm-protos.h: Update.
21340 * config/arm/neon.md (UNSPEC_VCONCAT): New.
21341 (*neon_vswp<VDQX>): New.
21342 (neon_vcombine<VDX>): Use neon_split_vcombine.
21343 (neon_vtbl1v16qi, neon_vtbl2v16qi, neon_vcombinev16qi): New.
21344 * config/arm/vec-common.md (vec_perm_const<VALL>): New.
21345 (vec_perm<VE>): New.
21346
21347 2012-01-10 Richard Henderson <rth@redhat.com>
21348
21349 * config/arm/arm.c (arm_gen_compare_reg): Add scratch argument;
21350 use it if reload_completed.
21351 (arm_legitimize_sync_memory, arm_emit, arm_insn_count, arm_count,
21352 arm_output_asm_insn, arm_process_output_memory_barrier,
21353 arm_output_memory_barrier, arm_ldrex_suffix, arm_output_ldrex,
21354 arm_output_strex, arm_output_it, arm_output_op2, arm_output_op3,
21355 arm_output_sync_loop, arm_get_sync_operand, FETCH_SYNC_OPERAND,
21356 arm_process_output_sync_insn, arm_output_sync_insn,
21357 arm_sync_loop_insns, arm_call_generator, arm_expand_sync): Remove.
21358 (arm_pre_atomic_barrier, arm_post_atomic_barrier): New.
21359 (arm_emit_load_exclusive, arm_emit_store_exclusive): New.
21360 (emit_unlikely_jump): New.
21361 (arm_expand_compare_and_swap, arm_split_compare_and_swap): New.
21362 (arm_split_atomic_op): New.
21363 * config/arm/arm-protos.h: Update.
21364 * config/arm/arm.h (enum arm_sync_generator_tag): Remove.
21365 (struct arm_sync_generator): Remove.
21366 * config/arm/arm.md (VUNSPEC_SYNC_COMPARE_AND_SWAP, VUNSPEC_SYNC_LOCK,
21367 VUNSPEC_SYNC_OP, VUNSPEC_SYNC_NEW_OP, VUNSPEC_SYNC_OLD_OP): Remove.
21368 (VUNSPEC_ATOMIC_CAS, VUNSPEC_ATOMIC_XCHG, VUNSPEC_ATOMIC_OP): New.
21369 (VUNSPEC_LL, VUNSPEC_SC): New.
21370 (sync_result, sync_memory, sync_required_value, sync_new_value,
21371 sync_t1, sync_t2, sync_release_barrier, sync_op): Remove.
21372 (attr length): Don't use arm_sync_loop_insns.
21373 (cbranch_cc, cstore_cc): Update call to arm_gen_compare_reg.
21374 (movsfcc, movdfcc): Likewise.
21375 * config/arm/constraints.md (Ua): New.
21376 * config/arm/prediates.md (mem_noofs_operand): New.
21377 (sync_compare_and_swap<QHSD>, sync_lock_test_and_set<QHSD>): Remove.
21378 (sync_clobber, sync_t2_reqd): Remove.
21379 (sync_<syncop><QHSD>, sync_nand<QHSD>): Remove.
21380 (sync_new_<syncop><QHSD>, sync_new_nand<QHSD>): Remove.
21381 (sync_old_<syncop><QHSD>, sync_old_nand<QHSD>): Remove.
21382 (arm_sync_compare_and_swap<SIDI>): Remove.
21383 (arm_sync_compare_and_swap<NARROW>): Remove.
21384 (arm_sync_lock_test_and_set<SIDI>): Remove.
21385 (arm_sync_lock_test_and_set<NARROW>): Remove.
21386 (arm_sync_new_<syncop><SIDI>): Remove.
21387 (arm_sync_new_<syncop><NARROW>): Remove.
21388 (arm_sync_new_nand<SIDI>): Remove.
21389 (arm_sync_new_nand<NARROW>): Remove.
21390 (arm_sync_old_<syncop><SIDI>): Remove.
21391 (arm_sync_old_<syncop><NARROW>): Remove.
21392 (arm_sync_old_nand<SIDI>): Remove.
21393 (arm_sync_old_nand<NARROW>): Remove.
21394 (*memory_barrier): Merge arm_output_memory_barrier.
21395 (atomic_compare_and_swap<QHSD>): New.
21396 (atomic_compare_and_swap<NARROW>_1): New.
21397 (atomic_compare_and_swap<SIDI>_1): New.
21398 (atomic_exchange<QHSD>): New.
21399 (cas_cmp_operand, cas_cmp_str): New.
21400 (atomic_op_operand, atomic_op_str): New.
21401 (atomic_<syncop><QHSD>, atomic_nand<QHSD>): New.
21402 (atomic_fetch_<syncop><QHSD>, atomic_fetch_nand<QHSD>): New.
21403 (atomic_<syncop>_fetch<QHSD>, atomic_nand_fetch<QHSD>): New.
21404 (arm_load_exclusive<NARROW>): New.
21405 (arm_load_exclusivesi, arm_load_exclusivedi): New.
21406 (arm_store_exclusive<QHSD>): New.
21407
21408 2012-01-09 Michael Meissner <meissner@linux.vnet.ibm.com>
21409
21410 * config/rs6000/rs6000.c (rs6000_init_hard_regno_mode_ok): Add DF
21411 reload patterns if -mvsx-scalar-memory.
21412
21413 * config/rs6000/vsx.md (vsx_xscvspdp): Allow xscvspdp to be
21414 generated, even -mno-vsx-scalar-double was used.
21415 (vsx_xscvdpsp_scalar): Likewise.
21416 (vsx_xscvspdp_scalar2): Likewise.
21417
21418 2012-01-09 Tom de Vries <tom@codesourcery.com>
21419 Andrew Pinski <apinski@cavium.com>
21420
21421 PR debug/51471
21422 * reorg.c (fill_slots_from_thread): Don't speculate
21423 frame-related insns.
21424
21425 2012-01-09 Richard Sandiford <rdsandiford@googlemail.com>
21426
21427 * sched-int.h (bb_note): Move to...
21428 * basic-block.h: ...here.
21429 * haifa-sched.c (bb_note): Move to...
21430 * cfgrtl.c: ...here.
21431 * function.c (next_block_for_reg): New function.
21432 (move_insn_for_shrink_wrap): Likewise.
21433 (prepare_shrink_wrap): Rewrite to use the above.
21434
21435 2012-01-09 Aldy Hernandez <aldyh@redhat.com>
21436
21437 * gimple.c (is_gimple_non_addressable): Remove.
21438 * gimple.h: Remove is_gimple_non_addressable.
21439 * gimplify.c (gimplify_modify_expr_rhs): Use is_gimple_reg instead of
21440 is_gimple_non_addressable.
21441 * trans-mem.c (expand_assign_tm): Same.
21442
21443 2012-01-09 Richard Guenther <rguenther@suse.de>
21444
21445 PR tree-optimization/51775
21446 * tree-ssa-sccvn.c (visit_use): Value-number throwing stmts.
21447 * tree-ssa-pre.c (eliminate): Properly fixup EH info.
21448
21449 2012-01-09 Matthew Gretton-Dann <matthew.gretton-dann@arm.com>
21450
21451 * config/arm/arm-cores.def (cortex-a15): Use cortex_a15_tune for
21452 tuning parameters.
21453 * config/arm/arm.c (arm_cortex_a15_tune): New static variable.
21454
21455 2012-01-09 Richard Guenther <rguenther@suse.de>
21456
21457 * tree-streamer-out.c (write_ts_optimization): Fix spelling.
21458
21459 2012-01-08 Jan Hubicka <jh@suse.cz>
21460
21461 PR tree-optimize/51680
21462 * ipa-inline-analyss.c (evaluate_properties_for_edge): Fix condition
21463 on when known_vals needs to be computed; cleanup.
21464
21465 2012-01-08 Jan Hubicka <jh@suse.cz>
21466
21467 PR tree-optimize/51694
21468 * ipa-cp.c (ipa_get_indirect_edge_target): Add bounds checks.
21469
21470 2012-01-08 Jonathan Wakely <jwakely.gcc@gmail.com>
21471
21472 * doc/cpp.texi (Predefined Macros): __STRICT_ANSI__ is defined
21473 for -std=c++98 and -std=c++11 too.
21474
21475 2012-01-08 Chung-Lin Tang <cltang@codesourcery.com>
21476
21477 * cfgloop.c (cancel_loop): Add free() of bbs array.
21478
21479 2012-01-07 Jan Hubicka <jh@suse.cz>
21480
21481 PR tree-optimization/51600
21482 * ipa-inline-analysis.c (estimate_edge_devirt_benefit): Disable code
21483 that benefits small functions.
21484
21485 2012-01-07 Jan Hubicka <jh@suse.cz>
21486
21487 * ipa-inline.c (want_inline_small_function_p): Fix formating.
21488
21489 2012-01-07 Jan Hubicka <jh@suse.cz>
21490
21491 PR tree-optimization/51680
21492 * ipa-inline.c (want_inline_small_function_p): Be more lax on functions
21493 whose inlining reduce unit size.
21494
21495 2012-01-07 Alexandre Oliva <aoliva@redhat.com>
21496
21497 PR bootstrap/51725
21498 * cselib.c (new_elt_loc_list): Promote addr_list to canonical node.
21499 Add canonical node to containing_mem chain after the non-canonical
21500 one, even if there weren't any locs to propagate.
21501 (remove_useless_values): Keep only canonical values.
21502 (add_mem_for_addr, cselib_lookup_mem): Canonicalize addr.
21503 (cselib_invalidate_mem): Likewise. Ensure v is canonical, and
21504 canonicalize mem_chain elements that are not discarded.
21505
21506 2012-01-06 Jakub Jelinek <jakub@redhat.com>
21507
21508 PR target/47333
21509 * cgraphunit.c (cgraph_optimize): Call output_weakrefs
21510 before emitting functions.
21511
21512 PR gcov-profile/50127
21513 * bb-reorder.c (partition_hot_cold_basic_blocks): Call
21514 clear_aux_for_blocks.
21515
21516 2012-01-06 Alexandre Oliva <aoliva@redhat.com>
21517
21518 PR debug/51746
21519 * cselib.c (cselib_hash_rtx): Hash incoming VALUEs too.
21520
21521 2012-01-06 Arnaud Charlet <charlet@adacore.com>
21522
21523 * c-decl.c (ext_block): Moved up.
21524 (collect_all_refs, for_each_global_decl): Take ext_block into account.
21525
21526 2012-01-06 Han Shen <shenhan@google.com>
21527
21528 Translate built-in include paths for sysroot.
21529 * Makefile.in (gcc_gxx_include_dir_add_sysroot): New.
21530 (PREPROCESSOR_DEFINES): Define GPLUSPLUS_INCLUDE_DIR_ADD_SYSROOT.
21531
21532 * cppdefault.c (cpp_include_defaults): Replace hard coded "0" with
21533 GPLUSPLUS_INCLUDE_DIR_ADD_SYSROOT for "add_sysroot" field.
21534
21535 * configure.ac (AC_SUBST): Add gcc_gxx_include_dir_add_sysroot to
21536 control whether sysroot should be prepended to gxx include dir.
21537
21538 * configure: Regenerate.
21539
21540 2012-01-06 Torvald Riegel <triegel@redhat.com>
21541
21542 PR rtl-optimization/51771
21543 * builtin-attrs.def (ATTR_RETURNS_TWICE, ATTR_TM_NOTHROW_RT_LIST): New.
21544 * gtm-builtins.def (BUILT_IN_TM_START): Add returns-twice attrib.
21545
21546 2012-01-05 Eric Botcazou <ebotcazou@adacore.com>
21547
21548 PR tree-optimization/51315
21549 * tree-sra.c (tree_non_aligned_mem_for_access_p): New predicate.
21550 (build_accesses_from_assign): Use it instead of tree_non_aligned_mem_p.
21551
21552 2012-01-05 Uros Bizjak <ubizjak@gmail.com>
21553
21554 PR target/51681
21555 * config/ia64/ia64.c (expand_vec_perm_shrp): Use correct operands
21556 for shrp pattern. Correctly handle and fixup shift variable.
21557 Return false when shift > nelt for BYTES_BIG_ENDIAN target.
21558
21559 2012-01-05 Jakub Jelinek <jakub@redhat.com>
21560
21561 PR debug/51762
21562 * calls.c (emit_call_1): For noreturn calls force a REG_ARGS_SIZE
21563 note when !ACCUMULATE_OUTGOING_ARGS.
21564
21565 2012-01-05 Eric Botcazou <ebotcazou@adacore.com>
21566
21567 * tree-vrp.c (extract_range_from_binary_expr_1): Remove duplicated
21568 condition.
21569 (extract_range_from_unary_expr_1): Avoid useless computations.
21570
21571 2012-01-05 Jakub Jelinek <jakub@redhat.com>
21572
21573 PR rtl-optimization/51767
21574 * cfgrtl.c (force_nonfallthru_and_redirect): Force addition
21575 of jump_block and add an extra edge for degenerated asm gotos.
21576
21577 PR middle-end/51768
21578 * stmt.c (check_unique_operand_names): Don't ICE during error
21579 reporting if i is from labels chain.
21580
21581 PR middle-end/44777
21582 * profile.c (branch_prob): Split bbs that have exit edge
21583 and need a fake entry edge too.
21584
21585 2012-01-05 Jan Hubicka <jh@suse.cz>
21586
21587 PR middle-end/49710
21588 * cfgloopmanip.c (remove_path): Walk loop hiearchy upwards when
21589 unlooping loops.
21590
21591 2012-01-05 Richard Guenther <rguenther@suse.de>
21592
21593 PR lto/50490
21594 * tree-streamer-out.c (write_ts_optimization): New function.
21595 (streamer_write_tree_body): Call it.
21596 * tree-streamer-in.c (lto_input_ts_optimization): New function.
21597 (streamer_read_tree_body): Call it.
21598 * lto-streamer-out.c (lto_is_streamable): Handle OPTIMIZATION_NODE.
21599
21600 2012-01-05 Jakub Jelinek <jakub@redhat.com>
21601
21602 PR middle-end/51761
21603 * gimple.h (struct gimplify_ctx): Add in_cleanup_point_expr field.
21604 * gimplify.c (gimplify_cleanup_point_expr): Save and set
21605 in_cleanup_point_expr before gimplify_stmt call and restore it
21606 afterwards.
21607 (gimplify_target_expr): Don't add {CLOBBER} cleanup if
21608 in_cleanup_point_expr is false.
21609
21610 2012-01-05 Richard Guenther <rguenther@suse.de>
21611
21612 PR middle-end/51764
21613 * common.opt (Wmudflap, fmudflap, fmudflapth, fmudflapir): Move
21614 to c.opt.
21615 * toplev.c (process_options): Reject combining mudflap and LTO.
21616 * tree-nomudflap.c (nogo): Use sorry instead of internal_error.
21617
21618 2012-01-05 Richard Guenther <rguenther@suse.de>
21619
21620 PR tree-optimization/51760
21621 * tree-ssa-ccp.c (likely_value): Drop UNDEFINED to CONSTANT,
21622 not VARYING.
21623 (bit_value_unop): Handle UNDEFINED operands.
21624 (bit_value_binop): Likewise.
21625
21626 2012-01-05 Georg-Johann Lay <avr@gjlay.de>
21627
21628 * config/avr/avr.c (avr_replace_prefix): Remove.
21629 (avr_asm_named_section): Use ACONCAT instead of avr_replace_prefix.
21630 (avr_asm_function_rodata_section): Ditto.
21631 (avr_asm_select_section): Ditto.
21632
21633 2012-01-05 Marcus Shawcroft <marcus.shawcroft@arm.com>
21634
21635 * reload.c (find_reloads): Adjust LABEL_NUSES on REG_LABEL_OPERAND
21636 insertion.
21637
21638 2012-01-05 Jakub Jelinek <jakub@redhat.com>
21639
21640 PR bootstrap/51648
21641 * tree-cfg.c (need_fake_edge_p): Return true also for noreturn
21642 calls that have any non-fake successor edges.
21643
21644 PR debug/51746
21645 * var-tracking.c (add_stores): For COND_EXEC allow oval to be NULL.
21646
21647 2012-01-04 Eric Botcazou <ebotcazou@adacore.com>
21648
21649 PR tree-optimization/51624
21650 * tree-sra.c (build_ref_for_model): When replicating a chain of
21651 COMPONENT_REFs, stop as soon as the offset would become negative.
21652
21653 2012-01-04 Jakub Jelinek <jakub@redhat.com>
21654
21655 PR debug/51695
21656 * dwarf2out.c (output_loc_list): For now drop >= 64KB expressions
21657 in .debug_loc on the floor.
21658
21659 2012-01-04 Andrew Pinski <apinski@cavium.com>
21660
21661 * doc/invoke.texi (-march=@var{arch}): Add octeon+ and octeon2.
21662
21663 2012-01-04 Andrew Pinski <apinski@cavium.com>
21664 Adam Nemet <anemet@caviumnetworks.com>
21665
21666 * config/mips/mips.md (size): Add SI and DI.
21667 (SIZE): New mode attribute.
21668 (U): New code attribute.
21669 * config/mips/mips-dsp.md (mips_lbux): Use gen_mips_lbux_extsi.
21670 (mips_lbux_<mode>): Delete.
21671 (mips_l<SHORT:size><u>x_ext<GPR:mode>_<P:mode>): New pattern.
21672 (mips_lhx): Use gen_mips_lhx_extsi.
21673 (mips_lhx_<mode>): Delete.
21674 (mips_lwx): Delete.
21675 (mips_l<size>x): New expand.
21676 (mips_lwx_<mode>): Delete.
21677 (mips_l<GPR:size>x_<P:mode>): New pattern.
21678 (*mips_lw<u>x_<P:mode>_ext): Likewise.
21679 * config/mips/mips-ftypes.def: Add DI f(POINTER, SI) function type.
21680 * config/mips/mips.c (mips_lx_address_p): New function.
21681 (mips_rtx_costs <case MEM>): Call mips_lx_address_p.
21682 (dsp64): New availability predicate.
21683 (mips_builtins): Add an entry for __builtin_mips_ldx.
21684 * config/mips/mips.h (ISA_HAS_LBX): New define.
21685 (ISA_HAS_LBUX): Likewise.
21686 (ISA_HAS_LHX): Likewise.
21687 (ISA_HAS_LHUX): Likewise.
21688 (ISA_HAS_LWX): Likewise.
21689 (ISA_HAS_LWUX): Likewise.
21690 (ISA_HAS_LDX): Likewise.
21691 * doc/extend.texi (__builtin_mips_ldx): Document.
21692
21693 2012-01-04 Tristan Gingold <gingold@adacore.com>
21694
21695 * config/vms/xm-vms.h (HOST_LONG_FORMAT, HOST_PTR_PRINTF): Define
21696 when long pointers are used.
21697 * config.build (*-*-*vms*): Handle all OpenVMS targets.
21698 (alpha64-dec-*vms*, alpha*-dec-*vms*)
21699 (ia64-hp-*vms*): Remove.
21700 * config/vms/xm-vms64.h: Delete.
21701
21702 2012-01-04 Aldy Hernandez <aldyh@redhat.com>
21703
21704 PR middle-end/51472
21705 * trans-mem.c (expand_assign_tm): Handle TM_MEMMOVE loads correctly.
21706
21707 2012-01-04 Aldy Hernandez <aldyh@redhat.com>
21708
21709 * opts.c (finish_options): Remove duplicate sorry.
21710
21711 2012-01-04 Aldy Hernandez <aldyh@redhat.com>
21712
21713 PR middle-end/51696
21714 * trans-mem.c (diagnose_tm_1): Display indirect calls with no name
21715 correctly.
21716
21717 2012-01-04 Richard Guenther <rguenther@suse.de>
21718
21719 PR middle-end/51750
21720 * tree.c (size_low_cst): New function.
21721 * tree.h (size_low_cst): Declare.
21722 * fold-const.c (fold_comparison): Use it to extract the low
21723 part of the POINTER_PLUS_EXPR offset.
21724
21725 2012-01-04 Georg-Johann Lay <avr@gjlay.de>
21726
21727 Fix clearing ZERO_REG
21728 * config/avr/avr.md (cc): Add alternative "ldi".
21729 (movqi_insn): Use it in cc attribute.
21730 * config/avr/avr.c (notice_update_cc): Handle CC_LDI.
21731 (output_reload_in_const): Use CLR to move 0 to ZERO_REG.
21732 (output_reload_insisf): Use ZERO_REG to pre-clear register.
21733
21734 2012-01-04 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
21735
21736 * configure: Regenerate.
21737
21738 2012-01-04 Richard Guenther <rguenther@suse.de>
21739
21740 PR tree-optimization/49651
21741 * tree-ssa-structalias.c (type_can_have_subvars): New function.
21742 (var_can_have_subvars): Use it.
21743 (get_constraint_for_1): Only consider subfields if there can be any.
21744
21745 2012-01-03 Jakub Jelinek <jakub@redhat.com>
21746
21747 PR bootstrap/51725
21748 * cselib.c (new_elt_loc_list): When moving locs from one cselib_val
21749 to its new canonical_cselib_val and the cselib_val was in
21750 first_containing_mem chain, but the canonical_cselib_val was not,
21751 add the latter into the chain.
21752 (cselib_invalidate_mem): Compare canonical_cselib_val of
21753 addr_list chain elt with v.
21754
21755 PR pch/51722
21756 * dwarf2out.c (dwarf2out_start_source_file, dwarf2out_define,
21757 dwarf2out_undef): Allocate e.info using ggc_strdup instead
21758 of xstrdup.
21759 (output_macinfo_op): Don't ggc_strdup fd->filename.
21760 (optimize_macinfo_range): Allocate grp_name using XALLOCAVEC,
21761 then ggc_strdup it. Don't free inc->info or cur->info.
21762 (output_macinfo): Don't free ref->info or file->info.
21763
21764 2012-01-03 Ira Rosen <irar@il.ibm.com>
21765
21766 PR tree-optimization/51269
21767 * tree-vect-loop-manip.c (set_prologue_iterations): Make
21768 first_niters a pointer.
21769 (slpeel_tree_peel_loop_to_edge): Likewise.
21770 (vect_do_peeling_for_loop_bound): Update call to
21771 slpeel_tree_peel_loop_to_edge.
21772 (vect_gen_niters_for_prolog_loop): Don't compute wide_prolog_niters
21773 here. Remove it from the parameters list.
21774 (vect_do_peeling_for_alignment): Update calls and compute
21775 wide_prolog_niters.
21776
21777 2012-01-03 Richard Guenther <rguenther@suse.de>
21778
21779 PR tree-optimization/51070
21780 * tree-loop-distribution.c (stmt_has_scalar_dependences_outside_loop):
21781 Properly handle calls.
21782
21783 2012-01-03 Richard Guenther <rguenther@suse.de>
21784
21785 PR tree-optimization/51692
21786 * tree-ssa-dce.c (eliminate_unnecessary_stmts): Do not remove
21787 the LHS of allocation stmts.
21788
21789 2012-01-03 Olivier Hainque <hainque@adacore.com>
21790
21791 * system.h: Prior to #define, #undef fopen and freopen unconditionally.
21792
21793 2012-01-03 Olivier Hainque <hainque@adacore.com>
21794
21795 * collect2.c (main): In AIX specific computations for vector
21796 insertions, use CONST_CAST2 to cast from char ** to const char **.
21797
21798 2012-01-03 Richard Guenther <rguenther@suse.de>
21799
21800 PR debug/51650
21801 * dwarf2out.c (dwarf2out_finish): Always create a DIE for
21802 the context of a limbo DIE when it does not already exist.
21803
21804 2012-01-03 Jakub Jelinek <jakub@redhat.com>
21805
21806 PR tree-optimization/51719
21807 * value-prof.c (gimple_ic): When indirect call isn't noreturn,
21808 but direct call is, clear direct call's lhs and don't add fallthrough
21809 edge from dcall_bb to join_bb and PHIs.
21810
21811 2012-01-03 Andreas Krebbel <Andreas.Krebbel@de.ibm.com>
21812
21813 * config/s390/s390.md ("*cmp<mode>_ccs"): Fix comment mentioning
21814 the instructions emitted by the pattern.
21815 ("*TDC_insn_<mode>"): Add comment.
21816
21817 2012-01-03 Richard Guenther <rguenther@suse.de>
21818
21819 PR middle-end/51730
21820 * fold-const.c (fold_comparison): Properly canonicalize
21821 tree offset and HOST_WIDE_INT bit position.
21822
21823 2012-01-02 Uros Bizjak <ubizjak@gmail.com>
21824
21825 * config/ia64/ia64.c (expand_vec_perm_broadcast): Use correct
21826 operands for extzv pattern.
21827
21828 2012-01-02 Jakub Jelinek <jakub@redhat.com>
21829
21830 PR bootstrap/51725
21831 * cselib.c (add_mem_for_addr): Call canonical_cselib_val
21832 on mem_elt first.
21833
21834 2012-01-02 Sandra Loosemore <sandra@codesourcery.com>
21835
21836 * doc/invoke.texi (-flto and related options): Copy-edit.
21837
21838 2012-01-02 Richard Sandiford <rdsandiford@googlemail.com>
21839
21840 * config/mips/mips.md (loadgp_newabi_<mode>): Add missing earlyclobber.
21841
21842 2012-01-02 Jakub Jelinek <jakub@redhat.com>
21843
21844 * config/i386/sse.md (*avx2_gatherdi<mode>_3, *avx2_gatherdi<mode>_4):
21845 New patterns.
21846
21847 2012-01-02 Richard Sandiford <rdsandiford@googlemail.com>
21848
21849 * expr.h (move_by_pieces_ninsns): Declare.
21850 * expr.c (move_by_pieces_ninsns): Make external.
21851 * config/mips/mips-protos.h (mips_move_by_pieces_p): Declare.
21852 (mips_store_by_pieces_p): Likewise.
21853 * config/mips/mips.h (MOVE_BY_PIECES_P): Call mips_move_by_pieces_p.
21854 (STORE_BY_PIECES_P): Likewise mips_store_by_pieces_p.
21855 * config/mips/mips.c (mips_move_by_pieces_p): New function.
21856 (mips_store_by_pieces_p): Likewise.
21857
21858 2012-01-02 Jakub Jelinek <jakub@redhat.com>
21859
21860 * passes.c (register_one_dump_file): Free full_name.
21861
21862 * reload1.c (reload): Don't allocate reg_max_ref_width here.
21863 (calculate_elim_costs_all_insns): Free offsets_at and
21864 offsets_known_at at the end and clear the pointers.
21865
21866 2012-01-02 Georg-Johann Lay <avr@gjlay.de>
21867
21868 * config/avr/avr.opt (-mbranch-cost): Fix double definition of
21869 this option introduced in r180739.
21870
21871 2012-01-02 Georg-Johann Lay <avr@gjlay.de>
21872
21873 PR target/51345
21874 * config.gcc (tm_file target=avr]): Add avr/avr-multilib.h
21875 (tmake_file target=avr): Add avr/t-multilib.
21876
21877 * config/avr/avr-c.c (avr_cpu_cpp_builtins): Use AVR_HAVE_8BIT_SP
21878 to built-in define __AVR_HAVE_8BIT_SP__, __AVR_HAVE_16BIT_SP__.
21879 * config/avr/genmultilib.awk: New file.
21880 * config/avr/t-multilib: New auto-generated file.
21881 * config/avr/multilib.h: New auto-generated file.
21882 * config/avr/t-avr (AVR_MCUS): New variable.
21883 (genopt.sh): Use it.
21884 (s-mlib): Depend on t-multilib.
21885 (t-multilib, multilib.h): New dependencies.
21886 (s-avr-mlib): New rule to build t-multilib, multilib.h from AVR_MCUS.
21887 (MULTILIB_OPTIONS): Remove.
21888 (MULTILIB_MATCHES): Remove.
21889 (MULTILIB_DIRNAMES): Remove.
21890 (MULTILIB_EXCEPTIONS): Remove:
21891 * config/avr/genopt.sh: Don't use hard coded file name;
21892 pass AVR_MCUS from t-avr instead.
21893
21894 2012-01-02 Georg-Johann Lay <avr@gjlay.de>
21895
21896 * config/avr/avr.c (avr_out_ashrpsi3): Fix "case 31" to "case 23".
21897
21898 2012-01-02 Georg-Johann Lay <avr@gjlay.de>
21899
21900 Implement light-weight DImode support.
21901 * config/avr/avr-dimode.md: New file.
21902 * config/avr/avr.md: Include it.
21903 (adjust_len): Add plus64, compare64.
21904 (HIDI): Remove code iterator.
21905 (code_stdname): New code attribute.
21906 (rotx, rotsmode): Remove DI.
21907 (rotl<mode>3, *rotw<mode>, *rotb<mode>): Use HISI instead of HIDI
21908 as code iterator.
21909 * config/avr/avr-protos.h (avr_have_dimode): New.
21910 (avr_out_plus64, avr_out_compare64): New.
21911 * config/avr/avr.c (avr_out_compare): Handle DImode.
21912 (avr_have_dimode): New variable definition and initialization.
21913 (avr_out_compare64, avr_out_plus64): New functions.
21914 (avr_out_plus_1): Use simplify_unary_operation to negate xval.
21915 (adjust_insn_length): Handle ADJUST_LEN_COMPARE64, ADJUST_LEN_PLUS64.
21916 (avr_compare_pattern): Skip DImode comparisons.
21917
21918 2012-01-02 Revital Eres <revital.eres@linaro.org>
21919
21920 * ddg.c (def_has_ccmode_p): New function.
21921 (add_cross_iteration_register_deps,
21922 create_ddg_dep_from_intra_loop_link): Call it.
21923
21924 2012-01-02 Richard Guenther <rguenther@suse.de>
21925
21926 PR other/51679
21927 * invoke.texi (fassociative-math): Remove spurious paranthesis.
21928
21929 2012-01-01 Jakub Jelinek <jakub@redhat.com>
21930
21931 * gcc.c (process_command): Update copyright notice dates.
21932 * gcov.c (print_version): Likewise.
21933 * gcov-dump.c (print_version): Likewise.
21934 * mips-tfile.c (main): Likewise.
21935 * mips-tdump.c (main): Likewise.
21936
21937 2012-01-01 Ira Rosen <irar@il.ibm.com>
21938
21939 PR tree-optimization/51704
21940 * tree-vect-slp.c (vect_detect_hybrid_slp_stmts): Check that
21941 a use is inside the basic block or loop before accessing its vect info.
21942
21943 2012-01-01 Jan Hubicka <jhjh@suse.cz>
21944
21945 PR rtl-optimization/51069
21946 * cfgloopmanip.c (remove_path): Removing path making irreducible
21947 region unconditional makes BB part of the region.
21948
21949 2012-01-01 Jakub Jelinek <jakub@redhat.com>
21950
21951 PR tree-optimization/51683
21952 * tree-ssa-propagate.c (substitute_and_fold): Don't optimize away
21953 calls with side-effects.
21954 * tree-ssa-ccp.c (ccp_fold_stmt): Likewise.
21955 \f
21956 Copyright (C) 2012 Free Software Foundation, Inc.
21957
21958 Copying and distribution of this file, with or without modification,
21959 are permitted in any medium without royalty provided the copyright
21960 notice and this notice are preserved.