OSDN Git Service

a89a8ff6943d4ad1117fa0a8f5ae1dbf3ce4ed5b
[pf3gnuchains/gcc-fork.git] / gcc / ChangeLog
1 2012-02-28  Georg-Johann Lay  <avr@gjlay.de>
2
3         * config/avr/builtins.def: New file.
4         * config/avr/t-avr (avr.o, avr-c.o): Depend on it.
5         * config/avr/avr.c (enum avr_builtin_id): Use it.
6         (avr_init_builtins): Use it. And use avr_bdesc.
7         (bdesc_1arg): Remove.
8         (bdesc_2arg): Remove.
9         (bdesc_3arg): Remove.
10         (struct avr_builtin_description): Add field n_args.
11         (avr_bdesc): New static variable using builtins.def.
12         (avr_expand_builtin): Use it.
13         Don't call avr_expand_delay_cycles if op0 is not CONST_INT.
14         (avr_fold_builtin): Fold AVR_BUILTIN_SWAP.
15         Don't fold AVR_BUILTIN_INSERT_BITS if arg0 is not INTEGER_CST.
16
17 2012-02-28  Georg-Johann Lay  <avr@gjlay.de>
18
19         PR target/52148
20         * config/avr/avr.md (movmem_<mode>): Replace match_operand that
21         match only one single hard register with respective hard reg rtx.
22         (movmemx_<mode>): Ditto.
23         * config/avr/avr.c (avr_emit_movmemhi): Adapt expanding to new
24         insn anatomy of movmem[x]_<mode>.
25         (avr_out_movmem): Same for printing assembler and operand usage.
26
27 2012-02-28  Georg-Johann Lay  <avr@gjlay.de>
28
29         PR target/49868
30         PR target/52261
31         * doc/extend.texi (AVR Named Address Spaces): No more try to fix
32         address spaces located outside of device flash.
33
34         * config/avr/avr.h (base_arch_s): Remove field n_segments.
35         (mcu_type_s): Add field n_flash.
36         * config/avr/avr-devices.c (avr_arch_types): Remove .n_segments.
37         Set .have_elpm and .have_elpmx to 1 for avrxmega4 and avrxmega5.
38         (AVR_MCU): Add N_FLASH argument.
39         * config/avr/avr-mcus.def (AVR_MCU): Add initializer for .n_flash.
40         * config/avr/avr-c.c (avr_cpu_cpp_builtins): Only define built-in
41         macro __FLASH<n> if that address space makes sense for the device.
42         * config/avr/avr.c (avr_out_lpm): Don't try to fix address spaces
43         outside of target flash.
44         (avr_asm_named_section): Ditto.
45         (avr_asm_select_section): Ditto.
46         (avr_addr_space_convert): Ditto.
47         (avr_emit_movmemhi): Ditto.
48         (avr_nonconst_pointer_addrspace, avr_pgm_check_var_decl): Error if
49         address space is outside of device flash.
50         (avr_insert_attributes): Ditto.
51         (avr_xload_libgcc_p): Use avr_current_device->n_flash instead of
52         avr_current_arch->n_segments.
53
54 2012-02-27  H.J. Lu  <hongjiu.lu@intel.com>
55
56         PR target/52352
57         * config/i386/i386.md (*movabs<mode>_1): Enable only for
58         TARGET_LP64.
59         (*movabs<mode>_2): Likewise.
60
61 2012-02-27  Jakub Jelinek  <jakub@redhat.com>
62
63         PR target/52375
64         * config/arm/neon.md (vashr<mode>3, vlshr<mode>3): Use
65         s_register_operand in the test instead of REG_P.  Don't call
66         gen_reg_rtx if it won't be used.
67
68         PR tree-optimization/52376
69         * ipa-split.c (split_function): Ignore CLOBBER stmts.
70
71 2012-02-27  Stuart Henderson  <shenders@gcc.gnu.org>
72
73         * ifcvt.c (noce_get_condition): Check condition variable is not
74         small_register_classes_for_mode_p before accepting.
75
76 2012-02-27  Uros Bizjak  <ubizjak@gmail.com>
77
78         * config/i386/i386.md (*movabs<mode>_1): Fix operand 1 constraints.
79
80 2012-02-27  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
81
82         Revert:
83         2012-01-09  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
84         * config/arm/arm-cores.def (cortex-a15): Use cortex_a15_tune for
85         tuning parameters.
86         * config/arm/arm.c (arm_cortex_a15_tune): New static variable.
87
88 2012-02-27  Oleg Endo  <olegendo@gcc.gnu.org>
89
90         * config/sh/sh.h: Delete dead GO_IF_LEGITIMATE_INDEX macro.
91
92 2012-02-26  Oleg Endo  <olegendo@gcc.gnu.org>
93
94         * config/sh/predicates.md: Remove blank lines.
95         * config/sh/sh.c: Fix typos in comments.
96         * config/sh/constraints.md: Likewise.
97         * config/sh/sh.md: Remove blank lines.
98         Fix typos in comments.  Use ;; as comment characters.
99
100 2012-02-26  Walter Lee  <walt@tilera.com>
101
102         * config/tilegx/tilegx.c (match_pcrel_step2): Fix instruction pattern.
103         (replace_mov_pcrel_step2): Ditto.
104
105 2012-02-25  Alexandre Oliva  <aoliva@redhat.com>
106
107         PR debug/52001
108         * alias.c (refs_newer_value_cb, refs_newer_value_p): New.
109         (get_addr): Walk canonical value's locs.  Avoid returning VALUEs
110         and locs that reference values newer than the non-canonical value
111         at hand.  Return the canonical value as a worst case.
112         (memrefs_conflict_p): Walk canonical value's locs.
113
114         PR debug/52001
115         * cselib.c (preserve_only_constants): Rename to...
116         (preserve_constants_and_equivs): ... this.  Split out...
117         (invariant_or_equiv_p): ... this.  Preserve plus expressions
118         of other preserved expressions too.
119         (cselib_reset_table): Adjust.
120         * var-tracking.c (reverse_op): Use canonical value to build
121         reverse operation.
122
123 2012-02-23  Kai Tietz  <ktietz@redhat.com>
124
125         * config/i386/i386.c (ix86_delegitimize_address): Handle
126         UNSPEC_PCREL plus displacement.
127
128 2012-02-24  Georg-Johann Lay  <avr@gjlay.de>
129
130         PR target/52261
131         * config/avr/avr.c (avr_out_movhi_mr_r_xmega): Use base
132         to test for unusedness in st X addressing.
133
134 2012-02-24  Richard Guenther  <rguenther@suse.de>
135
136         PR middle-end/52361
137         * gimple.c (walk_gimple_op): Use predicates with less redundant tests.
138         (is_gimple_reg_type): Move inline ...
139         * gimple.h (is_gimple_reg_type): ... here.
140
141 2012-02-24  Richard Guenther  <rguenther@suse.de>
142
143         PR middle-end/52361
144         * passes.c (execute_function_todo): When verifying SSA form
145         verify gimple form first.
146         * tree-ssa.c (verify_ssa): Do not verify gimple form here.
147
148 2012-02-24  Richard Guenther  <rguenther@suse.de>
149
150         PR middle-end/52355
151         * fold-const.c (fold_addr_of_array_ref_difference): New function.
152         (fold_binary_loc): Use it to extend the existing &a[i] - &a[j] folding.
153
154 2012-02-13  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
155
156         * tree-if-conv (predicate_scalar_phi): Commentary typo fix.
157
158 2012-02-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
159
160         * tree-phinodes.c (make_phi_node): Mark static.
161         * tree-flow.h (make_phi_node): Remove extern decl.
162         * doc/gimple.texi (make_phi_node): Remove documentation.
163
164 2012-02-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
165
166         * tree-into-ssa (update_ssa): Avoid trailing whitespace in dump_file.
167         * tree-ssa-sccvn.c (print_scc): Ditto.
168
169 2012-02-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
170
171         * doc/passes.texi (Full redundancy elimination): Fix typo.
172
173 2012-02-23  Bernhard Reutner-Fischer  <aldot@gcc.gnu.org>
174
175         * doc/invoke.texi (-fdse, -fdce): Remove duplicate entries.
176
177 2012-02-23  Eric Botcazou  <ebotcazou@adacore.com>
178
179         PR bootstrap/52287
180         * haifa-sched.c (rank_for_schedule): Stabilize sort for debug insns.
181
182 2012-02-23  Uros Bizjak  <ubizjak@gmail.com>
183
184         PR c/52290
185         * c-decl.c (start_function): Exit early if decl1 is not FUNTION_DECL.
186
187 2012-02-23  Georg-Johann Lay  <avr@gjlay.de>
188
189         * config/avr/avr.md (code_stdname): Add ior, xor.
190         (xior): New code iterator.
191         (*<code_stdname><mode>qi.byte0): Use xior instead of ior.
192         (*<code_stdname><mode>qi.byte1-3): Ditto.
193
194 2012-02-23  Jakub Jelinek  <jakub@redhat.com>
195
196         PR tree-optimization/52019
197         * ipa-split.c (find_return_bb, find_retval, visit_bb): Ignore
198         CLOBBER stmts.
199
200 2012-02-23  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
201
202         * acinclude.m4: Use HAVE_INITFINI_ARRAY_SUPPORT instead of
203         HAVE_INITFINI_ARRAY to work around namespace pollution in
204         certain versions of newlib system headers.
205         * config.in: Regenerate.
206         * configure: Regenerate.
207         * config/initfini-array.h: Use HAVE_INITFINI_ARRAY_SUPPORT
208         instead of HAVE_INITFINI_ARRAY.
209
210 2012-02-22  Uros Bizjak  <ubizjak@gmail.com>
211
212         PR target/52330
213         * config/i386/i386.c (ix86_print_operand) <case 'H'>: Error out if x
214         is not offsettable memory reference.
215
216 2012-02-22  Georg-Johann Lay  <avr@gjlay.de>
217
218         PR target/18145
219         * config/avr/avr.c (avr_asm_output_aligned_decl_common): Skip
220         setting avr_need_clear_bss_p for __gnu_lto* symbols.
221
222 2012-02-22  Georg-Johann Lay  <avr@gjlay.de>
223
224         * config/avr/avr.h (avr_accumulate_outgoing_args): Return int.
225         * config/avr/avr.c (avr_accumulate_outgoing_args): Return int.
226
227 2012-02-22  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
228
229         * configure.ac (LIB_TLS_SPEC): Enforce use of alternate thread
230         library on Solaris 8 even without TLS support.
231         * configure: Regenerate.
232
233 2012-02-22  Richard Guenther  <rguenther@suse.de>
234
235         PR middle-end/52329
236         * gimple-fold.c (fold_stmt_1): Also canonicalize ADDR_EXPRs
237         for GIMPLE_DEBUG stmts.
238
239 2012-02-22  Martin Jambor  <mjambor@suse.cz>
240
241         PR middle-end/51782
242         * emit-rtl.c (set_mem_attributes_minus_bitpos): Set address space
243         according to the base object.
244
245 2012-02-22  Georg-Johann Lay  <avr@gjlay.de>
246
247         PR rtl-optimization/50063
248         * config/avr/avr.md (movhi_sp_r): Handle -1 (unknown IRQ state)
249         and 2 (8-bit SP) in operand 2.
250         * config/avr/avr.c (avr_prologue_setup_frame): Adjust prologue
251         setup to use movhi_sp_r instead of vanilla move to write SP.
252         Adjust REG_CFA notes to superseed unspec.
253         (expand_epilogue): Adjust epilogue setup to use movhi_sp_r instead
254         of vanilla move.
255         As function body might contain CLI or SEI: Use irq_state 0 (IRQ
256         known to be off) only with TARGET_NO_INTERRUPTS. Never use
257         irq_state 1 (IRQ known to be on) here.
258
259 2012-02-21  Bernd Schmidt  <bernds@codesourcery.com>
260
261         * ira.c (check_allocation): Use REG_WORDS_BIG_ENDIAN, not
262         WORDS_BIG_ENDIAN.
263         * ira-color.c (setup_profitable_hard_regs, check_hard_reg_p,
264         assign_hard_reg): Likewise.
265
266 2012-02-21  Georg-Johann Lay  <avr@gjlay.de>
267
268         * config/avr/avr.md (neghi2): Remove "!d,0" alternative. Tweak "r,0".
269
270 2012-02-21  Georg-Johann Lay  <avr@gjlay.de>
271
272         * config/avr/avr.md
273         (*dec-and-branchhi!=-1.d.clobber): New text peephole.
274         (*dec-and-branchhi!=-1.l.clobber): New text peephole.
275
276 2012-02-21  Georg-Johann Lay  <avr@gjlay.de>
277
278         * config/avr/avr-protos.h (avr_accumulate_outgoing_args): Move
279         prototype from here to...
280         * config/avr/avr.h: ...here.
281
282 2012-02-21  Richard Earnshaw  <rearnsha@arm.com>
283
284         PR target/52294
285         * thumb2.md (thumb2_shiftsi3_short): Split register and
286         immediate shifts.  For register shifts tie operands 0 and 1.
287         (peephole2 for above): Check that register-controlled shifts
288         have suitably tied operands.
289
290 2012-02-21  Quentin Neill  <quentin.neill@amd.com>
291
292         PR target/52137
293         * config/i386/bdver1.md (bdver1_call, bdver1_push,
294         bdver1_pop, bdver1_leave, bdver1_lea, bdver1_imul_DI, bdver1_imul,
295         bdver1_imul_mem_DI, bdver1_imul_mem, bdver1_idiv, bdver1_idiv_mem,
296         bdver1_str, bdver1_idirect, bdver1_ivector, bdver1_idirect_loadmov,
297         bdver1_idirect_load, bdver1_ivector_load, bdver1_idirect_movstore,
298         bdver1_idirect_both, bdver1_ivector_both, bdver1_idirect_store,
299         bdver1_ivector_store, bdver1_fldxf, bdver1_fld, bdver1_fstxf,
300         bdver1_fst, bdver1_fist, bdver1_fmov_bdver1, bdver1_fadd_load,
301         bdver1_fadd, bdver1_fmul_load, bdver1_fmul, bdver1_fsgn,
302         bdver1_fdiv_load, bdver1_fdiv, bdver1_fpspc_load, bdver1_fpspc,
303         bdver1_fcmov_load, bdver1_fcmov, bdver1_fcomi_load,
304         bdver1_fcomi, bdver1_fcom_load, bdver1_fcom,
305         bdver1_fxch, bdver1_ssevector_avx128_unaligned_load,
306         bdver1_ssevector_avx256_unaligned_load,
307         bdver1_ssevector_sse128_unaligned_load,
308         bdver1_ssevector_avx128_load, bdver1_ssevector_avx256_load,
309         bdver1_ssevector_sse128_load, bdver1_ssescalar_movq_load,
310         bdver1_ssescalar_vmovss_load, bdver1_ssescalar_sse128_load,
311         bdver1_mmxsse_load, bdver1_sse_store_avx256, bdver1_sse_store,
312         bdver1_mmxsse_store_short, bdver1_ssevector_avx256,
313         bdver1_movss_movsd, bdver1_mmxssemov, bdver1_sselog_load_256,
314         bdver1_sselog_256, bdver1_sselog_load, bdver1_sselog,
315         bdver1_ssecmp_load, bdver1_ssecmp, bdver1_ssecomi_load,
316         bdver1_ssecomi, bdver1_vcvtX2Y_avx256_load, bdver1_vcvtX2Y_avx256,
317         bdver1_ssecvt_cvtss2sd_load, bdver1_ssecvt_cvtss2sd,
318         bdver1_sseicvt_cvtsi2sd_load, bdver1_sseicvt_cvtsi2sd,
319         bdver1_ssecvt_cvtpd2ps_load, bdver1_ssecvt_cvtpd2ps,
320         bdver1_ssecvt_cvtdq2ps_load, bdver1_ssecvt_cvtdq2ps,
321         bdver1_ssecvt_cvtdq2pd_load, bdver1_ssecvt_cvtdq2pd,
322         bdver1_ssecvt_cvtps2pd_load, bdver1_ssecvt_cvtps2pd,
323         bdver1_ssecvt_cvtsX2si_load, bdver1_ssecvt_cvtsX2si,
324         bdver1_ssecvt_cvtpd2pi_load, bdver1_ssecvt_cvtpd2pi,
325         bdver1_ssecvt_cvtpd2dq_load, bdver1_ssecvt_cvtpd2dq,
326         bdver1_ssecvt_cvtps2pi_load, bdver1_ssecvt_cvtps2pi,
327         bdver1_ssemuladd_load_256, bdver1_ssemuladd_256,
328         bdver1_ssemuladd_load, bdver1_ssemuladd, bdver1_sseimul_load,
329         bdver1_sseimul, bdver1_sseiadd_load, bdver1_sseiadd,
330         bdver1_ssediv_double_load_256, bdver1_ssediv_double_256,
331         bdver1_ssediv_single_load_256, bdver1_ssediv_single_256,
332         bdver1_ssediv_double_load, bdver1_ssediv_double,
333         bdver1_ssediv_single_load, bdver1_ssediv_single, bdver1_sseins):
334         Add "bdver2" attribute.
335
336 2012-02-21  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
337
338         * config/s390/s390.c (s390_option_override): Make -mhard-dfp the
339         default if possible and not specified otherwise.
340
341 2012-02-21  Richard Guenther  <rguenther@suse.de>
342
343         PR middle-end/52314
344         * gimplify.c (create_tmp_from_val): Use the main variant type
345         for the type of the temporary we create.
346
347 2012-02-21  Richard Guenther  <rguenther@suse.de>
348
349         PR tree-optimization/52324
350         * gimplify.c (gimplify_expr): When re-gimplifying expressions
351         do not gimplify a MEM_REF address operand if it is already
352         in suitable form.
353
354 2012-02-21  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
355
356         * config/s390/s390.md ("fixuns_trunc<mode>si2"): Replace
357         TARGET_HARD_FLOAT with TARGET_HARD_DFP.
358
359 2012-02-21  Richard Guenther  <rguenther@suse.de>
360
361         * tree-vect-stmts.c (vectorizable_load): Use pre-computed
362         nested_in_vect_loop.
363
364 2012-02-21  Jakub Jelinek  <jakub@redhat.com>
365
366         PR tree-optimization/52318
367         * gimple-fold.c (gimplify_and_update_call_from_tree): Add
368         vdef also to non-pure/const call stmts in the sequence.
369
370 2012-02-20  David S. Miller  <davem@davemloft.net>
371
372         * config/sparc/sparc.md (load_pcrel_sym<P:mode>): Explain why we
373         don't use the "rd %pc" instruction on v9 for PIC register loads.
374
375 2012-02-20  Aldy Hernandez  <aldyh@redhat.com>
376
377         PR middle-end/52141
378         * trans-mem.c (ipa_tm_scan_irr_block): Error out on GIMPLE_ASM's
379         in a transaction safe function.
380
381 2012-02-20  Kai Tietz  <ktietz@redhat.com>
382
383         PR target/52238
384         * stor-layout.c (place_field): Handle desired_align for
385         ms-bitfields, too.
386
387 2012-02-20  Richard Guenther  <rguenther@suse.de>
388
389         PR tree-optimization/52298
390         * tree-vect-stmts.c (vectorizable_store): Properly use
391         STMT_VINFO_DR_STEP instead of DR_STEP when vectorizing
392         outer loops.
393         (vectorizable_load): Likewise.
394         * tree-vect-data-refs.c (vect_analyze_data_ref_access):
395         Access DR_STEP after ensuring it is not NULL.
396
397 2012-02-20  Jakub Jelinek  <jakub@redhat.com>
398
399         PR tree-optimization/52286
400         * fold-const.c (fold_binary_loc): For (X & C1) | C2
401         optimization use double_int_to_tree instead of build_int_cst_wide,
402         rewrite to use double_int vars.
403
404 2012-02-20  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
405
406         PR target/50166
407         * acinclude.m4 (gcc_AC_INITFINI_ARRAY): Require gcc_SUN_LD_VERSION.
408         Define _start.
409         Remove -e 0 from $gcc_cv_ld invocation.
410         Only use __GLIBC_PREREQ if defined.
411         Enable on Solaris since Solaris 8 patch.
412         (gcc_SUN_LD_VERSION): New macro.
413         * configure.ac (ld_ver) <*-*-solaris2*>: Refer to
414         gcc_SUN_LD_VERSION for version number format.
415         * configure: Regenerate.
416         * varasm.c (get_elf_initfini_array_priority_section): Set
417         SECTION_NOTYPE for non-default priority.
418         Use get_section instead of get_unnamed_section to emit
419         .init_array/.fini_array with default priority.
420
421 2012-02-19  Richard Sandiford  <rdsandiford@googlemail.com>
422
423         * config/mips/mips.c (mips_need_mips16_rdhwr_p): New variable.
424         (mips_get_tp): Set it.  Record that __mips16_rdhwr binds locally.
425         (mips_start_unique_function, mips_output_mips16_rdhwr)
426         (mips_code_end): New functions.
427         (TARGET_ASM_CODE_END): Define.
428
429 2012-02-19  Richard Sandiford  <rdsandiford@googlemail.com>
430
431         * config/mips/mips.c (mips16_build_call_stub): Add CFI information
432         to stubs with non-sibling calls.
433
434 2012-02-18  Sandra Loosemore  <sandra@codesourcery.com>
435
436         * doc/invoke.texi (-fira-* options): Copy-edit.
437         (ira-* parameters): Copy-edit.
438
439 2012-02-17  Sandra Loosemore  <sandra@codesourcery.com>
440
441         * doc/invoke.texi: Minor copy-edits to bring into conformance with
442         GCC coding conventions.
443
444 2012-02-17  Sandra Loosemore  <sandra@codesourcery.com>
445
446         * doc/invoke.texi: Consistently hyphenate "big-endian"/"little-endian"
447         when used as adjectives.
448
449 2012-02-16  Sandra Loosemore  <sandra@codesourcery.com>
450
451         * doc/invoke.texi: Clean up "that"/"which" confusion.
452
453 2012-02-17  Steven Bosscher  <steven@gcc.gnu.org>
454
455         * system.h: Poison SMALL_REGISTER_CLASSES
456         * config/rl78/rl78.h: Replace SMALL_REGISTER_CLASSES with hook.
457         * config/rx/rx.h: Remove SMALL_REGISTER_CLASSES.
458
459 2012-02-16  Jakub Jelinek  <jakub@redhat.com>
460
461         PR tree-optimization/52285
462         * tree-tailcall.c (find_tail_calls): Ignore gimple_clobber_p stmts
463         when deciding if a call is a tail call or tail recursion.
464
465 2012-02-16  Kai Tietz  <ktietz@redhat.com>
466
467         * config/i386/i386.c (legitimate_pic_address_disp_p): Allow
468         interger-constant displacement for UNSPEC_PCREL.
469
470 2012-02-16  Jakub Jelinek  <jakub@redhat.com>
471
472         PR rtl-optimization/52208
473         * ira-costs.c (scan_one_insn): Don't decrease mem_cost
474         for MEMs with REG_EQUIV, if the MEM isn't general_operand.
475
476         PR tree-optimization/52255
477         * tree-vect-loop-manip.c (slpeel_tree_peel_loop_to_edge): If
478         loop->header has virtual PHI, but exit_e->dest doesn't, add
479         virtual PHI to exit_e->dest and adjust all uses after the loop.
480
481         PR debug/52260
482         * dwarf2out.c (copy_decls_walk): Fill in *slot before traversing
483         children with clone_tree_hash, not after it.
484
485 2012-02-16  Iain Sandoe  <iains@gcc.gnu.org>
486
487         * config/darwin.h (ASM_OUTPUT_LABELREF): Add user label prefix for
488         extended identifiers.
489
490 2012-02-16  Jakub Jelinek  <jakub@redhat.com>
491
492         PR middle-end/51929
493         * cgraphunit.c (verify_edge_corresponds_to_fndecl): If node is
494         a same_body_alias, also test whether e->callee isn't a former
495         or current clone of the decl this is a same body alias of.
496
497         PR translation/52264
498         * cgraphunit.c (verify_cgraph_node): Fix a typo.
499
500 2012-02-15  Sandra Loosemore  <sandra@codesourcery.com>
501
502         * doc/invoke.texi: Clean up "n-bit/byte/word" modifiers.
503
504 2012-02-15  Michael Meissner  <meissner@linux.vnet.ibm.com>
505
506         PR target/52199
507         * config/rs6000/rs6000.c (rs6000_expand_vector_init): Use
508         force_reg instead of copy_to_reg for better optimization.  Force
509         non-register or memory operands into a register.
510
511 2012-02-15  Andrew MacLeod  <amacleod@redhat.com>
512
513         * extend.texi: Reserve upper bits of memory model for future use.
514
515 2012-01-15  Georg-Johann Lay  <avr@gjlay.de>
516             Anatoly Sokolov <aesok@post.ru>
517             Eric Weddington <eric.weddington@atmel.com>
518
519         PR target/52261
520         * config/avr/avr-devices.c (avr_arch_types): Add avrxmega2,
521         avrxmega4, avrxmega5, avrxmega6, avrxmega7.
522         Rewrite initializers for .macro.
523         * config/avr/avr-mcus.def (AVR_MCU): Add known MCUs:
524         avrxmega2: atxmega16a4, atxmega16d4, atxmega16x1, atxmega32a4
525         atxmega32d4, atxmega32x1.
526         avrxmega4: atxmega64a3, atxmega64d3.
527         avrxmega5: atxmega64a1, atxmega64a1u.
528         avrxmega6: atxmega128a3, atxmega128d3, atxmega192a3, atxmega192d3,
529         atxmega256a3, atxmega256a3b, atxmega256a3bu, atxmega256d3.
530         avrxmega7: atxmega128a1, atxmega128a1u.
531         * config/avr/avr.h (enum avr_arch): Add: ARCH_AVRXMEGA2,
532         ARCH_AVRXMEGA4, ARCH_AVRXMEGA5, ARCH_AVRXMEGA6, ARCH_AVRXMEGA7.
533         (struct base_arch_s): Rename reserved to xmega_p.
534         Rename reserved2 to have_rampd.
535         (AVR_XMEGA): New define.
536         (AVR_HAVE_RAMPD, AVR_HAVE_RAMPX, AVR_HAVE_RAMPY): New defines.
537         (AVR_HAVE_RAMPZ): Change definition to fit xmega.
538         * config/avr/predicates.md (io_address_operand): Take into
539         account SFR offset.
540         (low_io_address_operand): Ditto.
541         (high_io_address_operand): Ditto.
542         * config/avr/avr.md (isa): Add alternatives no_xmega, xmega.
543         (enabled, movhi_sp_r): Use them.
544         * config/avr/avr-c.c (avr_cpu_cpp_builtins): Use
545         cpp_define_formatted to built-in define __AVR_ARCH__.
546         (__AVR_XMEGA__): New built-in define.
547         (__AVR_HAVE_RAMPD__): New built-in define.
548         (__AVR_HAVE_RAMPX__): New built-in define.
549         (__AVR_HAVE_RAMPY__): New built-in define.
550         (__AVR_HAVE_RAMPZ__): Change condition when to built-in define it.
551
552         * config/avr/avr.c (avr_addr_t): Add ccp, rampd, rampx, rampy.
553         (avr_option_override): Initialize them.
554         (sreg_rtx, rampd_rtx, rampx_rtx, rampy_rtx): New GTY rtx.
555         (avr_init_expanders): Initialize them. No more block several calls.
556         (emit_push_sfr): New static function.
557         (avr_prologue_setup_frame): Use it to push SREG, RAMPD/X/Y/Z as needed.
558         Handle AVR_XMEGA.
559         (expand_epilogue): Handle AVR_XMEGA. Pop RAMPD/X/Y/Z as needed.
560         (avr_print_operand): Print addreeses as symbols for
561         RAMPX, RAMPY, RAMPD, CCP.
562         (output_movhi): Handle AVR_XMEGA when writing to SP.
563         (avr_out_movhi_mr_r_xmega): New static function.
564         (out_movhi_mr_r): Forward to avr_out_movhi_mr_r_xmega for AVR_XMEGA.
565         (avr_file_start): Print symbol defines for __RAMPX__,  __RAMPY__,
566         __RAMPD__,  __CCP__ as needed.
567
568         * config/avr/multilib.h: Regenerate.
569         * config/avr/t-multilib: Regenerate.
570         * config/avr/avr-tables.opt: Regenerate.
571
572 2012-02-15  Tobias Grosser <grosser@fim.uni-passau.de>
573
574         PR tree-optimization/50561
575         * graphite-flattening.c (lst_project_loop): Do not
576         remove old scattering dimensions after flattening.
577         (lst_do_flatten): Likewise.
578
579 2012-02-15  Georg-Johann Lay  <avr@gjlay.de>
580
581         * doc/extend.texi (AVR Built-in Functions): Remove doc for
582         __builtin_avr_map8, __builtin_avr_map16.
583         Document __builtin_avr_insert_bits.
584
585         * config/avr/avr.md (map_bitsqi, map_bitshi): Remove.
586         (insert_bits): New insn.
587         (adjust_len.map_bits): Rename to insert_bits.
588         (UNSPEC_MAP_BITS): Rename to UNSPEC_INSERT_BITS.
589         * avr-protos.h (avr_out_map_bits): Remove.
590         (avr_out_insert_bits, avr_has_nibble_0xf): New.
591         * config/avr/constraints.md (Cxf,C0f): New.
592         * config/avr/avr.c (avr_cpu_cpp_builtins): Remove built-in
593         defines __BUILTIN_AVR_MAP8, __BUILTIN_AVR_MAP16.
594         New built-in define __BUILTIN_AVR_INSERT_BITS.
595         * config/avr/avr.c (TARGET_FOLD_BUILTIN): New define.
596         (enum avr_builtin_id): Add AVR_BUILTIN_INSERT_BITS.
597         (avr_move_bits): Rewrite.
598         (avr_fold_builtin, avr_map_metric, avr_map_decompose): New static
599         functions.
600         (avr_map_op_t): New typedef.
601         (avr_map_op): New static variable.
602         (avr_out_insert_bits, avr_has_nibble_0xf): New functions.
603         (adjust_insn_length): Handle ADJUST_LEN_INSERT_BITS.
604         (avr_init_builtins): Add definition for __builtin_avr_insert_bits.
605         (bdesc_3arg, avr_expand_triop_builtin): New.
606         (avr_expand_builtin): Use them. And handle AVR_BUILTIN_INSERT_BITS.
607         (avr_revert_map, avr_swap_map, avr_id_map, avr_sig_map): Remove.
608         (avr_map_hamming_byte, avr_map_hamming_nonstrict): Remove.
609         (avr_map_equal_p, avr_map_sig_p): Remove.
610         (avr_out_swap_bits, avr_out_revert_bits, avr_out_map_bits): Remove.
611         (bdesc_2arg): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
612         (adjust_insn_length): Remove handling for ADJUST_LEN_MAP_BITS.
613         (enum avr_builtin_id): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
614         (avr_init_builtins): Remove __builtin_avr_map8, __builtin_avr_map16.
615         (avr_expand_builtin): Remove AVR_BUILTIN_MAP8, AVR_BUILTIN_MAP16.
616
617 2012-02-14  Bernd Schmidt  <bernds@codesourcery.com>
618
619         * config/c6x/c6x.md (reserve_cycles): New attribute.
620         * config/c6x/c6x.c (c6x_sched_reorder_1): Ensure insns we predicate
621         don't reserve functional units after the branch occurs.
622
623 2012-02-14  Aldy Hernandez  <aldyh@redhat.com>
624
625         PR middle-end/52142
626         * ipa-inline.c (can_inline_edge_p): Do not inline tm_pure
627         functions into non-tm_pure functions.
628
629 2012-02-14  Eric Botcazou  <ebotcazou@adacore.com>
630
631         PR lto/52178
632         * gimple.c (iterative_hash_gimple_type): Use RECORD_OR_UNION_TYPE_P.
633         (iterative_hash_canonical_type): Likewise.
634         * tree-ssa-pre.c (fini_pre): Clean up the CFG only after purging all
635         the dead edges.
636
637 2012-02-14  Bernd Schmidt  <bernds@codesourcery.com>
638
639         * haifa-sched.c (prune_ready_list): Ensure that if there is a
640         sched-group insn, it either remains alone or the entire list is pruned.
641
642 2012-02-14  Jonathan Wakely  <jwakely.gcc@gmail.com>
643
644         * doc/install.texi (Prerequisites): Fix grammar.
645         (Configuration): Likewise.
646
647 2012-02-14  Jonathan Wakely  <jwakely.gcc@gmail.com>
648
649         * doc/install.texi (Prerequisites): Suggest building GMP, MPFR and
650         MPC as part of GCC before describing configuring with --with-gmp etc.
651         (Installing GCC: Configuration): --with-gmp etc. aren't needed if
652         sources are present.
653
654 2012-02-14  Jakub Jelinek  <jakub@redhat.com>
655
656         PR debug/51950
657         * dwarf2out.c (clone_tree_hash): New function.
658         (copy_decls_walk): Use it instead of clone_tree.
659
660 2012-02-14  Richard Guenther  <rguenther@suse.de>
661
662         PR tree-optimization/52244
663         PR tree-optimization/51528
664         * tree-sra.c (analyze_access_subtree): Only create INTEGER_TYPE
665         replacements for integral types.
666
667 2012-02-14  Walter Lee  <walt@tilera.com>
668
669         * config.gcc: Handle tilegx and tilepro.
670         * configure.ac (gcc_cv_as_dwarf2_debug_line): Enable test for
671         tilegx and tilepro.
672         Add HAVE_AS_TLS check for tilegx and tilepro.
673         * configure: Regenerate.
674         * doc/contrib.texi: Add Mat Hostetter and self.
675         * doc/extend.texi (TILE-Gx Built-in Functions): New node.
676         Document instruction intrinsics and network accessing intrinsics.
677         (TILEPro Built-in Functions): New node.  Document instruction
678         intrinsics and network accessing intrinsics.
679         * doc/install.texi (Specific, tilegx-*-linux*): Document it.
680         (Specific, tilepro-*-linux*): Likewise.
681         * doc/invoke.texi (TILE-Gx Options): New section.
682         (TILEPro Options): New section.
683         * doc/md.texi (TILE-Gx): New section.
684         (TILEPro): New section.
685         * common/config/tilegx/tilegx-common.c: New file.
686         * common/config/tilepro/tilepro-common.c: New file.
687         * config/tilegx/constraints.md: New file.
688         * config/tilegx/linux.h: New file.
689         * config/tilegx/mul-tables.c: New file.
690         * config/tilegx/predicates.md: New file.
691         * config/tilegx/sync.md: New file.
692         * config/tilegx/t-tilegx: New file.
693         * config/tilegx/tilegx-builtins.h: New file.
694         * config/tilegx/tilegx-c.c: New file.
695         * config/tilegx/tilegx-generic.md: New file.
696         * config/tilegx/tilegx-modes.def: New file.
697         * config/tilegx/tilegx-multiply.h: New file.
698         * config/tilegx/tilegx-protos.h: New file.
699         * config/tilegx/tilegx.c: New file.
700         * config/tilegx/tilegx.h: New file.
701         * config/tilegx/tilegx.md: New file.
702         * config/tilegx/tilegx.opt: New file.
703         * config/tilepro/constraints.md: New file.
704         * config/tilepro/gen-mul-tables.cc: New file.
705         * config/tilepro/linux.h: New file.
706         * config/tilepro/mul-tables.c: New file.
707         * config/tilepro/predicates.md: New file.
708         * config/tilepro/t-tilepro: New file.
709         * config/tilepro/tilepro-builtins.h: New file.
710         * config/tilepro/tilepro-c.c: New file.
711         * config/tilepro/tilepro-generic.md: New file.
712         * config/tilepro/tilepro-modes.def: New file.
713         * config/tilepro/tilepro-multiply.h: New file.
714         * config/tilepro/tilepro-protos.h: New file.
715         * config/tilepro/tilepro.c: New file.
716         * config/tilepro/tilepro.h: New file.
717         * config/tilepro/tilepro.md: New file.
718         * config/tilepro/tilepro.opt: New file.
719
720 2012-02-14  Jakub Jelinek  <jakub@redhat.com>
721
722         PR tree-optimization/52210
723         * tree-vect-slp.c (vect_get_and_check_slp_defs): Call
724         vect_model_simple_cost with two entry vect_def_type array instead
725         of an address of dt.
726
727 2012-02-14  Richard Guenther  <rguenther@suse.de>
728
729         PR lto/52178
730         * tree-streamer-in.c (lto_input_ts_field_decl_tree_pointers):
731         Do not stream DECL_QUALIFIER.
732         * tree-streamer-out.c (write_ts_field_decl_tree_pointers): Likewise.
733         * tree.c (free_lang_data_in_decl): Free DECL_QUALIFIER.
734         (find_decls_types_r): Do not walk DECL_QUALIFIER.
735
736 2012-02-14  Jakub Jelinek  <jakub@redhat.com>
737
738         PR c/52181
739         * c-decl.c (merge_decls): Copy DECL_USER_ALIGN bit from olddecl to
740         newdecl.
741
742 2012-02-13  Jakub Jelinek  <jakub@redhat.com>
743
744         PR bootstrap/52172
745         * cselib.h (cselib_subst_to_values_from_insn): New prototype.
746         * cselib.c (cselib_subst_to_values_from_insn): New function.
747         * sched-deps.c (add_insn_mem_dependence,
748         sched_analyze_1, sched_analyze_2): Use it.
749
750 2012-02-13  Jan Hubicka  <jh@suse.cz>
751
752         PR middle-end/52214
753         * predict.c (predict_paths_for_bb): Fix thinko in prevoius patch.
754
755 2012-02-13  Eric Botcazou  <ebotcazou@adacore.com>
756
757         * gcc.c (LINK_COMMAND_SPEC): Deal with -fgnu-tm.
758         (GTM_SELF_SPECS): Define if not already defined.
759         (driver_self_specs): Add GTM_SELF_SPECS.
760         * config/darwin.h (LINK_COMMAND_SPEC_A): Deal with -fgnu-tm.
761         (GTM_SELF_SPECS): Define.
762         * config/i386/cygwin.h (GTM_SELF_SPECS): Likewise.
763         * config/i386/mingw32.h (GTM_SELF_SPECS): Likewise.
764
765 2012-02-13  Jakub Jelinek  <jakub@redhat.com>
766
767         * cselib.c (expand_loc): Return sp, fp, hfp or cfa base reg right
768         away if seen.
769
770         * cselib.c (dump_cselib_val): Don't assume l->setting_insn is non-NULL.
771
772         PR middle-end/52230
773         * omp-low.c (expand_omp_for): If a static schedule without chunk size
774         has NULL region->cont, force fd.chunk_size to be integer_zero_node.
775
776 2012-02-13  Andrew MacLeod  <amacleod@redhat.com>
777
778         PR c/52190
779         * doc/extend.texi : Fix another __atomic_compare_exchange typo.
780
781 2012-02-13  Richard Guenther  <rguenther@suse.de>
782
783         PR translation/52211
784         * passes.c (enable_disable_pass): Fix typo.
785
786 2012-02-13  Jakub Jelinek  <jakub@redhat.com>
787
788         PR middle-end/52209
789         * expr.c (expand_expr_real_2) <case BIT_NOT_EXPR>: Only expand using
790         XOR for reduce_bit_field if type is unsigned.
791
792 2012-02-12  Eric Botcazou  <ebotcazou@adacore.com>
793
794         * config/sparc/sparc.h (CANNOT_CHANGE_MODE_CLASS): In 64-bit mode,
795         disallow changes from SFmode to mode with different size in FP regs.
796
797 2012-02-12  Robert Millan  <rmh@gnu.org>
798             Gerald Pfeifer <gerald@pfeifer.com>
799
800         * ginclude/stddef.h [__FreeBSD_kernel__] (__size_t): Do not define.
801         Tweak comment.
802
803 2012-02-11  Richard Sandiford  <rdsandiford@googlemail.com>
804
805         PR rtl-optimization/52175
806         * reorg.c (fill_slots_from_thread): Don't apply add/sub optimization
807         to frame-related instructions.
808
809 2012-02-10  Jason Merrill  <jason@redhat.com>
810
811         PR c++/51910
812         * tlink.c (demangled_hash_entry): Change mangled to a VEC.
813         (demangle_new_symbols): Fill it.
814         (scan_linker_output): Walk it.
815         (start_tweaking): Split out from scan_linker_output.
816         (maybe_tweak): Update sym->chosen.
817         * Makefile.in (COLLECT2_OBJS): Add vec.o and gcc-none.o
818
819 2012-02-11  Jakub Jelinek  <jakub@redhat.com>
820
821         PR debug/52132
822         * reg-stack.c (subst_stack_regs_in_debug_insn): Don't use get_true_reg.
823
824 2012-02-11  Uros Bizjak  <ubizjak@gmail.com>
825
826         * compare-elim.c (find_comparisons_in_bb): Eliminate only compares
827         having the same mode as previous compare.
828
829 2012-02-10  Eric Botcazou  <ebotcazou@adacore.com>
830
831         * config/sparc/sparc.c (sparc_flat_expand_prologue): Use emit_use.
832         * config/sparc/sparc.md (UNSPECV_GOTO): Delete.
833         (nonlocal_goto_internal): Likewise.
834         (nonlocal_goto): Emit a use and an indirect jump directly.
835
836 2012-02-10  Andrew MacLeod  <amacleod@redhat.com>
837
838         PR c/52190
839         * doc/extend.texi : Update comments for __atomic_compare_exchange and
840         __atomic_{is,always}_lock_free.
841
842 2012-02-10  Uros Bizjak  <ubizjak@gmail.com>
843
844         PR target/52146
845         * config/i386/i386.c (ix86_legitimate_address_p): Disallow
846         negative constant address for x32.
847
848 2012-02-10  Richard Henderson  <rth@redhat.com>
849
850         * tree-ssa-dce.c (propagate_necessity): Handle GIMPLE_TRANSACTION.
851         * tree-ssa-operands.c (parse_ssa_operands): Add virtual operands
852         for GIMPLE_TRANSACTION.  Tidy if's into a switch.
853
854 2012-02-10  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
855             Ira Rosen  <irar@il.ibm.com>
856
857         PR tree-optimization/50031
858         * targhooks.c (default_builtin_vectorization_cost): Handle
859         vec_promote_demote.
860         * target.h (enum vect_cost_for_stmt): Add vec_promote_demote.
861         * tree-vect-loop.c (vect_get_single_scalar_iteraion_cost): Handle
862         all types of reduction and pattern statements.
863         (vect_estimate_min_profitable_iters): Likewise.
864         * tree-vect-stmts.c (vect_model_promotion_demotion_cost): New function.
865         (vect_get_load_cost): Use vec_perm for permutations; add dump logic
866         for explicit realigns.
867         (vectorizable_conversion): Call vect_model_promotion_demotion_cost.
868         * config/spu/spu.c (spu_builtin_vectorization_cost): Handle
869         vec_promote_demote.
870         * config/i386/i386.c (ix86_builtin_vectorization_cost): Likewise.
871         * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost): Update
872         vec_perm for VSX and handle vec_promote_demote.
873
874 2012-02-10  Jakub Jelinek  <jakub@redhat.com>
875
876         PR middle-end/52177
877         * builtins.c (fold_builtin_atomic_always_lock_free,
878         expand_builtin_atomic_always_lock_free,
879         fold_builtin_atomic_is_lock_free, expand_builtin_atomic_is_lock_free):
880         Return and/or test boolean_true_node/boolean_false_node instead of
881         integer_one_node/integer_zero_node.
882
883 2012-02-10  Jan Hubicka  <jh@suse.cz>
884
885         PR middle-end/48600
886         * predict.c (predict_paths_for_bb): Prevent looping.
887         (predict_paths_leading_to_edge, predict_paths_leading_to): Update.
888
889 2012-02-10  Roman Zhuykov  <zhroma@ispras.ru>
890
891         * config/arm/arm.c (output_move_double): In one case properly
892         count number of instructions that will be emitted.
893
894 2012-02-10  Richard Guenther  <rguenther@suse.de>
895
896         PR translation/52193
897         * cgraphunit.c (cgraph_mark_functions_to_output): Fix typo.
898
899 2012-02-09  Peter Bergner  <bergner@vnet.ibm.com>
900
901         PR middle-end/52140
902         * dojump.c (do_compare_rtx_and_jump): Use SCALAR_FLOAT_MODE_P.
903
904 2012-02-09  Jakub Jelinek  <jakub@redhat.com>
905
906         PR debug/52165
907         * var-tracking.c (emit_note_insn_var_location): If
908         EMIT_NOTE_BEFORE_INSN and insn is NOTE_INSN_CALL_ARG_LOCATION,
909         emit it before next non-NOTE_INSN_CALL_ARG_LOCATION
910         non-NOTE_DURING_CALL_P insn.
911
912 2012-02-09  Bin Cheng  <bin.cheng@arm.com>
913
914         PR middle-end/51867
915         * builtins.c (expand_builtin): Don't check DECL_ASSEMBLER_NAME_SET_P.
916
917 2012-02-08  Magnus Granberg  <zorry@gentoo.org>
918
919         PR driver/48524
920         * gcc.c (switch_matches) Support switches with separated form,
921         -D and -U.
922
923 2012-02-08  Georg-Johann Lay  <avr@gjlay.de>
924
925         * config/avr/avr.md (SREG_ADDR): Remove constant definition.
926         (SP_ADDR): Ditto.
927         (RAMPZ_ADDR): Ditto.
928         * config/avr/avr.c (avr_addr_t): New typedef.
929         (avr_addr): New struct to hold RAM address of SPL, SPH, RAMPZ, SREG.
930         (avr_init_expanders): Initialize it.
931         (expand_prologue): Use avr_addr instead of RAMPZ_ADDR, SP_ADDR,
932         SREG_ADDR.
933         (expand_epilogue): Ditto.
934         (avr_print_operand): Ditto.
935         (avr_file_start): Ditto.
936         (avr_emit_movmemhi): Ditto.
937
938 2012-02-08  Richard Guenther  <rguenther@suse.de>
939
940         PR tree-optimization/46886
941         * tree-flow.h (do_while_loop_p): Declare.
942         * tree-ssa-loop-ch.c (do_while_loop_p): Export.
943         * tree-parloops.c (parallelize_loops): Only parallelize do-while loops.
944
945 2012-02-08  Andrew MacLeod  <amacleod@redhat.com>
946
947         * optabs.c (expand_atomic_load): Do not assume compare_and_swap will
948         always succeed for integers larger than a native word.
949
950 2012-02-08  Richard Guenther  <rguenther@suse.de>
951
952         PR rtl-optimization/52170
953         * simplify-rtx.c (simplify_plus_minus): Use CONSTM1_RTX to
954         properly handle integer vector modes.
955
956 2012-02-08  Jakub Jelinek  <jakub@redhat.com>
957
958         PR gcov-profile/52150
959         * coverage.c: Include target.h.
960         (build_var): Call targetm.strip_name_encoding on the assembler name.
961         Change one _ into . or $ if the target allows it.
962         * Makefile.in (coverage.o): Depend on $(TARGET_H).
963
964         PR rtl-optimization/52139
965         * cfgrtl.c (cfg_layout_merge_blocks): If BB_END
966         is a BARRIER after emit_insn_after_noloc, move BB_END
967         to the last non-BARRIER insn before it.
968
969 2012-02-07  Richard Sandiford  <rdsandiford@googlemail.com>
970
971         PR middle-end/24306
972         * config/mips/mips.c (mips_std_gimplify_va_arg_expr): New function.
973         (mips_gimplify_va_arg_expr): Call it instead of
974         std_gimplify_va_arg_expr.
975
976 2012-02-07  Michael Meissner  <meissner@linux.vnet.ibm.com>
977
978         * config/rs6000/rs6000.c (rs6000_trampoline_init): Fix error
979         message for -mno-pointers-to-nested-function.
980
981 2012-02-07  Eric Botcazou  <ebotcazou@adacore.com>
982
983         PR middle-end/51994
984         * expr.c (get_inner_reference): If there is an offset, add a negative
985         bit position to it (if any).
986
987 2012-02-07  Jakub Jelinek  <jakub@redhat.com>
988
989         PR rtl-optimization/52060
990         * combine.c (try_combine): Add i0src_copy and i0src_copy2 variables,
991         copy i1src to i1src_copy whenever added_sets_2 && i1_feeds_i2_n already
992         before i1dest -> i1src substitution in newpat, copy i0src to i0src_copy
993         and/or i0src_copy2 when needed.
994
995 2012-02-07  Jakub Jelinek  <jakub@redhat.com>
996
997         * gcc.c (main): Don't look for lto-wrapper or lto-wrapper
998         or LTOPLUGINSONAME if have_c.
999
1000         * config/freebsd-spec.h: Add comment about what macros can be defined
1001         in this header.
1002         (LINK_EH_SPEC, LINK_SSP_SPEC, USE_LD_AS_NEEDED): Don't define here.
1003         * config/freebsd.h (LINK_EH_SPEC, LINK_SSP_SPEC, USE_LD_AS_NEEDED): But
1004         here instead.
1005
1006 2012-02-07  Richard Guenther  <rguenther@suse.de>
1007
1008         * gimple-pretty-print.c (dump_gimple_phi): Avoid excessive
1009         newline in -alias dumps.
1010
1011 2012-02-07  Kai Tietz  <ktietz@redhat.com>
1012             Dave Korn  <dave.korn.cygwin@gmail.com>
1013
1014         PR target/40068
1015         * config/i386/winnt-cxx.c (i386_pe_adjust_class_at_definition):
1016         Take care that typinfo gets dllexport-attribute.
1017
1018 2012-02-07  Jakub Jelinek  <jakub@redhat.com>
1019
1020         PR middle-end/52074
1021         * expr.c (expand_expr_addr_expr_1): For CONSTANT_CLASS_P or CONST_DECL
1022         if modifier < EXPAND_SUM call force_operand on the result.
1023
1024 2012-02-07  Joern Rennecke  <joern.rennecke@embecosm.com>
1025
1026         * config/epiphany/epiphany.h (ASM_DECLARE_FUNCTION_SIZE): Redefine,
1027         adding __forwarder_dst__ prefix if a forwarder_section attribute is
1028         present.
1029         (epiphany_function_type): Replace types for specific interrupts with
1030         EPIPHANY_FUNCTION_INTERRUPT.
1031         (EPIPHANY_INTERRUPT_P): Update.
1032         * config/epiphany/epiphany.c (epiphany_handle_forwarder_attribute):
1033         New static function.
1034         (epiphany_attribute_table) <interrupt>: min_len is 0, max_len is 9.
1035         <disinterrupt>: Affects type identity.
1036         (epiphany_handle_interrupt_attribute): Handle variable number of
1037         arguments.
1038         (epiphany_compute_function_type): Update for new
1039         epiphany_function_type definition.
1040         (epiphany_expand_prologue): Don't save (reg:DI GPR_0) for interrupt
1041         handlers with a longcall forwarder.
1042         (epiphany_start_function): Handle multiple interrupt arguments and/or
1043         forwarder_section attribute.
1044
1045         * config/epiphany/epiphany.h (LIB_SPEC): Link libc again after
1046         libgloss.
1047
1048 2012-02-07  Alan Modra  <amodra@gmail.com>
1049
1050         PR target/52107
1051         * config/rs6000/rs6000.c (rs6000_emit_move): Don't create DImode
1052         subregs of TFmode.
1053
1054 2012-02-06  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
1055
1056         PR tree-optimization/50969
1057         * tree-vect-stmts.c (vect_model_store_cost): Correct statement cost to
1058         use vec_perm rather than vector_stmt.
1059         (vect_model_load_cost): Likewise.
1060         * config/i386/i386.c (ix86_builtin_vectorization_cost): Change cost of
1061         vec_perm to be the same as other vector statements.
1062         * config/rs6000/rs6000.c (rs6000_builtin_vectorization_cost): Revise
1063         cost of vec_perm for TARGET_VSX.
1064
1065 2012-02-06  Richard Guenther  <rguenther@suse.de>
1066
1067         PR tree-optimization/52115
1068         * tree-sra.c (access_has_replacements_p): New function.
1069         (sra_modify_assign): Use it to decide whether a use is uninitialized.
1070
1071 2012-02-06  Patrick Marlier  <patrick.marlier@gmail.com>
1072
1073         PR middle-end/52047
1074         * trans-mem.c (expand_call_tm): Add an assertion.
1075         * calls.c (flags_from_decl_or_type): Add ECF_TM_PURE to 'no vops'
1076         functions.
1077
1078 2012-02-06  Richard Guenther  <rguenther@suse.de>
1079
1080         PR tree-optimization/50955
1081         * tree-ssa-loop-ivopts.c (get_computation_cost_at): Artificially
1082         raise cost of expressions that replace an address with an
1083         expression based on a different pointer.
1084
1085 2012-02-06  Jakub Jelinek  <jakub@redhat.com>
1086
1087         PR target/52129
1088         * calls.c (mem_overlaps_already_clobbered_arg_p): If val is
1089         CONST_INT_P, subtract resp. add crtl->args.pretend_args_size to it.
1090
1091 2012-02-06  Jonathan Wakely  <jwakely.gcc@gmail.com>
1092
1093         PR c++/48680
1094         * doc/invoke.texi (C++ Dialect Options): Use @option markup for
1095         -Weffc++ and specify guidelines come from second edition.
1096
1097 2012-02-05  Richard Sandiford  <rdsandiford@googlemail.com>
1098
1099         * config/mips/mips.md (sibcall_internal, sibcall_value_internal)
1100         (sibcall_value_multiple_internal, call_split, call_internal_direct)
1101         (call_direct_split, call_value_split, call_value_internal_direct)
1102         (call_value_direct_split, call_value_multiple_split): Use jal and
1103         jal_macro attributes.
1104
1105 2012-02-05  Richard Sandiford  <rdsandiford@googlemail.com>
1106
1107         * reload1.c (reload_regs_reach_end_p): Replace with...
1108         (reload_reg_rtx_reaches_end_p): ...this function.
1109         (new_spill_reg_store): Update commentary.
1110         (emit_input_reload_insns): Don't clear new_spill_reg_store here.
1111         (emit_output_reload_insns): Check reload_reg_rtx_reaches_end_p
1112         before setting new_spill_reg_store.
1113         (emit_reload_insns): Use a separate loop to clear new_spill_reg_store.
1114         Use reload_reg_rtx_reaches_end_p instead of reload_regs_reach_end_p.
1115         Also use reload_reg_rtx_reaches_end_p when reading new_spill_reg_store
1116         for non-spill reload registers.
1117
1118 2012-02-05  Ira Rosen  <irar@il.ibm.com>
1119
1120         PR tree-optimization/52091
1121         * tree-vectorizer.h (vect_is_simple_use): Add an argument.
1122         (vect_is_simple_use_1): Likewise.
1123         * tree-vect-loop.c (vectorizable_reduction): Update calls
1124         to vect_is_simple_use_1 and vect_is_simple_use.
1125         (vectorizable_live_operation): Likewise.
1126         * tree-vect-patterns.c (widened_name_p,
1127         vect_recog_vector_vector_shift_pattern, check_bool_pattern): Likewise.
1128         * tree-vect-stmts.c (process_use, vect_get_vec_def_for_operand,
1129         vectorizable_call, vectorizable_conversion, vectorizable_assignment,
1130         vectorizable_shift,vectorizable_operation, vectorizable_store,
1131         vectorizable_load): Likewise.
1132         (vect_is_simple_cond): Add an argument, pass it to
1133         vect_is_simple_use_1.
1134         (vectorizable_condition): Update calls to vect_is_simple_cond,
1135         vect_is_simple_use.
1136         (vect_is_simple_use): Add an argument, the statement in which
1137         OPERAND is used.  Check that if OPERAND's def stmt is a double
1138         reduction phi node, the use is a phi node too.
1139         (vect_is_simple_use_1): Add an argument, pass it to
1140         vect_is_simple_use.
1141         * tree-vect-slp.c (vect_get_and_check_slp_defs): Update a call
1142         to vect_is_simple_use.
1143
1144 2012-02-04  Jakub Jelinek  <jakub@redhat.com>
1145
1146         PR rtl-optimization/52095
1147         * modulo-sched.c (dump_insn_locator): New function.
1148         (loop_canon_p, sms_schedule): Use it.
1149
1150         PR rtl-optimization/52113
1151         * lower-subreg.c (decompose_multiword_subregs): Call recog_memoized
1152         even for decomposable shift/zext insns.
1153
1154 2012-02-03  Jakub Jelinek  <jakub@redhat.com>
1155             Zdenek Dvorak  <ook@ucw.cz>
1156
1157         PR rtl-optimization/52092
1158         * loop-unswitch.c (unswitch_single_loop): Call copy_rtx_if_shared
1159         on get_iv_value result.
1160
1161 2012-02-02  Andrew Pinski  <apinski@cavium.com>
1162
1163         PR middle-end/47982
1164         PR middle-end/43967
1165         * doc/libgcc.texi (__udivmoddi4/__udivmodti4): Fix documentation typo.
1166
1167 2012-02-02  Jakub Jelinek  <jakub@redhat.com>
1168
1169         PR middle-end/48071
1170         * diagnostic.c (diagnostic_finish): Remove trailing newlines.
1171
1172 2012-02-02  Vladimir Makarov  <vmakarov@redhat.com>
1173
1174         PR rtl-optimization/49800
1175         * haifa-sched.c (sched_init): Call regstat_init_n_sets_and_refs.
1176         (sched_finish): Call regstat_free_n_sets_and_refs.
1177
1178 2012-02-02  Jia Liu  <proljc@gmail.com>
1179
1180         * config/mips/mips-dspr2.md (mips_prepend): Mask operand 3 rather
1181         than operand 2.
1182
1183 2012-02-02  Jan Hubicka  <jh@suse.cz>
1184             Tom de Vries  <tom@codesourcery.com>
1185
1186         PR middle-end/51998
1187         * cgraphunit.c (cgraph_analyze_function): Break cyclic aliases.
1188         * varpool.c (varpool_analyze_pending_decls): Likewise.
1189
1190 2012-02-02  Sumanth G <sumanth.gundapaneni@kpitcummins.com>
1191             Jayant R Sonar <jayant.sonar@kpitcummins.com>
1192
1193         * config.gcc: Add cr16-* support.
1194
1195         * doc/extend.texi: Document cr16 extensions.
1196         * doc/install.texi: Document cr16 install.
1197         * doc/invoke.texi: Document cr16 options.
1198         * doc/md.texi: Document cr16 constraints.
1199
1200         * common/config/cr16/cr16-common.c: New file.
1201         * config/cr16/cr16.c: New file.
1202         * config/cr16/cr16.h: New file.
1203         * config/cr16/cr16.md: New file.
1204         * config/cr16/cr16.opt: New file.
1205         * config/cr16/cr16-protos.h: New file.
1206         * config/cr16/predicates.md: New file.
1207         * config/cr16/constraints.md: New file.
1208         * config/cr16/t-cr16: New file.
1209
1210 2012-02-02  Jakub Jelinek  <jakub@redhat.com>
1211
1212         PR target/52086
1213         * config/i386/i386.md (*addqi_2 peephole with SImode addition): Check
1214         that operands[2] is either immediate, or q_regs_operand.
1215
1216         PR tree-optimization/52073
1217         * tree-vect-stmts.c (vect_mark_relevant): When checking uses of
1218         a pattern stmt for pattern uses, ignore uses outside of the loop.
1219
1220 2012-02-01  Georg-Johann Lay  <avr@gjlay.de>
1221
1222         * config/avr/avr.c: Resolve all AS1 and AS2 macros.
1223         * config/avr/avr.h (AS1, AS2, AS2C, AS3): Remove.
1224         (OUT_AS1, OUT_AS2): Remove.
1225
1226 2012-02-01  Georg-Johann Lay  <avr@gjlay.de>
1227
1228         PR rtl-optimization/51374
1229         * combine.c (can_combine_p): Don't allow volatile_refs_p insns
1230         to cross other volatile_refs_p insns.
1231
1232 2012-02-01  Richard Guenther  <rguenther@suse.de>
1233
1234         * doc/invoke.texi (fno-inline): Clarify documentation.
1235         (finline-small-functions): Likewise.
1236         (finline-functions): Likewise.
1237         * common.opt (finline): Adjust comment and documentation.
1238         (finline-small-functions): Clarify documentation.
1239         (finline-functions): Likewise.
1240         (finline-functions-called-once): Likewise.
1241
1242 2012-02-01  Tristan Gingold  <gingold@adacore.com>
1243
1244         * c-typeck.c (composite_type): Keep mode for pointers.
1245
1246 2012-01-31  Richard Sandiford  <rdsandiford@googlemail.com>
1247
1248         * function.h (regno_reg_rtx): Adjust comment.
1249         * reginfo.c (init_reg_modes_target): Only use the previous mode
1250         if it fits within one register.  Remove MIPS comment.
1251
1252 2012-01-31  Jakub Jelinek  <jakub@redhat.com>
1253
1254         PR bootstrap/52058
1255         * combine.c (do_SUBST_LINK, SUBST_LINK): Guard with #ifndef HAVE_cc0.
1256
1257 2012-01-31  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
1258
1259         * config/s390/s390.md ("*ashr<mode>3_and"): Add missing z196 flag
1260         to srak instruction.
1261
1262 2012-01-31  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
1263
1264         * config/arm/thumb2.md (thumb2_mov_notscc): Use MVN for true condition.
1265
1266 2012-01-31  Jakub Jelinek  <jakub@redhat.com>
1267
1268         PR bootstrap/52041
1269         PR bootstrap/52039
1270         PR target/51974
1271         * ipa-prop.c (detect_type_change_1): Call ao_ref_init.
1272
1273 2012-01-31  Richard Guenther  <rguenther@suse.de>
1274
1275         PR tree-optimization/51528
1276         * tree-sra.c (sra_modify_assign): Avoid copy-in/out for aggregate
1277         assigns.
1278
1279 2012-01-31  Jakub Jelinek  <jakub@redhat.com>
1280
1281         PR bootstrap/52041
1282         PR bootstrap/52039
1283         PR target/51974
1284         * ree.c (add_removable_extension): Change def_map argument
1285         to unsigned *, store in def_map 1 + offset into *insn_list vector
1286         instead of pointers into the vector.
1287         (find_removable_extensions): Adjust caller.
1288
1289 2012-01-30  Georg-Johann Lay  <avr@gjlay.de>
1290
1291         * config/avr/avr.md: Resolve all AS1 and AS2 macros.
1292         Transform all "* quoted-c-code" to { c-code }.
1293         Remove redundant test for "optimize" in combine patterns.
1294         Move (include "avr-dimode.md") to end of file.
1295
1296 2012-01-30  Bin Cheng  <bin.cheng@arm.com>
1297
1298         PR target/51835
1299         * config/arm/arm.c (arm_libcall_uses_aapcs_base): Use correct ABI
1300         for __aeabi_d2iz/__aeabi_d2uiz with hard-float.
1301
1302 2012-01-30  Richard Guenther  <rguenther@suse.de>
1303
1304         PR tree-optimization/52028
1305         * tree-loop-distribution.c (ldist_gen): Properly update
1306         virtual SSA form.
1307
1308 2012-01-30  Jakub Jelinek  <jakub@redhat.com>
1309
1310         PR debug/52027
1311         * dwarf2out.c (dwarf2out_switch_text_section): Don't call
1312         set_cur_line_info_table if not emitting debug info.
1313
1314         PR tree-optimization/52046
1315         * tree-vect-patterns.c (check_bool_pattern): Give up if
1316         a comparison could throw.
1317
1318         PR debug/52048
1319         * tree-ssa-tail-merge.c (local_def): Ignore debug uses.
1320
1321 2012-01-30  Richard Guenther  <rguenther@suse.de>
1322
1323         PR tree-optimization/52045
1324         * tree-optimize.c (execute_cleanup_cfg_post_optimizing): Update
1325         SSA form if cfgcleanup did anything.
1326
1327 2012-01-30  Richard Guenther  <rguenther@suse.de>
1328
1329         PR tree-optimization/52045
1330         * ipa-inline-transform.c (inline_transform): Call execute_fixup_cfg
1331         before computing final todo.
1332
1333 2012-01-30  Richard Guenther  <rguenther@suse.de>
1334
1335         PR tree-optimization/51528
1336         * tree-sra.c (sra_modify_assign): Re-factor in preparation
1337         for PR51528 fix.
1338
1339 2012-01-30  Paolo Bonzini  <bonzini@gnu.org>
1340
1341         * df-problems.c (df_kill_notes): Check that the use refers
1342         to the note under examination.
1343
1344 2012-01-30  Eric Botcazou  <ebotcazou@adacore.com>
1345
1346         PR target/51920
1347         * config/sparc/sparc.c (vector_init_fpmerge): Remove INNER_MODE
1348         parameter and use short-lived pseudos.
1349         (vector_init_faligndata): Remove INNER_MODE parameter and use loop.
1350         (sparc_expand_vector_init): Const-ify local variables and adjust
1351         calls to above functions.
1352
1353 2012-01-30  Georg-Johann Lay  <avr@gjlay.de>
1354
1355         * config/avr/avr.c (out_movqi_mr_r): Fix length computation.
1356
1357 2012-01-29  Sandra Loosemore  <sandra@codesourcery.com>
1358
1359         * doc/invoke.texi: Make usage of "compile time" and
1360         "run time"/"runtime" consistent throughout the file.
1361
1362 2012-01-29  Uros Bizjak  <ubizjak@gmail.com>
1363
1364         * config/alpha/alpha.c (alpha_option_override): Default to
1365         full IEEE compliance mode for Go language.
1366
1367 2011-01-29  Tijl Coosemans  <tijl@coosemans.org>
1368
1369         * config/freebsd-spec.h [TARGET_LIBC_PROVIDES_SSP]
1370         (LINK_SSP_SPEC): Define.
1371
1372 2012-01-28  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
1373
1374         PR target/51871
1375         * config/pa/pa.c (pa_return_addr_rtx): Add support for PA2.0 export
1376         stubs.
1377
1378 2012-01-28  Sandra Loosemore  <sandra@codesourcery.com>
1379
1380         * doc/invoke.texi: Correct hyphenation of "floating point",
1381         "double precision", and related terminology throughout the file.
1382
1383 2012-01-28  Jakub Jelinek  <jakub@redhat.com>
1384
1385         PR target/52006
1386         * config/arm/arm.md (pic_add_dot_plus_eight peephole2): Use
1387         arm_general_register_operand predicate for operand 2 instead of
1388         register_operand.
1389
1390 2012-01-27  Ian Lance Taylor  <iant@google.com>
1391
1392         PR go/47656
1393         * builtins.def (BUILT_IN_INIT_HEAP_TRAMPOLINE): Define.
1394         * builtins.c (expand_builtin_init_trampoline): Add onstack
1395         parameter.  Change caller.
1396         (expand_builtin): Handle BUILT_IN_INIT_HEAP_TRAMPOLINE.
1397         * tree.c (build_common_builtin_nodes): Declare
1398         __builtin_init_heap_trampoline.
1399
1400 2012-01-27  Georg-Johann Lay  <avr@gjlay.de>
1401
1402         * config/avr/avr-protos.h (lpm_reg_rtx, lpm_addr_reg_rtx,
1403         tmp_reg_rtx, zero_reg_rtx, all_regs_rtx, rampz_rtx): Make global.
1404         * config/avr/avr.c: Ditto.
1405         (avr_regnames): Remove because unused.
1406         * config/avr/avr.md (*cpse.ne): New peephole.
1407         (*cpse.eq): New peephole from former cpse peepholes.
1408
1409 2012-01-27  Michael Eager  <eager@eagercon.com>
1410
1411         * config/microblaze.c (microblaze_emit_compare): Correct
1412         test after pcmp instruction.
1413
1414 2012-01-27  Richard Guenther  <rguenther@suse.de>
1415
1416         PR tree-optimization/52020
1417         * tree-sra.c (sra_modify_assign): Do not transform clobbers.
1418
1419 2012-01-27  Richard Guenther  <rguenther@suse.de>
1420
1421         * ipa-pure-const.c (check_stmt): Clobbers do not make a
1422         function non-const/pure.
1423
1424 2012-01-27  Richard Guenther  <rguenther@suse.de>
1425
1426         PR tree-optimization/50444
1427         * tree-sra.c (build_ref_for_offset): Properly adjust the
1428         MEM_REF type for unaligned accesses.
1429
1430 2012-01-27  Richard Guenther  <rguenther@suse.de>
1431
1432         PR tree-optimization/50444
1433         * expr.c (mem_ref_refers_to_non_mem_p): New function.
1434         (expand_assignment): Use it.  Properly handle misaligned
1435         bases when expanding stores to component references.
1436         (expand_expr_real_1): Use mem_ref_refers_to_non_mem_p and
1437         refactor that case.
1438
1439 2012-01-27  Andrey Belevantsev  <abel@ispras.ru>
1440
1441         PR middle-end/51389
1442         * Makefile.in (tree-data-ref.o): Depend on $(PARAMS_H).
1443         * tree-data-ref.h (find_data_references_in_loop): Remove declaration.
1444         * tree-data-ref.c (find_data_references_in_loop): Make static.
1445         (compute_all_dependences): Change return type to bool.  Bail out
1446         for too many datarefs in a loop.  Move the hunk resetting the data
1447         dependences vector from ...
1448         (compute_data_dependences_for_loop): ... here.  Account for
1449         compute_all_dependences returning false.
1450         (compute_data_dependences_for_bb): Likewise.
1451         * params.def (PARAM_LOOP_MAX_DATAREFS_FOR_DATADEPS): New param.
1452         * doc/invoke.texi (loop-max-datarefs-for-datadeps): Document it.
1453
1454 2012-01-27  Richard Guenther  <rguenther@suse.de>
1455
1456         PR middle-end/51959
1457         * expr.c (store_field): Use the alias-set of the scratch memory
1458         for storing to it.
1459
1460 2012-01-27  Tom de Vries  <tom@codesourcery.com>
1461
1462         PR tree-optimization/51990
1463         * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Handle
1464         WITH_SIZE_EXPR.
1465         * tree-ssa-pre.c (create_component_ref_by_pieces_1): Same.
1466
1467 2012-01-27  Jakub Jelinek  <jakub@redhat.com>
1468
1469         PR debug/52001
1470         * var-tracking.c (reverse_op): Don't add any reverse operation
1471         if V already has any constant locations.
1472
1473 2012-01-27  Sandra Loosemore  <sandra@codesourcery.com>
1474
1475         * doc/invoke.texi: Correct usage of "command line" (noun)
1476         vs "command-line" (adjective) throughout.
1477
1478 2012-01-27  Sandra Loosemore  <sandra@codesourcery.com>
1479
1480         * doc/invoke.texi (Language Independent Options): Move
1481         -Wcoverage-mismatch blurb from here....
1482         (Warning Options): ...to here.
1483
1484 2012-01-27  Peter Bergner  <bergner@vnet.ibm.com>
1485
1486         * config/rs6000/rs6000.c (rs6000_option_override_internal):
1487         Set rs6000_always_hint to false for 476.
1488
1489 2012-01-27  Matthias Klose  <doko@ubuntu.com>
1490
1491         * gcc.c (add_sysrooted_prefix): Remove trailing dir separator from
1492           system root.
1493         * incpath.c (add_standard_paths): Likewise.
1494
1495 2012-01-27  Richard Henderson  <rth@redhat.com>
1496
1497         * config/m68k/m68k.c (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
1498         * config/m68k/sync.md (atomic_test_and_set): Rename from
1499         sync_test_and_setqi and adjust the operands.
1500         (atomic_test_and_set_1): Rename from sync_test_and_setqi_1
1501         and unconditionally enable.
1502
1503 2012-01-27  Richard Henderson  <rth@redhat.com>
1504
1505         * config/sparc/sparc.c (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
1506         * config/sparc/sync.md (atomic_test_and_set): Only handle QImode.
1507         (ldstub): Rename from ldstubqi.
1508         (ldstub<I24MODE>): Remove.
1509
1510 2012-01-27  Richard Henderson  <rth@redhat.com>
1511
1512         * target.def (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): New.
1513         * c-cppbuiltin.c (cpp_atomic_builtins): Define
1514         __GCC_ATOMIC_TEST_AND_SET_TRUEVAL.
1515         * doc/tm.texi.in (TARGET_ATOMIC_TEST_AND_SET_TRUEVAL): Add doc hook.
1516         * doc/tm.texi: Rebuild.
1517
1518 2012-01-27  Richard Henderson  <rth@redhat.com>
1519
1520         * optabs.c (gen_atomic_test_and_set): Remove default.
1521         (maybe_emit_atomic_test_and_set): Use maybe_expand_insn.
1522
1523 2012-01-26  Jakub Jelinek  <jakub@redhat.com>
1524
1525         PR rtl-optimization/51978
1526         * ree.c (make_defs_and_copies_lists): Change set_pat type to const_rtx.
1527         (combine_reaching_defs): Likewise.
1528         (struct re_info): Remove.
1529         (add_removable_extension): Remove x and data arguments,
1530         add insn, insn_list and def_map.  Use the arguments directly
1531         instead of using struct re_info.
1532         (find_removable_extensions): Don't call add_removable_extension
1533         through note_stores, instead just call it with single_set
1534         result if non-NULL.
1535         (find_and_remove_re): Pass curr_cand->expr instead of
1536         PATTERN (curr_cand->insn) as set_pat argument to combine_reaching_defs.
1537
1538 2012-01-26  Michael Matz  <matz@suse.de>
1539
1540         PR tree-optimization/46590
1541         * cfgexpand.c: Revert last change (r183305).
1542         * gimplify.c (gimplify_bind_expr): Add clobbers for all non-gimple
1543         regs.
1544         * tree-eh.c (cleanup_empty_eh): Try to optimize clobbers before
1545         checking for emptiness.
1546
1547 2012-01-26  Jakub Jelinek  <jakub@redhat.com>
1548
1549         PR middle-end/51895
1550         * expr.c (expand_expr_real_1): Handle BLKmode MEM_REF of
1551         non-addressable non-BLKmode base correctly.
1552
1553 2012-01-26  Michael Matz  <matz@suse.de>
1554
1555         PR tree-optimization/48794
1556         * tree-eh.c (remove_unreachable_handlers_no_lp): Don't remove
1557         regions referenced from RESX/EH_DISPATCH.
1558
1559 2012-01-26  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
1560
1561         * config/s390/s390.h: Make BRANCH_COST an option.
1562         * config/s390/s390.opt: New option -mbranch-cost.
1563
1564 2012-01-26  Richard Henderson  <rth@redhat.com>
1565
1566         Revert 2012-01-24 change:
1567         * trans-mem.c (requires_barrier): Do not instrument thread local
1568         variables and emit save/restore for them.
1569
1570 2012-01-25  Jakub Jelinek  <jakub@redhat.com>
1571
1572         PR middle-end/51986
1573         * sched-deps.c (sched_get_condition_with_rev_uncached): Don't test
1574         for pat == 0.
1575
1576 2012-01-25  Richard Sandiford  <rdsandiford@googlemail.com>
1577
1578         * config/mips/mips.c (mips_small_data_pattern_1): Don't process
1579         ASM_OPERANDS.
1580
1581 2012-01-25  Georg-Johann Lay  <avr@gjlay.de>
1582
1583         PR target/49868
1584         Rename __pgm to __flash.
1585         Rename __pgm1 to __flash1.
1586         Rename __pgm2 to __flash2.
1587         Rename __pgm3 to __flash3.
1588         Rename __pgm4 to __flash4.
1589         Rename __pgm5 to __flash5.
1590         Rename __pgmx to __memx.
1591         * doc/extend.texi (AVR Named Address Spaces)
1592         Rename address space names as indicated above.
1593         * config/avr/avr.c (avr_addrspace): Ditto.
1594
1595         * config/avr/avr-protos.h
1596         (avr_mem_pgmx_p): Rename to avr_mem_memx_p.
1597         (avr_mem_pgm_p): Rename to avr_mem_flash_p.
1598         * config/avr/predicates.md: Ditto.
1599         * config/avr/avr.c Ditto, and
1600         (avr_decl_pgmx_p): Rename to avr_decl_memx_p.
1601         (avr_decl_pgm_p): Rename to avr_decl_flash_p.
1602
1603         * config/avr/avr.h (ADDR_SPACE_PGM): Rename to ADDR_SPACE_FLASH.
1604         (ADDR_SPACE_PGM1): Rename to ADDR_SPACE_FLASH1.
1605         (ADDR_SPACE_PGM2): Rename to ADDR_SPACE_FLASH2.
1606         (ADDR_SPACE_PGM3): Rename to ADDR_SPACE_FLASH3.
1607         (ADDR_SPACE_PGM4): Rename to ADDR_SPACE_FLASH4.
1608         (ADDR_SPACE_PGM5): Rename to ADDR_SPACE_FLASH5.
1609         (ADDR_SPACE_PGMX): Rename to ADDR_SPACE_MEMX.
1610         * config/avr/avr.c: Ditto.
1611         * config/avr/avr.md: Ditto.
1612
1613 2012-01-25  Jason Merrill  <jason@redhat.com>
1614
1615         PR c++/51992
1616         * tree.c (find_decls_types_in_node): Walk gimple_call_fntype.
1617
1618 2012-01-25  Jakub Jelinek  <jakub@redhat.com>
1619
1620         PR tree-optimization/51987
1621         * tree-data-ref.c (get_references_in_stmt): Handle references in
1622         non-volatile GIMPLE_ASM.
1623
1624 2012-01-25  Richard Guenther  <rguenther@suse.de>
1625
1626         * tree-ssa-sccvn.c (vn_reference_eq): Also compare if both
1627         bases are dereferenced.
1628
1629 2012-01-25  Andrey Belevantsev  <abel@ispras.ru>
1630
1631         PR rtl-optimization/48374
1632         * sel-sched-ir.h (get_all_loop_exits): Check for zero successors.
1633
1634 2012-01-25  Andrey Belevantsev  <abel@ispras.ru>
1635
1636         * tree-predcom.c (tree_predictive_commoning_loop): Bail out when
1637         compute_data_dependences_for_loop returns false.
1638         * tree-parloops.c (loop_parallel_p): Likewise.
1639
1640 2012-01-25  Richard Guenther  <rguenther@suse.de>
1641
1642         * tree.h (get_pointer_alignment_1): Declare.
1643         * builtins.c (get_pointer_alignment_1): New function.
1644         (get_pointer_alignment): Use it.
1645
1646 2012-01-25  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
1647
1648         PR rtl-optimization/48308
1649         * combine.c (enum undo_kind): Add UNDO_LINKS.
1650         (struct undo): Add member l to other_contents and where.
1651         (do_SUBST_LINK): New.
1652         (SUBST_LINK): New.
1653         (try_combine): Handle LOG_LINKS for the dummy i1 case.
1654         (undo_all): Handle UNDO_LINKS.
1655
1656 2012-01-25  Richard Henderson  <rth@redhat.com>
1657
1658         * optabs.c (maybe_emit_atomic_test_and_set): Allow non-QImode
1659         mem inputs.
1660
1661 2012-01-24  Richard Sandiford  <rdsandiford@googlemail.com>
1662
1663         * optabs.c (gen_atomic_test_and_set): Use each argument.
1664
1665 2012-01-24  Richard Sandiford  <rdsandiford@googlemail.com>
1666
1667         * config/mips/mips-ps-3d.md (mips_addr_ps, reduc_splus_v2sf)
1668         (mips_cvt_pw_ps, mips_cvt_ps_pw, mips_mulr_ps, mips_cabs_cond_<fmt>)
1669         (mips_cabs_cond_4s, mips_cabs_cond_ps, bc1any4t, bc1any4f, bc1any2t)
1670         (bc1any2f, mips_rsqrt1_<fmt>, mips_rsqrt2_<fmt>, mips_recip1_<fmt>)
1671         (mips_recip2_<fmt>): Require TARGET_MIPS3D rather than
1672         TARGET_PAIRED_SINGLE_FLOAT.
1673
1674 2012-01-24  Richard Sandiford  <rdsandiford@googlemail.com>
1675
1676         * doc/rtl.texi (MEM_IN_STRUCT_P, MEM_SCALAR_P): Delete.
1677         (in_struct, return_val): Remove MEM documentation.
1678         * rtl.h (rtx_def): Remove MEM meanings from in_struct and return_val.
1679         (MEM_IN_STRUCT_P, MEM_SCALAR_P): Delete.
1680         (MEM_COPY_ATTRIBUTES): Remove references to MEM_IN_STRUCT_P
1681         and MEM_SCALAR.
1682         * emit-rtl.c (set_mem_attributes_minus_bitpos): Likewise.
1683         * cfgexpand.c (add_alias_set_conflicts): Likewise.
1684         * expr.c (store_field): Likewise.
1685         * function.c (assign_stack_temp_for_type): Likewise.
1686         * ifcvt.c (noce_try_cmove_arith): Likewise.
1687         * reload1.c (reload): Likewise.
1688         * config/alpha/alpha.c (alpha_set_memflags_1): Likewise.
1689         (alpha_set_memflags): Likewise.
1690         * config/m32c/m32c.c (m32c_immd_dbl_mov): Nullify.
1691
1692 2012-01-24  Richard Sandiford  <rdsandiford@googlemail.com>
1693
1694         * rtl.h (true_dependence, canon_true_dependence): Remove varies
1695         parameter.
1696         * alias.c (fixed_scalar_and_varying_struct_p): Delete.
1697         (true_dependence_1, write_dependence_p, may_alias_p): Don't call it.
1698         (true_dependence_1, true_dependence, canon_true_dependence): Remove
1699         varies parameter.
1700         * cselib.c (cselib_rtx_varies_p): Delete.
1701         (cselib_invalidate_mem): Update call to canon_true_dependence.
1702         * dse.c (record_store, check_mem_read_rtx): Likewise.
1703         (scan_reads_nospill): Likewise.
1704         * cse.c (check_dependence): Likewise.
1705         (cse_rtx_varies_p): Delete.
1706         * expr.c (safe_from_p): Update call to true_dependence.
1707         * ira.c (validate_equiv_mem_from_store): Likewise.
1708         (memref_referenced_p): Likewise.
1709         * postreload-gcse.c (find_mem_conflicts): Likewise.
1710         * sched-deps.c (sched_analyze_2): Likewise.
1711         * store-motion.c (load_kills_store): Likewise.
1712         * config/frv/frv.c (frv_registers_conflict_p_1): Likewise.
1713         * gcse.c (mems_conflict_for_gcse_p): Likewise.
1714         (compute_transp): Update call to canon_true_dependence.
1715
1716 2012-01-25  Richard Henderson  <rth@redhat.com>
1717
1718         * optabs.c (CODE_FOR_atomic_test_and_set): Provide default.
1719         (maybe_emit_atomic_test_and_set): New.
1720         (expand_sync_lock_test_and_set): Use it.
1721         (expand_atomic_test_and_set): Likewise.
1722         * doc/extend.texi (__atomic_test_and_set): Adjust the docs to match
1723         the implementation; clarify implementation defined details.
1724         * doc/md.texi (atomic_test_and_set): Document.
1725
1726 2012-01-25  Richard Henderson  <rth@redhat.com>
1727
1728         * config/sparc/predicates.md (zero_or_v7_operand): Use match_code.
1729
1730 2012-01-25  Richard Henderson  <rth@redhat.com>
1731
1732         PR target/51968
1733         * config/arm/arm.c (neon_split_vcombine): Emit deleted note
1734         to effect no-op split.
1735
1736 2012-01-24  Aldy Hernandez  <aldyh@redhat.com>
1737
1738         PR lto/51698
1739         * builtin-types.def: (BT_CONST_DOUBLE_PTR): New.
1740         (BT_FN_VOID_PTR_CONST_PTR_SIZE): New.
1741         (BT_FN_VOID_PTR_INT_SIZE): New.
1742         (BT_FN_UINT_UINT_VAR): Remove.
1743         (BT_FN_UINT32_UINT32_VAR): New.
1744         (BT_FN_DOUBLE_VPTR): Remove.
1745         (BT_FN_DOUBLE_CONST_DOUBLE_PTR): New.
1746
1747         * gtm-builtins.def (_ITM_abortTransaction): Set return type to void.
1748         (_ITM_changeTransactionMode): Same.
1749         (_ITM_memmoveRtWt): Change return type to void.
1750         (_ITM_memcpyRtWt): Same.
1751         (_ITM_memsetW): Same.
1752         (_ITM_RaRD): Change types to double.
1753         (_ITM_RD): Same.
1754         (_ITM_RaWD): Same.
1755         (_ITM_RfWD): Same.
1756
1757         * builtins.def (DEF_TM_BUILTIN): Set BOTH_P to true.
1758
1759 2012-01-24  Aldy Hernandez  <aldyh@redhat.com>
1760             Patrick Marlier  <patrick.marlier@gmail.com>
1761
1762         * trans-mem.c (requires_barrier): Do not instrument thread local
1763         variables and emit save/restore for them.
1764
1765 2012-01-24  Jason Merrill  <jason@redhat.com>
1766
1767         PR c++/51812
1768         * cgraphunit.c (cgraph_decide_is_function_needed): Don't always
1769         output static aliases.
1770
1771 2012-01-24  Jakub Jelinek  <jakub@redhat.com>
1772
1773         PR driver/47249
1774         * common.opt (-pie, -shared, pie, shared): Change from Common to
1775         Driver.
1776         * gcc.c (display_help): Display help for -pie and -shared.
1777
1778 2012-01-24  Georg-Johann Lay  <avr@gjlay.de>
1779
1780         PR target/49868
1781         * doc/extend.texi (AVR Named Address Spaces): Move sample code up.
1782         Remove note on size/offset limitation.
1783         (AVR Variable Attributes): Add example how to read data located
1784         with progmem.  Refer to named address spaces.
1785         * doc/invoke.texi (AVR Options): Fix typo.
1786
1787 2012-01-24  Richard Guenther  <rguenther@suse.de>
1788
1789         Forward-port to trunk
1790         2010-09-21  Jakub Jelinek  <jakub@redhat.com>
1791
1792         PR middle-end/45678
1793         * expr.c (expand_expr_real_1) <case VIEW_CONVERT_EXPR>: If
1794         op0 isn't sufficiently aligned and there is movmisalignM
1795         insn for mode, use it to load op0 into a temporary register.
1796
1797 2012-01-24  Jakub Jelinek  <jakub@redhat.com>
1798
1799         PR target/51957
1800         * target.def (const_not_ok_for_debug_p): New hook.
1801         * doc/tm.texi.in (TARGET_CONST_NOT_OK_FOR_DEBUG_P): New hook
1802         documentation.
1803         * doc/tm.texi: Regenerated.
1804         * dwarf2out.c (const_ok_for_output_1): If
1805         targetm.const_not_ok_for_debug_p returns true, fail.
1806         * config/rs6000/rs6000.c (rs6000_const_not_ok_for_debug_p): New
1807         function.
1808         (TARGET_CONST_NOT_OK_FOR_DEBUG_P): Redefine.
1809
1810 2012-01-23  Kai Tietz  <ktietz@redhat.com>
1811
1812         PR target/51900
1813         * config/i386/predicates.md (symbolic_operand): Allow
1814         UNSPEC_PCREL as PIC expression for lea.
1815         * config/i386/winnt.c (i386_pe_binds_local_p): Reworked.
1816         * config/i386/i386.c (ix86_delegitimize_address): Handle
1817         UNSPEC_PCREL for none-MEM, too.
1818
1819 2012-01-23  Aldy Hernandez  <aldyh@redhat.com>
1820
1821         * trans-mem.c (ipa_tm_create_version): Set externally_visible.
1822         (ipa_tm_create_version_alias): Same.
1823
1824 2012-01-23  Uros Bizjak  <ubizjak@gmail.com>
1825
1826         PR libitm/51830
1827         * builtin-types.def (BT_FN_UINT_UINT_VAR): New.
1828         * gtm-builtins.def (BUILT_IN_TM_START): Declare as BT_FN_UINT_UINT_VAR.
1829
1830 2012-01-23  Aldy Hernandez  <aldyh@redhat.com>
1831             Patrick Marlier  <patrick.marlier@gmail.com>
1832             Iain Sandoe  <developer@sandoe-acoustics.co.uk>
1833
1834         PR lto/51916
1835         * lto-wrapper.c (run_gcc): Pass the LTO section name to
1836         simple_object_start_read.
1837
1838 2012-01-23  Richard Guenther  <rguenther@suse.de>
1839
1840
1841         PR tree-optimization/51895
1842         * tree-sra.c (decide_one_param_reduction): Avoid sub-optimal
1843         parameter decomposition into BLKmode components.
1844
1845 2012-01-23  Eric Botcazou  <ebotcazou@adacore.com>
1846
1847         * tree-ssa-structalias.c (intra_create_variable_infos): Do not create
1848         fake variables for restrict-qualified pointers whose pointed-to type
1849         contains a placeholder.
1850
1851 2012-01-23  Richard Guenther  <rguenther@suse.de>
1852
1853         PR tree-optimization/51949
1854         * ipa-split.c (execute_split_functions): Do not split malloc functions.
1855
1856 2012-01-23  Jakub Jelinek  <jakub@redhat.com>
1857
1858         PR rtl-optimization/51933
1859         * ree.c (transform_ifelse): Return true right away if dstreg is
1860         already wider or equal to cand->mode.
1861         (enum ext_modified_kind, struct ext_modified, ext_state): New types.
1862         (make_defs_and_copies_lists): Remove defs_list and copies_list
1863         arguments, add state argument, just truncate state->work_list
1864         instead of always allocating and freeing the vector.  Assert that
1865         get_defs succeeds instead of returning 2.  Changed return type to bool.
1866         (merge_def_and_ext): Add state argument.  If SET_DEST doesn't
1867         have ext_src_mode, see if it has been modified already with the
1868         right kind of extension and has been extended before from the
1869         ext_src_mode.  If SET_DEST is already wider or equal to cand->mode,
1870         just return true.  Remember the original mode in state->modified array.
1871         (combine_reaching_defs): Add state argument.  Don't allocate and
1872         free here def_list, copied_list and vec vectors, instead just
1873         VEC_truncate the vectors in *state.  Don't handle outcome == 2 here.
1874         (find_and_remove_re): Set DF_DEFER_INSN_RESCAN df flag.
1875         Add state variable, clear vectors in it, initialize state.modified
1876         if needed.  Free all the vectors at the end and state.modified too.
1877         Don't skip a candidate if the extension expression has been modified.
1878
1879 2012-01-22  Douglas B Rupp  <rupp@gnat.com>
1880
1881         PR target/47096
1882         * config.gcc: (i[34567]86-*-interix3*): Remove from obsolete
1883          configurations. Change triplet to i[34567]86-*-interix[3-9]*.
1884         (extra_options) interix.opt -> i386/interix.opt"
1885         (extra_objs):Add winnt-stubs.o
1886         * configure.ac: Add interix to target_os .comm on PE check.
1887         * configure: Regenerate.
1888         * config/interix3.h: Delete and move bits to..
1889         * config/interix.h: Delete and move bits to..
1890         * config/i386/i386-interix3.h: Delete and move bits to..
1891         * config/i386/i386-interix.h: ..here.
1892         (TARGET_CPU_DEFAULT): Remove redefinition.
1893         (TARGET_ASM_CONSTRUCTOR): Undefine.
1894         (SUBTARGET_SWITCHES): Define for ms-bitfields.
1895         (TARGET_OS_CPP_BUILTINS): Remove __OPENNT. Add __declspec.
1896         (PTRDIFF_TYPE): Define.
1897         (LONG_DOUBLE_TYPE_SIZE): Define.
1898         (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Define.
1899         (SUBTARGET_OVERRIDE_OPTIONS): Remove.
1900         (TARGET_SECTION_TYPE_FLAGS): Define.
1901         (ASM_DECLARE_FUNCTION_NAME): Define.
1902         (ASM_OUTPUT_EXTERNAL): Define.
1903         (ASM_OUTPUT_EXTERNAL_LIBCALL): Define.
1904         (ASM_OUTPUT_ALIGNED_BSS): Define.
1905         (PCC_BITFIELD_TYPE_MATTERS): Define.
1906         (USE_CONST_SECTION): Define.
1907         (SUBTARGET_ENCODE_SECTION_INFO): Remove.
1908         (TARGET_ASM_FUNCTION_RODATA_SECTION): Remove.
1909         (SUPPORTS_ONE_ONLY): Remove.
1910         (I386_PE_STRIP_ENCODING): Define.
1911         * config/interix.opt: Delete and move bits to..
1912         * config/i386/interix.opt: ..here. New.
1913         (mpe-aligned-commons): Add.
1914         * config/i386/t-interix: Add copyright header.
1915         (winnt-stubs.o): Add rule.
1916
1917 2012-01-22  Jason Merrill  <jason@redhat.com>
1918
1919         PR c++/51832
1920         * varpool.c (varpool_analyze_pending_decls): Copy DECL_EXTERNAL
1921         for extra name aliases.
1922
1923 2012-01-22  Eric Botcazou  <ebotcazou@adacore.com>
1924
1925         PR rtl-optimization/51924
1926         * ree.c (combine_set_extension): Improve debugging message.
1927         (combine_reaching_defs): Likewise.
1928         (get_defs): Rename confusingly named variable.
1929         (find_and_remove_re): Skip a candidate if the extension expression has
1930         been modified.
1931
1932 2012-01-21  Robert Millan  <rmh@gnu.org>
1933             Gerald Pfeifer  <gerald@pfeifer.com>
1934
1935         * config/kfreebsd-gnu.h (GNU_USER_DYNAMIC_LINKERX32): New macro.
1936         (GNU_USER_DYNAMIC_LINKER): Adjust indentation.
1937
1938 2012-01-20  Jakub Jelinek  <jakub@redhat.com>
1939
1940         PR tree-optimization/51914
1941         * tree-vect-stmts.c (vectorizable_conversion): For
1942         cvt_type && modifier == WIDEN, put temporary with cvt_type
1943         at the beginning of vec_dsts and set vec_dest to temporary
1944         with vectype_out.
1945
1946 2012-01-20  Eric Botcazou  <ebotcazou@adacore.com>
1947
1948         * cfgrtl.c (rtl_dump_bb): Do not dump insns for {ENTRY|EXIT}_BLOCK.
1949
1950 2011-01-20  Tijl Coosemans  <tijl@coosemans.org>
1951
1952         * config/i386/i386.c: Fix checks for !TARGET_MACHO.
1953         * config/rs6000/rs6000.c: Likewise.
1954
1955 2012-01-20  Jakub Jelinek  <jakub@redhat.com>
1956
1957         PR target/51915
1958         * config/arm/arm.c (arm_count_output_move_double_insns): Call
1959         output_move_double on a copy of operands array.
1960
1961 2012-01-20  Cary Coutant  <ccoutant@google.com>
1962             Dodji Seketeli  <dodji@redhat.com>
1963
1964         PR debug/45682
1965         * dwarf2out.c (copy_declaration_context): Return ref to parent
1966         of declaration DIE, if necessary.
1967         (remove_child_or_replace_with_skeleton): Add new parameter; update
1968         caller.  Place skeleton DIE under parent DIE of original declaration.
1969         Move call to copy_declaration_context to here ...
1970         (break_out_comdat_types): ... from here.
1971
1972 2012-01-20  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
1973
1974         PR rtl-optimization/51856
1975         * reload.c (find_reloads_subreg_address): Set the address_reloaded
1976         flag to reloaded.
1977
1978 2012-01-20  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
1979
1980         PR target/51819
1981         * config/arm/arm.c (arm_print_operand): Correct output of alignment
1982         hints for neon loads and stores.
1983
1984 2012-01-20  Georg-Johann Lay  <avr@gjlay.de>
1985
1986         PR target/49868
1987         PR target/50887
1988         * doc/extend.texi (Named Address Spaces): Split into subsections.
1989         (AVR Named Address Spaces): New subsection.
1990         (M32C Named Address Spaces): New subsection.
1991         (RL78 Named Address Spaces): New subsection.
1992         (SPU Named Address Spaces): New subsection.
1993         (Variable Attributes): New anchor "AVR Variable Attributes".
1994         (AVR Variable Attributes): Rewrite and avoid wording
1995         "address space" in this context.
1996         * doc/invoke.texi (AVR Options): Rewrite and add documentation
1997         for -maccumulate-args, -mbranch-cost=, -mrelax, -mshort-calls.
1998         (AVR Built-in Macros): New subsubsection therein.
1999         * doc/md.texi (AVR constraints): Remove "C04", "R".
2000
2001 2012-01-20  Richard Guenther  <rguenther@suse.de>
2002
2003         PR tree-optimization/51903
2004         * tree-ssa-pre.c (eliminate): Properly purging of EH edges
2005         when removing stmts.
2006
2007 2012-01-20  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
2008
2009         PR target/50313
2010         * config/arm/arm.c (arm_load_pic_register): Use
2011         gen_pic_load_addr_unified. Delete calls to gen_pic_load_addr_32bit
2012         , gen_pic_add_dot_plus_eight and gen_pic_add_dot_plus_four.
2013         (arm_pic_static_addr): Likewise.
2014         (arm_rtx_costs_1): Adjust cost for UNSPEC_PIC_UNIFIED.
2015         (arm_note_pic_base): Handle UNSPEC_PIC_UNIFIED.
2016         * config/arm/arm.md (UNSPEC_PIC_UNIFIED): Define.
2017         (pic_load_addr_unified): New.
2018
2019 2012-01-20  Andrey Belevantsev  <abel@ispras.ru>
2020
2021         PR target/51106
2022         * function.c (instantiate_virtual_regs_in_insn): Use
2023         delete_insn_and_edges when removing a wrong asm insn.
2024
2025 2012-01-19  Vladimir Makarov  <vmakarov@redhat.com>
2026
2027         PR rtl-optimization/40761
2028         * ira-int.h (struct ira_loop_tree_node): Add comment for member loop.
2029         Add new member loop_num.
2030         (IRA_LOOP_NODE_BY_INDEX): Modify the check.
2031         (ira_build): Remove the parameter.
2032
2033         * ira.c (ira_print_disposition): Use loop_num instead of loop->num.
2034         (ira.c): Do not build CFG loops for one region allocation.  Remove
2035         argument from ira_build call.
2036
2037         * ira-build.c (init_loop_tree_node): New function.
2038         (create_loop_tree_nodes): Use it.  Separate the case when CFG
2039         loops are not built.
2040         (more_one_region_p): Check current_loops.
2041         (finish_loop_tree_nodes): Separate the case when CFG loops are not
2042         built.
2043         (add_loop_to_tree): Process loop equal to NULL too.
2044         (form_loop_tree): Separate the case when CFG loops are not built.
2045         Use explicitly number for the root.
2046         (rebuild_regno_allocno_maps, create_loop_tree_node_allocnos): Add
2047         an assertion.
2048         (ira_print_expanded_allocno, loop_compare_func): Use loop_num
2049         instead of loop->num.
2050         (mark_loops_for_removal): Ditto.  Use loop_num instead of loop->num.
2051         (mark_all_loops_for_removal): Ditto.
2052         (remove_unnecessary_regions): Separate the case when CFG loops
2053         are not built.
2054         (ira_build): Remove the parameter.  Use explicit number of regions
2055         when CFG loops are not built.
2056
2057         * ira-color.c (print_loop_title): Separate the case for the root node.
2058         Use loop_num instead of loop->num.
2059         (move_spill_restore): Use loop_num instead of loop->num.
2060
2061         * ira-emit.c (setup_entered_from_non_parent_p): Add an assertion.
2062         (change_loop): Ditto.
2063         (change_loop): Use loop_num instead of loop->num.
2064
2065         * ira-lives.c (process_bb_node_lives): Ditto.
2066
2067         * ira-costs.c (print_allocno_costs, find_costs_and_classes): Ditto.
2068
2069         * ira-conflicts.c (print_allocno_conflicts): Ditto.
2070
2071 2012-01-19  Jakub Jelinek  <jakub@redhat.com>
2072
2073         PR libmudflap/40778
2074         * tree-mudflap.c (mf_artificial): New function.
2075         (execute_mudflap_function_ops, execute_mudflap_function_decls,
2076         mx_register_decls, mudflap_enqueue_decl): Use it.
2077
2078         PR target/51876
2079         * config/arm/neon.md (*neon_vswp<mode>): Fix up operand
2080         numbers in the insn pattern.
2081
2082 2012-01-19  Michael Matz  <matz@suse.de>
2083
2084         PR tree-optimization/46590
2085         * cfgexpand.c (add_scope_conflicts_1): New old_conflicts argument,
2086         use it in remembering which conflicts we already created.
2087         (add_scope_conflicts): Adjust call to above, (de)allocate helper
2088         bitmap.
2089
2090 2012-01-19  Aldy Hernandez  <aldyh@redhat.com>
2091
2092         PR lto/51280
2093         * lto-wrapper.c (run_gcc): Pass -fgnu_tm on.
2094         (merge_and_complain): Same.
2095
2096 2012-01-19  Jakub Jelinek  <jakub@redhat.com>
2097
2098         PR bootstrap/50237
2099         * config/initfini-array.h: Guard content of the header
2100         with #ifdef HAVE_INITFINI_ARRAY.
2101         * configure.ac: Move gcc_AC_INITFINI_ARRAY much later into the file.
2102         Add initfini-array.h to tm_file here.
2103         * acinclude.m4 (gcc_AC_INITFINI_ARRAY): For non-ia64 do a linker test.
2104         * config.gcc: Don't add initfini-array.h to tm_file here.
2105         * configure: Regenerated.
2106
2107 2012-01-19  Andrey Belevantsev  <abel@ispras.ru>
2108
2109         PR rtl-optimization/51505
2110         * df-problems.c (df_kill_notes): New parameter live. Update comment.
2111         Remove REG_EQUAL/REG_EQUIV notes referring to dead registers.
2112         (df_note_bb_compute): Update the call to df_kill_notes.
2113
2114 2012-01-18  Aldy Hernandez  <aldyh@redhat.com>
2115
2116         * trans-mem.c (requires_barrier): Remove call to is_global_var.
2117
2118 2012-01-18  Richard Guenther  <rguenther@suse.de>
2119
2120         * tree-ssa.c (useless_type_conversion_p): Remove special-casing
2121         of conversions to void *.
2122
2123 2012-01-17  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2124             Richard Sandiford  <rdsandiford@googlemail.com>
2125
2126         PR middle-end/50325
2127         PR middle-end/51192
2128         * optabs.h (simplify_expand_binop): Declare.
2129         * optabs.c (simplify_expand_binop): Make global.
2130         * expmed.c (store_bit_field_1): Use simplify_expand_binop on big
2131         endian targets if the source cannot be exactly covered by word
2132         mode chunks.
2133
2134 2012-01-17  Jakub Jelinek  <jakub@redhat.com>
2135
2136         PR bootstrap/51872
2137         * hard-reg-set.h (struct hard_reg_set_container): New type.
2138         * target.h (struct hard_reg_set_container): Forward declare.
2139         * target.def (set_up_by_prologue): New target hook.
2140         * doc/tm.texi.in (TARGET_SET_UP_BY_PROLOGUE): Document it.
2141         * doc/tm.texi: Regenerated.
2142         * function.c (thread_prologue_and_epilogue_insns): Change
2143         set_up_by_prologue HARD_REG_SET into struct hard_reg_set_container.
2144         Call targetm.set_up_by_prologue on it.
2145         * config/rs6000/rs6000.c (rs6000_set_up_by_prologue): New function.
2146         (TARGET_SET_UP_BY_PROLOGUE): Redefine to it.
2147
2148 2012-01-17  Nick Clifton  <nickc@redhat.com>
2149
2150         * config/rx/rx.c (rx_can_use_simple_return): New function.
2151         * config/rx/rx-protos.h (rx_can_use_simple_return): Prototype.
2152         * config/rx/rx.md (return): Predicate on rx_can_use_simple_return.
2153
2154 2012-01-17  Richard Guenther  <rguenther@suse.de>
2155
2156         PR middle-end/51782
2157         * expr.c (expand_assignment): Take address-space information
2158         from the address operand of MEM_REF and TARGET_MEM_REF.
2159         (expand_expr_real_1): Likewise.
2160
2161 2012-01-17  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2162
2163         * ira.c (do_reload): Make sure ira_dump_file is re-set if no
2164         reload dump is requested.
2165
2166 2012-01-17  Aldy Hernandez  <aldyh@redhat.com>
2167
2168         PR other/51165
2169         * trans-mem.c (requires_barrier): Call may_be_aliased.
2170
2171 2012-01-17  Jakub Jelinek  <jakub@redhat.com>
2172
2173         PR tree-optimization/51877
2174         * tree-ssa-tail-merge.c (gimple_equal_p): Don't return true whenever
2175         call arguments and fndecls compare equal, instead return false if they
2176         don't.  Return true only if lhs1 and lhs2 are either both NULL, or
2177         both SSA_NAMEs that are valueized the same, or they satisfy
2178         operand_equal_p.
2179
2180 2012-01-17  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
2181
2182         * configure.ac (gcc_cv_target_dl_iterate_phdr): Only check on
2183         Solaris 11+.
2184         * configure: Regenerate.
2185
2186 2012-01-16  Jan Hubicka  <jh@suse.cz>
2187
2188         PR c/12245
2189         PR c++/14179
2190         * convert.c (convert_to_integer): Use fold_convert for
2191         converting an INTEGER_CST to integer type.
2192
2193 2012-01-16  Jason Merrill  <jason@redhat.com>
2194
2195         PR c++/14179
2196         * vec.c (vec_gc_o_reserve_1): Use ggc_round_alloc_size.
2197
2198 2012-01-16  Jakub Jelinek  <jakub@redhat.com>
2199
2200         PR bootstrap/51860
2201         * config/s390/s390.c (s390_chunkify_start): Don't skip
2202         call insns followed by NOTE_INSN_CALL_ARG_LOCATION note.  Skip
2203         NOTE_INSN_VAR_LOCATION and NOTE_INSN_CALL_ARG_LOCATION notes.
2204         If insn is followed by NOTE_INSN_VAR_LOCATION or
2205         NOTE_INSN_CALL_ARG_LOCATION notes, insert jump after all those notes.
2206         Don't use location of note insns.
2207
2208         PR tree-optimization/51865
2209         * tree-inline.c (tree_function_versioning): Call remap_decl
2210         on DECL_RESULT whenever it has VOID_TYPE_P type.
2211
2212 2012-01-15  Richard Sandiford  <rdsandiford@googlemail.com>
2213
2214         * config/mips/mips.c (mips16_build_call_stub): Don't use a stub
2215         for calls to locally-binding MIPS16 functions if only the return
2216         type uses float regs.
2217
2218 2012-01-15  Chung-Lin Tang  <cltang@codesourcery.com>
2219             Richard Sandiford  <rdsandiford@googlemail.com>
2220
2221         * config/mips/mips-protos.h (SYMBOL_FORCE_TO_MEM): Delete.
2222         (SYMBOL_32_HIGH): Likewise.
2223         (mips_output_tls_reloc_directive): Declare.
2224         * config/mips/mips.h (PIC_FUNCTION_ADDR_REGNUM): Move to mips.md.
2225         (mips_use_pcrel_pool_p, mips_lo_relocs, mips_hi_relocs): Declare.
2226         * config/mips/mips.c (mips_use_pcrel_pool_p): New variable.
2227         (mips_lo_relocs, mips_hi_relocs): Make extern.
2228         (mips16_stub_function): Move up file.
2229         (mips_classify_symbol): Remove SYMBOL_FORCE_TO_MEM handling.
2230         (mips_symbolic_constant_p): Likewise.  Remove SYMBOL_32_HIGH too.
2231         (mips_symbol_insns_1): Likewise.  Check mips_use_pcrel_pool_p.
2232         (mips_cannot_force_const_mem): Use mips_use_pcrel_pool_p instead of
2233         SYMBOL_FORCE_TO_MEM.  Only check mips_tls_symbol_ref_1 if it's false.
2234         (mips_get_tp): Add MIPS16 support.
2235         (mips_legitimize_tls_address): Remove MIPS16 sorry().
2236         Generalize DTPREL and TPREL handling.
2237         (mips_init_relocs): Initialize mips_use_pcrel_pool_p.
2238         Add MIPS16 TLS support.
2239         (mips_output_tls_reloc_directive): New function.
2240         (mips16_rewrite_pool_refs): Ignore UNSPEC_TLS_GET_TPs.
2241         * config/mips/predicates.md (symbolic_operand_with_high)
2242         (tls_reloc_operand): New predicates.
2243         (force_to_mem_operand): Use mips_use_pcrel_pool_p.
2244         * config/mips/mips.md (UNSPEC_UNSHIFTED_HIGH): New unspec.
2245         (PIC_FUNCTION_ADDR_REGNUM): Moved from mips.h.
2246         (*unshifted_high): New instruction.  Use it for MIPS16 high splitter.
2247         (consttable_tls_reloc, tls_get_tp_mips16_<mode>): New patterns.
2248         (*tls_get_tp_mips16_call_<mode>): Likewise.
2249
2250 2012-01-15  Uros Bizjak  <ubizjak@gmail.com>
2251
2252         PR rtl-optimization/51821
2253         * recog.c (peep2_find_free_register): Determine clobbered registers
2254         from insn pattern.
2255
2256 2012-01-14  Denis Chertykov  <chertykov@gmail.com>
2257
2258         PR target/50925
2259         * config/avr/avr-protos.h: Revert change of 2012-01-09.
2260         * config/avr/avr.c: Likewise.
2261         * config/avr/avr.h: Likewise.
2262
2263 2012-01-13  Ian Lance Taylor  <iant@google.com>
2264
2265         PR c++/50012
2266         * tree.h (TYPE_QUALS): Add cast to int.
2267         (TYPE_QUALS_NO_ADDR_SPACE): Likewise.
2268
2269 2012-01-13  Ian Lance Taylor  <iant@google.com>
2270
2271         * ipa-cp.c (ipa_get_indirect_edge_target): Add typecasts when
2272         comparing param_index to VEC_length result.
2273
2274 2012-01-13  Steven Bosscher  <steven@gcc.gnu.org>
2275
2276         * c-decl.c: Do not include tree-mudflap.h
2277         * tree-optimize.c: Likewise.
2278         * Makefile.in: Update dependencies.
2279
2280 2012-01-13  Richard Guenther  <rguenther@suse.de>
2281
2282         PR middle-end/8081
2283         * gimplify.c (gimplify_modify_expr_rhs): For calls with a
2284         variable-sized result always use RSO.
2285
2286 2012-01-12  DJ Delorie  <dj@redhat.com>
2287
2288         * cfgexpand.c (convert_debug_memory_address): Allow any valid
2289         pointer type, not just the default pointer type.
2290
2291 2012-01-09  Richard Henderson  <rth@redhat.com>
2292             Denis Chertykov  <chertykov@gmail.com>
2293
2294         PR target/50925
2295         * config/avr/avr-protos.h (avr_hard_regno_nregs): Declare.
2296         * config/avr/avr.c (avr_can_eliminate): Simplify.
2297         (avr_initial_elimination_offset): Likewise.
2298         (avr_prologue_setup_frame): Use hard_frame_pointer_rtx.
2299         (expand_epilogue): Likewise.
2300         (avr_legitimize_address): Gut.
2301         (avr_legitimize_reload_address): Use hard_frame_pointer_rtx.
2302         (avr_hard_regno_nregs): New.
2303         (avr_hard_regno_ok): Allow only Pmode for arg and frame_pointers.
2304         (avr_regno_mode_code_ok_for_base_b): Handle arg and frame pointers.
2305         * config/avr/avr.h (FIXED_REGISTERS): Adjust arg pointer,
2306         add soft frame pointer.
2307         (CALL_USED_REGISTERS): Likewise.
2308         (REG_CLASS_CONTENTS): Likewise.
2309         (REGISTER_NAMES): Likewise.
2310         (HARD_REGNO_NREGS): Use avr_hard_regno_nregs.
2311         (HARD_FRAME_POINTER_REGNUM): New.
2312         (FRAME_POINTER_REGNUM): Use soft frame pointer.
2313         (ELIMINABLE_REGS): Eliminate from the soft frame pointer,
2314         remove the HARD_FRAME_POINTER self-elimination.
2315
2316 2012-01-12  Georg-Johann Lay  <avr@gjlay.de>
2317
2318         PR target/51756
2319         * config/avr/avr.c (avr_encode_section_info): Test for absence of
2320         DECL_EXTERNAL when checking for initializers of progmem variables.
2321
2322 2012-01-12  Ira Rosen  <irar@il.ibm.com>
2323
2324         PR tree-optimization/51799
2325         * tree-vect-patterns.c (vect_recog_over_widening_pattern): Check
2326         that the last operation is a type demotion.
2327
2328 2012-01-12  Uros Bizjak  <ubizjak@gmail.com>
2329
2330         * config/i386/i386.md (*zero_extendsidi2_rex64): Correct movl template.
2331         (x86_shift<mode>_adj_1): Remove operand constraint from operand 3.
2332
2333 2012-01-11  Jakub Jelinek  <jakub@redhat.com>
2334
2335         PR bootstrap/51796
2336         * combine.c (distribute_notes): If i3 is a noreturn call,
2337         allow old_size to be equal to args_size and make sure the
2338         noreturn call gets REG_ARGS_SIZE note.
2339         * expr.c (fixup_args_size_notes): Put REG_ARGS_SIZE notes
2340         on noreturn calls even when the delta is 0.
2341
2342 2012-01-11  Nathan Sidwell  <nathan@acm.org>
2343
2344         * gcov.c (STRING_SIZE): Remove.
2345         (generate_results): Erase annotations for source files with no
2346         coverage information.
2347         (read_line): New.
2348         (output_lines): Use it.
2349
2350 2012-01-11  Eric Botcazou  <ebotcazou@adacore.com>
2351
2352         * gimple.h (gimplify_body): Remove first argument.
2353         * gimplify.c (copy_if_shared): Add DATA argument.  Do not create the
2354         pointer set here, instead just pass DATA to walk_tree.
2355         (unshare_body): Remove BODY_P argument and adjust.  Create the pointer
2356         set here and invoke copy_if_shared on the size trees of DECL_RESULT.
2357         (unvisit_body): Likewise, but with unmark_visited.
2358         (gimplify_body): Remove BODY_P argument and adjust.
2359         (gimplify_function_tree): Adjust call to gimplify_body.
2360         * omp-low.c (finalize_task_copyfn): Likewise.
2361
2362 2012-01-11  Eric Botcazou  <ebotcazou@adacore.com>
2363
2364         * tree.h (build_function_decl_skip_args): Add boolean parameter.
2365         (build_function_type_skip_args): Delete.
2366         * tree.c (build_function_type_skip_args): Make static and add
2367         SKIP_RETURN parameter.  Fix thinko in the handling of variants.
2368         (build_function_decl_skip_args): Add SKIP_RETURN parameter and
2369         pass it to build_function_type_skip_args.
2370         * cgraph.h (cgraph_function_versioning): Add boolean parameter.
2371         (tree_function_versioning): Likewise.
2372         * cgraph.c (cgraph_create_virtual_clone): Adjust call to
2373         build_function_decl_skip_args.
2374         * cgraphunit.c (cgraph_function_versioning): Add SKIP_RETURN parameter
2375         and pass it to build_function_decl_skip_args/tree_function_versioning.
2376         (cgraph_materialize_clone): Adjust call to tree_function_versioning.
2377         * ipa-inline-transform.c (save_inline_function_body): Likewise.
2378         * trans-mem.c (ipa_tm_create_version): Likewise.
2379         * tree-sra.c (modify_function): Ditto for cgraph_function_versioning.
2380         * tree-inline.c (declare_return_variable): Remove always-true test.
2381         (tree_function_versioning): Add SKIP_RETURN parameter.  If the function
2382         returns non-void and SKIP_RETURN, create a void-typed RESULT_DECL.
2383         * ipa-split.c (split_function): Skip the return value for the split
2384         part if it doesn't return.
2385
2386 2012-01-11  Bill Schmidt  <wschmidt@linux.vnet.ibm.com>
2387
2388         PR tree-optimization/49642
2389         * ipa-split.c (forbidden_dominators): New variable.
2390         (check_forbidden_calls): New function.
2391         (dominated_by_forbidden): Likewise.
2392         (consider_split): Check for forbidden dominators.
2393         (execute_split_functions): Initialize and free forbidden
2394         dominators info; call check_forbidden_calls.
2395
2396 2012-01-11  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
2397
2398         * config/arm/arm.md (mov_notscc): Use MVN for false condition.
2399
2400 2012-01-11  Nick Clifton  <nickc@redhat.com>
2401
2402         * config/rx/rx.md (return): Define pattern.
2403
2404 2012-01-11  Richard Guenther  <rguenther@suse.de>
2405
2406         * doc/extend.texi (malloc attribute): Adjust according to
2407         implementation.
2408
2409 2012-01-10  Aldy Hernandez  <aldyh@redhat.com>
2410             Patrick Marlier  <patrick.marlier@gmail.com>
2411
2412         PR middle-end/51516
2413         * trans-mem.c (get_cg_data): Traverse aliases if requested.
2414         (ipa_tm_scan_calls_block): Update parameters to get_cg_data.
2415         (ipa_tm_note_irrevocable): Same.
2416         (ipa_tm_scan_irr_block): Same.
2417         (ipa_tm_decrement_clone_counts): Same.
2418         (ipa_tm_scan_irr_function): Same.
2419         (ipa_tm_create_version_alias): Same.
2420         (ipa_tm_create_version): Same.
2421         (ipa_tm_transform_calls_redirect): Same.
2422         (ipa_tm_transform_calls): Same.
2423         (ipa_tm_transform_transaction): Same.
2424         (ipa_tm_execute): Same.
2425
2426 2012-01-10  Richard Guenther  <rguenther@suse.de>
2427
2428         PR middle-end/51806
2429         * opts.c (common_handle_option): Handle -Werror.
2430
2431 2012-01-10  Andreas Schwab  <schwab@linux-m68k.org>
2432
2433         * config/m68k/sync.md ("atomic_compare_and_swap<mode>_1"): Fix
2434         operand number.
2435
2436 2012-01-10  Jason Merrill  <jason@redhat.com>
2437
2438         * doc/invoke.texi (C++ Dialect Options): Update -fabi-version=6
2439         information.
2440
2441 2012-01-10  Rainer Orth  <ro@CeBiTec.Uni-Bielefeld.DE>
2442
2443         * configure.ac (gcc_cv_as_ix86_tlsgdplt): Check if linker
2444         supports R_386_TLS_GD_PLT reloc.
2445         (gcc_cv_as_ix86_tlsldmplt): Check if linker
2446         supports R_386_TLS_LDM_PLT reloc.
2447         * configure: Regenerate.
2448         * config.in: Regenerate.
2449
2450 2012-01-10  Georg-Johann Lay  <avr@gjlay.de>
2451
2452         PR target/49868
2453         Extend __pgmx semantics to linearize memory.
2454         * config/avr/avr.md (mov<mode>): Use avr_xload_libgcc_p to
2455         determine if code comes inline or from libgcc.
2456         (MOVMEM_r_d:HI): Add "w" to constraint for better preference.
2457         (movmem_qi, movmem_qi): Set constraint #2 to "n".
2458         (movmem_qi_elpm, movmem_hi_elpm): Remove insns.
2459         (movmemx_qi, movmemx_hi): New insns.
2460         (xload_<mode>_libgcc): Rewrite to new insn condition.
2461         (xload_<mode>): Remove insns.
2462         * config/avr/avr.c (avr_out_xload): Rewrite: Only need to handle
2463         cases that don't satisfy avr_xload_libgcc_p().
2464         (avr_addr_space_convert): Allow converting in any direction.
2465         (avr_addr_space_subset_p): Return always true.
2466         (avr_xload_libgcc_p): Rewrite to fit new __pgmx semantics.
2467         (avr_emit_movmemhi): Ditto.
2468         (avr_out_lpm): No need to handle ADDR_SPACE_PGMX any more.
2469         (avr_out_movmem): Ditto.
2470         (AVR_SYMBOL_FLAG_PROGMEM): New macro.
2471         (AVR_SYMBOL_SET_ADDR_SPACE): New macro.
2472         (AVR_SYMBOL_GET_ADDR_SPACE): New macro.
2473         (avr_encode_section_info): Encode 'progmem' in symbol flags.
2474         (output_reload_in_const): Don't zero-extend any 24-bit symbols.
2475
2476 2012-01-10  Richard Guenther  <rguenther@suse.de>
2477
2478         PR tree-optimization/50913
2479         * graphite-scop-detection.c (stmt_has_simple_data_refs_p):
2480         Require data-refs to be representable by Graphite with respect
2481         to any loop nest.
2482
2483 2012-01-10  Uros Bizjak  <ubizjak@gmail.com>
2484
2485         * config/i386/constraints.md ("L"): Return true for 0xffffffff.
2486         * config/i386/i386.c (*anddi_1): Emit AND with 0xffffffff as MOV.
2487
2488 2012-01-10  Tom de Vries  <tom@codesourcery.com>
2489
2490         PR rtl-optimization/51271
2491         * dwarf2cfi.c (scan_trace): Save and restore cur_row->reg_save when
2492         handling annulled branch.
2493
2494 2012-01-10  Richard Henderson  <rth@redhat.com>
2495
2496         * config/arm/arm.c (arm_vectorize_vec_perm_const_ok,
2497         TARGET_VECTORIZE_VEC_PERM_CONST_OK, neon_split_vcombine, MAX_VECT_LEN,
2498         struct expand_vec_perm_d, arm_expand_vec_perm_1, arm_expand_vec_perm,
2499         arm_evpc_neon_vuzp, arm_evpc_neon_vzip, arm_evpc_neon_vrev,
2500         arm_evpc_neon_vtrn, arm_evpc_neon_vtbl, arm_expand_vec_perm_const_1,
2501         arm_expand_vec_perm_const): New.
2502         * config/arm/arm-protos.h: Update.
2503         * config/arm/neon.md (UNSPEC_VCONCAT): New.
2504         (*neon_vswp<VDQX>): New.
2505         (neon_vcombine<VDX>): Use neon_split_vcombine.
2506         (neon_vtbl1v16qi, neon_vtbl2v16qi, neon_vcombinev16qi): New.
2507         * config/arm/vec-common.md (vec_perm_const<VALL>): New.
2508         (vec_perm<VE>): New.
2509
2510 2012-01-10  Richard Henderson  <rth@redhat.com>
2511
2512         * config/arm/arm.c (arm_gen_compare_reg): Add scratch argument;
2513         use it if reload_completed.
2514         (arm_legitimize_sync_memory, arm_emit, arm_insn_count, arm_count,
2515         arm_output_asm_insn, arm_process_output_memory_barrier,
2516         arm_output_memory_barrier, arm_ldrex_suffix, arm_output_ldrex,
2517         arm_output_strex, arm_output_it, arm_output_op2, arm_output_op3,
2518         arm_output_sync_loop, arm_get_sync_operand, FETCH_SYNC_OPERAND,
2519         arm_process_output_sync_insn, arm_output_sync_insn,
2520         arm_sync_loop_insns, arm_call_generator, arm_expand_sync): Remove.
2521         (arm_pre_atomic_barrier, arm_post_atomic_barrier): New.
2522         (arm_emit_load_exclusive, arm_emit_store_exclusive): New.
2523         (emit_unlikely_jump): New.
2524         (arm_expand_compare_and_swap, arm_split_compare_and_swap): New.
2525         (arm_split_atomic_op): New.
2526         * config/arm/arm-protos.h: Update.
2527         * config/arm/arm.h (enum arm_sync_generator_tag): Remove.
2528         (struct arm_sync_generator): Remove.
2529         * config/arm/arm.md (VUNSPEC_SYNC_COMPARE_AND_SWAP, VUNSPEC_SYNC_LOCK,
2530         VUNSPEC_SYNC_OP, VUNSPEC_SYNC_NEW_OP, VUNSPEC_SYNC_OLD_OP): Remove.
2531         (VUNSPEC_ATOMIC_CAS, VUNSPEC_ATOMIC_XCHG, VUNSPEC_ATOMIC_OP): New.
2532         (VUNSPEC_LL, VUNSPEC_SC): New.
2533         (sync_result, sync_memory, sync_required_value, sync_new_value,
2534         sync_t1, sync_t2, sync_release_barrier, sync_op): Remove.
2535         (attr length): Don't use arm_sync_loop_insns.
2536         (cbranch_cc, cstore_cc): Update call to arm_gen_compare_reg.
2537         (movsfcc, movdfcc): Likewise.
2538         * config/arm/constraints.md (Ua): New.
2539         * config/arm/prediates.md (mem_noofs_operand): New.
2540         (sync_compare_and_swap<QHSD>, sync_lock_test_and_set<QHSD>): Remove.
2541         (sync_clobber, sync_t2_reqd): Remove.
2542         (sync_<syncop><QHSD>, sync_nand<QHSD>): Remove.
2543         (sync_new_<syncop><QHSD>, sync_new_nand<QHSD>): Remove.
2544         (sync_old_<syncop><QHSD>, sync_old_nand<QHSD>): Remove.
2545         (arm_sync_compare_and_swap<SIDI>): Remove.
2546         (arm_sync_compare_and_swap<NARROW>): Remove.
2547         (arm_sync_lock_test_and_set<SIDI>): Remove.
2548         (arm_sync_lock_test_and_set<NARROW>): Remove.
2549         (arm_sync_new_<syncop><SIDI>): Remove.
2550         (arm_sync_new_<syncop><NARROW>): Remove.
2551         (arm_sync_new_nand<SIDI>): Remove.
2552         (arm_sync_new_nand<NARROW>): Remove.
2553         (arm_sync_old_<syncop><SIDI>): Remove.
2554         (arm_sync_old_<syncop><NARROW>): Remove.
2555         (arm_sync_old_nand<SIDI>): Remove.
2556         (arm_sync_old_nand<NARROW>): Remove.
2557         (*memory_barrier): Merge arm_output_memory_barrier.
2558         (atomic_compare_and_swap<QHSD>): New.
2559         (atomic_compare_and_swap<NARROW>_1): New.
2560         (atomic_compare_and_swap<SIDI>_1): New.
2561         (atomic_exchange<QHSD>): New.
2562         (cas_cmp_operand, cas_cmp_str): New.
2563         (atomic_op_operand, atomic_op_str): New.
2564         (atomic_<syncop><QHSD>, atomic_nand<QHSD>): New.
2565         (atomic_fetch_<syncop><QHSD>, atomic_fetch_nand<QHSD>): New.
2566         (atomic_<syncop>_fetch<QHSD>, atomic_nand_fetch<QHSD>): New.
2567         (arm_load_exclusive<NARROW>): New.
2568         (arm_load_exclusivesi, arm_load_exclusivedi): New.
2569         (arm_store_exclusive<QHSD>): New.
2570
2571 2012-01-09  Michael Meissner  <meissner@linux.vnet.ibm.com>
2572
2573         * config/rs6000/rs6000.c (rs6000_init_hard_regno_mode_ok): Add DF
2574         reload patterns if -mvsx-scalar-memory.
2575
2576         * config/rs6000/vsx.md (vsx_xscvspdp): Allow xscvspdp to be
2577         generated, even -mno-vsx-scalar-double was used.
2578         (vsx_xscvdpsp_scalar): Likewise.
2579         (vsx_xscvspdp_scalar2): Likewise.
2580
2581 2012-01-09  Tom de Vries  <tom@codesourcery.com>
2582             Andrew Pinski  <apinski@cavium.com>
2583
2584         PR debug/51471
2585         * reorg.c (fill_slots_from_thread): Don't speculate
2586         frame-related insns.
2587
2588 2012-01-09  Richard Sandiford  <rdsandiford@googlemail.com>
2589
2590         * sched-int.h (bb_note): Move to...
2591         * basic-block.h: ...here.
2592         * haifa-sched.c (bb_note): Move to...
2593         * cfgrtl.c: ...here.
2594         * function.c (next_block_for_reg): New function.
2595         (move_insn_for_shrink_wrap): Likewise.
2596         (prepare_shrink_wrap): Rewrite to use the above.
2597
2598 2012-01-09  Aldy Hernandez  <aldyh@redhat.com>
2599
2600         * gimple.c (is_gimple_non_addressable): Remove.
2601         * gimple.h: Remove is_gimple_non_addressable.
2602         * gimplify.c (gimplify_modify_expr_rhs): Use is_gimple_reg instead of
2603         is_gimple_non_addressable.
2604         * trans-mem.c (expand_assign_tm): Same.
2605
2606 2012-01-09  Richard Guenther  <rguenther@suse.de>
2607
2608         PR tree-optimization/51775
2609         * tree-ssa-sccvn.c (visit_use): Value-number throwing stmts.
2610         * tree-ssa-pre.c (eliminate): Properly fixup EH info.
2611
2612 2012-01-09  Matthew Gretton-Dann  <matthew.gretton-dann@arm.com>
2613
2614         * config/arm/arm-cores.def (cortex-a15): Use cortex_a15_tune for
2615         tuning parameters.
2616         * config/arm/arm.c (arm_cortex_a15_tune): New static variable.
2617
2618 2012-01-09  Richard Guenther  <rguenther@suse.de>
2619
2620         * tree-streamer-out.c (write_ts_optimization): Fix spelling.
2621
2622 2012-01-08  Jan Hubicka  <jh@suse.cz>
2623
2624         PR tree-optimize/51680
2625         * ipa-inline-analyss.c (evaluate_properties_for_edge): Fix condition
2626         on when known_vals needs to be computed; cleanup.
2627
2628 2012-01-08  Jan Hubicka  <jh@suse.cz>
2629
2630         PR tree-optimize/51694
2631         * ipa-cp.c (ipa_get_indirect_edge_target): Add bounds checks.
2632
2633 2012-01-08  Jonathan Wakely  <jwakely.gcc@gmail.com>
2634
2635         * doc/cpp.texi (Predefined Macros): __STRICT_ANSI__ is defined
2636         for -std=c++98 and -std=c++11 too.
2637
2638 2012-01-08  Chung-Lin Tang  <cltang@codesourcery.com>
2639
2640         * cfgloop.c (cancel_loop): Add free() of bbs array.
2641
2642 2012-01-07  Jan Hubicka  <jh@suse.cz>
2643
2644         PR tree-optimization/51600
2645         * ipa-inline-analysis.c (estimate_edge_devirt_benefit): Disable code
2646         that benefits small functions.
2647
2648 2012-01-07  Jan Hubicka  <jh@suse.cz>
2649
2650         * ipa-inline.c (want_inline_small_function_p): Fix formating.
2651
2652 2012-01-07  Jan Hubicka  <jh@suse.cz>
2653
2654         PR tree-optimization/51680
2655         * ipa-inline.c (want_inline_small_function_p): Be more lax on functions
2656         whose inlining reduce unit size.
2657
2658 2012-01-07  Alexandre Oliva  <aoliva@redhat.com>
2659
2660         PR bootstrap/51725
2661         * cselib.c (new_elt_loc_list): Promote addr_list to canonical node.
2662         Add canonical node to containing_mem chain after the non-canonical
2663         one, even if there weren't any locs to propagate.
2664         (remove_useless_values): Keep only canonical values.
2665         (add_mem_for_addr, cselib_lookup_mem): Canonicalize addr.
2666         (cselib_invalidate_mem): Likewise.  Ensure v is canonical, and
2667         canonicalize mem_chain elements that are not discarded.
2668
2669 2012-01-06  Jakub Jelinek  <jakub@redhat.com>
2670
2671         PR target/47333
2672         * cgraphunit.c (cgraph_optimize): Call output_weakrefs
2673         before emitting functions.
2674
2675         PR gcov-profile/50127
2676         * bb-reorder.c (partition_hot_cold_basic_blocks): Call
2677         clear_aux_for_blocks.
2678
2679 2012-01-06  Alexandre Oliva  <aoliva@redhat.com>
2680
2681         PR debug/51746
2682         * cselib.c (cselib_hash_rtx): Hash incoming VALUEs too.
2683
2684 2012-01-06  Arnaud Charlet  <charlet@adacore.com>
2685
2686         * c-decl.c (ext_block): Moved up.
2687         (collect_all_refs, for_each_global_decl): Take ext_block into account.
2688
2689 2012-01-06  Han Shen  <shenhan@google.com>
2690
2691         Translate built-in include paths for sysroot.
2692         * Makefile.in (gcc_gxx_include_dir_add_sysroot): New.
2693         (PREPROCESSOR_DEFINES): Define GPLUSPLUS_INCLUDE_DIR_ADD_SYSROOT.
2694
2695         * cppdefault.c (cpp_include_defaults): Replace hard coded "0" with
2696         GPLUSPLUS_INCLUDE_DIR_ADD_SYSROOT for "add_sysroot" field.
2697
2698         * configure.ac (AC_SUBST): Add gcc_gxx_include_dir_add_sysroot to
2699         control whether sysroot should be prepended to gxx include dir.
2700
2701         * configure: Regenerate.
2702
2703 2012-01-06  Torvald Riegel  <triegel@redhat.com>
2704
2705         PR rtl-optimization/51771
2706         * builtin-attrs.def (ATTR_RETURNS_TWICE, ATTR_TM_NOTHROW_RT_LIST): New.
2707         * gtm-builtins.def (BUILT_IN_TM_START): Add returns-twice attrib.
2708
2709 2012-01-05  Eric Botcazou  <ebotcazou@adacore.com>
2710
2711         PR tree-optimization/51315
2712         * tree-sra.c (tree_non_aligned_mem_for_access_p): New predicate.
2713         (build_accesses_from_assign): Use it instead of tree_non_aligned_mem_p.
2714
2715 2012-01-05  Uros Bizjak  <ubizjak@gmail.com>
2716
2717         PR target/51681
2718         * config/ia64/ia64.c (expand_vec_perm_shrp): Use correct operands
2719         for shrp pattern.  Correctly handle and fixup shift variable.
2720         Return false when shift > nelt for BYTES_BIG_ENDIAN target.
2721
2722 2012-01-05  Jakub Jelinek  <jakub@redhat.com>
2723
2724         PR debug/51762
2725         * calls.c (emit_call_1): For noreturn calls force a REG_ARGS_SIZE
2726         note when !ACCUMULATE_OUTGOING_ARGS.
2727
2728 2012-01-05  Eric Botcazou  <ebotcazou@adacore.com>
2729
2730         * tree-vrp.c (extract_range_from_binary_expr_1): Remove duplicated
2731         condition.
2732         (extract_range_from_unary_expr_1): Avoid useless computations.
2733
2734 2012-01-05  Jakub Jelinek  <jakub@redhat.com>
2735
2736         PR rtl-optimization/51767
2737         * cfgrtl.c (force_nonfallthru_and_redirect): Force addition
2738         of jump_block and add an extra edge for degenerated asm gotos.
2739
2740         PR middle-end/51768
2741         * stmt.c (check_unique_operand_names): Don't ICE during error
2742         reporting if i is from labels chain.
2743
2744         PR middle-end/44777
2745         * profile.c (branch_prob): Split bbs that have exit edge
2746         and need a fake entry edge too.
2747
2748 2012-01-05  Jan Hubicka  <jh@suse.cz>
2749
2750         PR middle-end/49710
2751         * cfgloopmanip.c (remove_path): Walk loop hiearchy upwards when
2752         unlooping loops.
2753
2754 2012-01-05  Richard Guenther  <rguenther@suse.de>
2755
2756         PR lto/50490
2757         * tree-streamer-out.c (write_ts_optimization): New function.
2758         (streamer_write_tree_body): Call it.
2759         * tree-streamer-in.c (lto_input_ts_optimization): New function.
2760         (streamer_read_tree_body): Call it.
2761         * lto-streamer-out.c (lto_is_streamable): Handle OPTIMIZATION_NODE.
2762
2763 2012-01-05  Jakub Jelinek  <jakub@redhat.com>
2764
2765         PR middle-end/51761
2766         * gimple.h (struct gimplify_ctx): Add in_cleanup_point_expr field.
2767         * gimplify.c (gimplify_cleanup_point_expr): Save and set
2768         in_cleanup_point_expr before gimplify_stmt call and restore it
2769         afterwards.
2770         (gimplify_target_expr): Don't add {CLOBBER} cleanup if
2771         in_cleanup_point_expr is false.
2772
2773 2012-01-05  Richard Guenther  <rguenther@suse.de>
2774
2775         PR middle-end/51764
2776         * common.opt (Wmudflap, fmudflap, fmudflapth, fmudflapir): Move
2777         to c.opt.
2778         * toplev.c (process_options): Reject combining mudflap and LTO.
2779         * tree-nomudflap.c (nogo): Use sorry instead of internal_error.
2780
2781 2012-01-05  Richard Guenther  <rguenther@suse.de>
2782
2783         PR tree-optimization/51760
2784         * tree-ssa-ccp.c (likely_value): Drop UNDEFINED to CONSTANT,
2785         not VARYING.
2786         (bit_value_unop): Handle UNDEFINED operands.
2787         (bit_value_binop): Likewise.
2788
2789 2012-01-05  Georg-Johann Lay  <avr@gjlay.de>
2790
2791         * config/avr/avr.c (avr_replace_prefix): Remove.
2792         (avr_asm_named_section): Use ACONCAT instead of avr_replace_prefix.
2793         (avr_asm_function_rodata_section): Ditto.
2794         (avr_asm_select_section): Ditto.
2795
2796 2012-01-05  Marcus Shawcroft  <marcus.shawcroft@arm.com>
2797
2798         * reload.c (find_reloads): Adjust LABEL_NUSES on REG_LABEL_OPERAND
2799         insertion.
2800
2801 2012-01-05  Jakub Jelinek  <jakub@redhat.com>
2802
2803         PR bootstrap/51648
2804         * tree-cfg.c (need_fake_edge_p): Return true also for noreturn
2805         calls that have any non-fake successor edges.
2806
2807         PR debug/51746
2808         * var-tracking.c (add_stores): For COND_EXEC allow oval to be NULL.
2809
2810 2012-01-04  Eric Botcazou  <ebotcazou@adacore.com>
2811
2812         PR tree-optimization/51624
2813         * tree-sra.c (build_ref_for_model): When replicating a chain of
2814         COMPONENT_REFs, stop as soon as the offset would become negative.
2815
2816 2012-01-04  Jakub Jelinek  <jakub@redhat.com>
2817
2818         PR debug/51695
2819         * dwarf2out.c (output_loc_list): For now drop >= 64KB expressions
2820         in .debug_loc on the floor.
2821
2822 2012-01-04  Andrew Pinski  <apinski@cavium.com>
2823
2824         * doc/invoke.texi (-march=@var{arch}): Add octeon+ and octeon2.
2825
2826 2012-01-04  Andrew Pinski  <apinski@cavium.com>
2827             Adam Nemet  <anemet@caviumnetworks.com>
2828
2829         * config/mips/mips.md (size): Add SI and DI.
2830         (SIZE): New mode attribute.
2831         (U): New code attribute.
2832         * config/mips/mips-dsp.md (mips_lbux): Use gen_mips_lbux_extsi.
2833         (mips_lbux_<mode>): Delete.
2834         (mips_l<SHORT:size><u>x_ext<GPR:mode>_<P:mode>): New pattern.
2835         (mips_lhx): Use gen_mips_lhx_extsi.
2836         (mips_lhx_<mode>): Delete.
2837         (mips_lwx): Delete.
2838         (mips_l<size>x): New expand.
2839         (mips_lwx_<mode>): Delete.
2840         (mips_l<GPR:size>x_<P:mode>): New pattern.
2841         (*mips_lw<u>x_<P:mode>_ext): Likewise.
2842         * config/mips/mips-ftypes.def: Add DI f(POINTER, SI) function type.
2843         * config/mips/mips.c (mips_lx_address_p): New function.
2844         (mips_rtx_costs <case MEM>): Call mips_lx_address_p.
2845         (dsp64): New availability predicate.
2846         (mips_builtins): Add an entry for __builtin_mips_ldx.
2847         * config/mips/mips.h (ISA_HAS_LBX): New define.
2848         (ISA_HAS_LBUX): Likewise.
2849         (ISA_HAS_LHX): Likewise.
2850         (ISA_HAS_LHUX): Likewise.
2851         (ISA_HAS_LWX): Likewise.
2852         (ISA_HAS_LWUX): Likewise.
2853         (ISA_HAS_LDX): Likewise.
2854         * doc/extend.texi (__builtin_mips_ldx): Document.
2855
2856 2012-01-04  Tristan Gingold  <gingold@adacore.com>
2857
2858         * config/vms/xm-vms.h (HOST_LONG_FORMAT, HOST_PTR_PRINTF): Define
2859         when long pointers are used.
2860         * config.build (*-*-*vms*): Handle all OpenVMS targets.
2861         (alpha64-dec-*vms*, alpha*-dec-*vms*)
2862         (ia64-hp-*vms*): Remove.
2863         * config/vms/xm-vms64.h: Delete.
2864
2865 2012-01-04  Aldy Hernandez  <aldyh@redhat.com>
2866
2867         PR middle-end/51472
2868         * trans-mem.c (expand_assign_tm): Handle TM_MEMMOVE loads correctly.
2869
2870 2012-01-04  Aldy Hernandez  <aldyh@redhat.com>
2871
2872         * opts.c (finish_options): Remove duplicate sorry.
2873
2874 2012-01-04  Aldy Hernandez  <aldyh@redhat.com>
2875
2876         PR middle-end/51696
2877         * trans-mem.c (diagnose_tm_1): Display indirect calls with no name
2878         correctly.
2879
2880 2012-01-04  Richard Guenther  <rguenther@suse.de>
2881
2882         PR middle-end/51750
2883         * tree.c (size_low_cst): New function.
2884         * tree.h (size_low_cst): Declare.
2885         * fold-const.c (fold_comparison): Use it to extract the low
2886         part of the POINTER_PLUS_EXPR offset.
2887
2888 2012-01-04  Georg-Johann Lay  <avr@gjlay.de>
2889
2890         Fix clearing ZERO_REG
2891         * config/avr/avr.md (cc): Add alternative "ldi".
2892         (movqi_insn): Use it in cc attribute.
2893         * config/avr/avr.c (notice_update_cc): Handle CC_LDI.
2894         (output_reload_in_const): Use CLR to move 0 to ZERO_REG.
2895         (output_reload_insisf): Use ZERO_REG to pre-clear register.
2896
2897 2012-01-04  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2898
2899         * configure: Regenerate.
2900
2901 2012-01-04  Richard Guenther  <rguenther@suse.de>
2902
2903         PR tree-optimization/49651
2904         * tree-ssa-structalias.c (type_can_have_subvars): New function.
2905         (var_can_have_subvars): Use it.
2906         (get_constraint_for_1): Only consider subfields if there can be any.
2907
2908 2012-01-03  Jakub Jelinek  <jakub@redhat.com>
2909
2910         PR bootstrap/51725
2911         * cselib.c (new_elt_loc_list): When moving locs from one cselib_val
2912         to its new canonical_cselib_val and the cselib_val was in
2913         first_containing_mem chain, but the canonical_cselib_val was not,
2914         add the latter into the chain.
2915         (cselib_invalidate_mem): Compare canonical_cselib_val of
2916         addr_list chain elt with v.
2917
2918         PR pch/51722
2919         * dwarf2out.c (dwarf2out_start_source_file, dwarf2out_define,
2920         dwarf2out_undef): Allocate e.info using ggc_strdup instead
2921         of xstrdup.
2922         (output_macinfo_op): Don't ggc_strdup fd->filename.
2923         (optimize_macinfo_range): Allocate grp_name using XALLOCAVEC,
2924         then ggc_strdup it.  Don't free inc->info or cur->info.
2925         (output_macinfo): Don't free ref->info or file->info.
2926
2927 2012-01-03  Ira Rosen  <irar@il.ibm.com>
2928
2929         PR tree-optimization/51269
2930         * tree-vect-loop-manip.c (set_prologue_iterations): Make
2931         first_niters a pointer.
2932         (slpeel_tree_peel_loop_to_edge): Likewise.
2933         (vect_do_peeling_for_loop_bound): Update call to
2934         slpeel_tree_peel_loop_to_edge.
2935         (vect_gen_niters_for_prolog_loop): Don't compute wide_prolog_niters
2936         here.  Remove it from the parameters list.
2937         (vect_do_peeling_for_alignment): Update calls and compute
2938         wide_prolog_niters.
2939
2940 2012-01-03  Richard Guenther  <rguenther@suse.de>
2941
2942         PR tree-optimization/51070
2943         * tree-loop-distribution.c (stmt_has_scalar_dependences_outside_loop):
2944         Properly handle calls.
2945
2946 2012-01-03  Richard Guenther  <rguenther@suse.de>
2947
2948         PR tree-optimization/51692
2949         * tree-ssa-dce.c (eliminate_unnecessary_stmts): Do not remove
2950         the LHS of allocation stmts.
2951
2952 2012-01-03  Olivier Hainque  <hainque@adacore.com>
2953
2954         * system.h: Prior to #define, #undef fopen and freopen unconditionally.
2955
2956 2012-01-03  Olivier Hainque  <hainque@adacore.com>
2957
2958         * collect2.c (main): In AIX specific computations for vector
2959         insertions, use CONST_CAST2 to cast from char ** to const char **.
2960
2961 2012-01-03  Richard Guenther  <rguenther@suse.de>
2962
2963         PR debug/51650
2964         * dwarf2out.c (dwarf2out_finish): Always create a DIE for
2965         the context of a limbo DIE when it does not already exist.
2966
2967 2012-01-03  Jakub Jelinek  <jakub@redhat.com>
2968
2969         PR tree-optimization/51719
2970         * value-prof.c (gimple_ic): When indirect call isn't noreturn,
2971         but direct call is, clear direct call's lhs and don't add fallthrough
2972         edge from dcall_bb to join_bb and PHIs.
2973
2974 2012-01-03  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
2975
2976         * config/s390/s390.md ("*cmp<mode>_ccs"): Fix comment mentioning
2977         the instructions emitted by the pattern.
2978         ("*TDC_insn_<mode>"): Add comment.
2979
2980 2012-01-03  Richard Guenther  <rguenther@suse.de>
2981
2982         PR middle-end/51730
2983         * fold-const.c (fold_comparison): Properly canonicalize
2984         tree offset and HOST_WIDE_INT bit position.
2985
2986 2012-01-02  Uros Bizjak  <ubizjak@gmail.com>
2987
2988         * config/ia64/ia64.c (expand_vec_perm_broadcast): Use correct
2989         operands for extzv pattern.
2990
2991 2012-01-02  Jakub Jelinek  <jakub@redhat.com>
2992
2993         PR bootstrap/51725
2994         * cselib.c (add_mem_for_addr): Call canonical_cselib_val
2995         on mem_elt first.
2996
2997 2012-01-02  Sandra Loosemore  <sandra@codesourcery.com>
2998
2999         * doc/invoke.texi (-flto and related options): Copy-edit.
3000
3001 2012-01-02  Richard Sandiford  <rdsandiford@googlemail.com>
3002
3003         * config/mips/mips.md (loadgp_newabi_<mode>): Add missing earlyclobber.
3004
3005 2012-01-02  Jakub Jelinek  <jakub@redhat.com>
3006
3007         * config/i386/sse.md (*avx2_gatherdi<mode>_3, *avx2_gatherdi<mode>_4):
3008         New patterns.
3009
3010 2012-01-02  Richard Sandiford  <rdsandiford@googlemail.com>
3011
3012         * expr.h (move_by_pieces_ninsns): Declare.
3013         * expr.c (move_by_pieces_ninsns): Make external.
3014         * config/mips/mips-protos.h (mips_move_by_pieces_p): Declare.
3015         (mips_store_by_pieces_p): Likewise.
3016         * config/mips/mips.h (MOVE_BY_PIECES_P): Call mips_move_by_pieces_p.
3017         (STORE_BY_PIECES_P): Likewise mips_store_by_pieces_p.
3018         * config/mips/mips.c (mips_move_by_pieces_p): New function.
3019         (mips_store_by_pieces_p): Likewise.
3020
3021 2012-01-02  Jakub Jelinek  <jakub@redhat.com>
3022
3023         * passes.c (register_one_dump_file): Free full_name.
3024
3025         * reload1.c (reload): Don't allocate reg_max_ref_width here.
3026         (calculate_elim_costs_all_insns): Free offsets_at and
3027         offsets_known_at at the end and clear the pointers.
3028
3029 2012-01-02  Georg-Johann Lay  <avr@gjlay.de>
3030
3031         * config/avr/avr.opt (-mbranch-cost): Fix double definition of
3032         this option introduced in r180739.
3033
3034 2012-01-02  Georg-Johann Lay  <avr@gjlay.de>
3035
3036         PR target/51345
3037         * config.gcc (tm_file target=avr]): Add avr/avr-multilib.h
3038         (tmake_file target=avr): Add avr/t-multilib.
3039
3040         * config/avr/avr-c.c (avr_cpu_cpp_builtins): Use AVR_HAVE_8BIT_SP
3041         to built-in define __AVR_HAVE_8BIT_SP__, __AVR_HAVE_16BIT_SP__.
3042         * config/avr/genmultilib.awk: New file.
3043         * config/avr/t-multilib: New auto-generated file.
3044         * config/avr/multilib.h: New auto-generated file.
3045         * config/avr/t-avr (AVR_MCUS): New variable.
3046         (genopt.sh): Use it.
3047         (s-mlib): Depend on t-multilib.
3048         (t-multilib, multilib.h): New dependencies.
3049         (s-avr-mlib): New rule to build t-multilib, multilib.h from AVR_MCUS.
3050         (MULTILIB_OPTIONS): Remove.
3051         (MULTILIB_MATCHES): Remove.
3052         (MULTILIB_DIRNAMES): Remove.
3053         (MULTILIB_EXCEPTIONS): Remove:
3054         * config/avr/genopt.sh: Don't use hard coded file name;
3055         pass AVR_MCUS from t-avr instead.
3056
3057 2012-01-02  Georg-Johann Lay  <avr@gjlay.de>
3058
3059         * config/avr/avr.c (avr_out_ashrpsi3): Fix "case 31" to "case 23".
3060
3061 2012-01-02  Georg-Johann Lay  <avr@gjlay.de>
3062
3063         Implement light-weight DImode support.
3064         * config/avr/avr-dimode.md: New file.
3065         * config/avr/avr.md: Include it.
3066         (adjust_len): Add plus64, compare64.
3067         (HIDI): Remove code iterator.
3068         (code_stdname): New code attribute.
3069         (rotx, rotsmode): Remove DI.
3070         (rotl<mode>3, *rotw<mode>, *rotb<mode>): Use HISI instead of HIDI
3071         as code iterator.
3072         * config/avr/avr-protos.h (avr_have_dimode): New.
3073         (avr_out_plus64, avr_out_compare64): New.
3074         * config/avr/avr.c (avr_out_compare): Handle DImode.
3075         (avr_have_dimode): New variable definition and initialization.
3076         (avr_out_compare64, avr_out_plus64): New functions.
3077         (avr_out_plus_1): Use simplify_unary_operation to negate xval.
3078         (adjust_insn_length): Handle ADJUST_LEN_COMPARE64, ADJUST_LEN_PLUS64.
3079         (avr_compare_pattern): Skip DImode comparisons.
3080
3081 2012-01-02  Revital Eres  <revital.eres@linaro.org>
3082
3083         * ddg.c (def_has_ccmode_p): New function.
3084         (add_cross_iteration_register_deps,
3085         create_ddg_dep_from_intra_loop_link): Call it.
3086
3087 2012-01-02  Richard Guenther  <rguenther@suse.de>
3088
3089         PR other/51679
3090         * invoke.texi (fassociative-math): Remove spurious paranthesis.
3091
3092 2012-01-01  Jakub Jelinek  <jakub@redhat.com>
3093
3094         * gcc.c (process_command): Update copyright notice dates.
3095         * gcov.c (print_version): Likewise.
3096         * gcov-dump.c (print_version): Likewise.
3097         * mips-tfile.c (main): Likewise.
3098         * mips-tdump.c (main): Likewise.
3099
3100 2012-01-01  Ira Rosen  <irar@il.ibm.com>
3101
3102         PR tree-optimization/51704
3103         * tree-vect-slp.c (vect_detect_hybrid_slp_stmts): Check that
3104         a use is inside the basic block or loop before accessing its vect info.
3105
3106 2012-01-01  Jan Hubicka  <jhjh@suse.cz>
3107
3108         PR rtl-optimization/51069
3109         * cfgloopmanip.c (remove_path): Removing path making irreducible
3110         region unconditional makes BB part of the region.
3111
3112 2012-01-01  Jakub Jelinek  <jakub@redhat.com>
3113
3114         PR tree-optimization/51683
3115         * tree-ssa-propagate.c (substitute_and_fold): Don't optimize away
3116         calls with side-effects.
3117         * tree-ssa-ccp.c (ccp_fold_stmt): Likewise.
3118 \f
3119 Copyright (C) 2012 Free Software Foundation, Inc.
3120
3121 Copying and distribution of this file, with or without modification,
3122 are permitted in any medium without royalty provided the copyright
3123 notice and this notice are preserved.