OSDN Git Service

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